/*
- * Copyright (c) 2020 Samsung Electronics Co., Ltd.
+ * Copyright (c) 2023 Samsung Electronics Co., Ltd.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
#include <dali/internal/window-system/common/event-handler.h>
// EXTERNAL INCLUDES
-#include <cstring>
#include <sys/time.h>
+#include <cstring>
#include <dali/devel-api/events/touch-point.h>
-#include <dali/public-api/events/key-event.h>
-#include <dali/public-api/events/wheel-event.h>
#include <dali/integration-api/debug.h>
+#include <dali/integration-api/events/hover-event-integ.h>
#include <dali/integration-api/events/key-event-integ.h>
#include <dali/integration-api/events/touch-event-integ.h>
-#include <dali/integration-api/events/hover-event-integ.h>
#include <dali/integration-api/events/wheel-event-integ.h>
+#include <dali/public-api/events/key-event.h>
+#include <dali/public-api/events/wheel-event.h>
// INTERNAL INCLUDES
-#include <dali/internal/clipboard/common/clipboard-impl.h>
+#include <dali/internal/text-clipboard/common/text-clipboard-impl.h>
#include <dali/internal/styling/common/style-monitor-impl.h>
#include <dali/internal/window-system/common/window-render-surface.h>
namespace Dali
{
-
namespace Internal
{
-
namespace Adaptor
{
-
#if defined(DEBUG_ENABLED)
namespace
{
} // unnamed namespace
#endif
-EventHandler::EventHandler( WindowBase* windowBase, DamageObserver& damageObserver )
-: mStyleMonitor( StyleMonitor::Get() ),
- mDamageObserver( damageObserver ),
- mClipboardEventNotifier( ClipboardEventNotifier::Get() ),
- mClipboard( Clipboard::Get() ),
- mPaused( false )
+EventHandler::EventHandler(WindowBase* windowBase, DamageObserver& damageObserver)
+: mStyleMonitor(StyleMonitor::Get()),
+ mDamageObserver(damageObserver),
+ mClipboardEventNotifier(),
+ mPaused(false)
{
// Connect signals
- if( windowBase )
+ if(windowBase)
{
- windowBase->WindowDamagedSignal().Connect( this, &EventHandler::OnWindowDamaged );
- windowBase->FocusChangedSignal().Connect( this, &EventHandler::OnFocusChanged );
- windowBase->RotationSignal().Connect( this, &EventHandler::OnRotation );
- windowBase->TouchEventSignal().Connect( this, &EventHandler::OnTouchEvent );
- windowBase->WheelEventSignal().Connect( this, &EventHandler::OnWheelEvent );
- windowBase->KeyEventSignal().Connect( this, &EventHandler::OnKeyEvent );
- windowBase->SelectionDataSendSignal().Connect( this, &EventHandler::OnSelectionDataSend );
- windowBase->SelectionDataReceivedSignal().Connect( this, &EventHandler::OnSelectionDataReceived );
- windowBase->StyleChangedSignal().Connect( this, &EventHandler::OnStyleChanged );
+ windowBase->WindowDamagedSignal().Connect(this, &EventHandler::OnWindowDamaged);
+ windowBase->FocusChangedSignal().Connect(this, &EventHandler::OnFocusChanged);
+ windowBase->RotationSignal().Connect(this, &EventHandler::OnRotation);
+ windowBase->TouchEventSignal().Connect(this, &EventHandler::OnTouchEvent);
+ windowBase->WheelEventSignal().Connect(this, &EventHandler::OnWheelEvent);
+ windowBase->KeyEventSignal().Connect(this, &EventHandler::OnKeyEvent);
+ windowBase->SelectionDataSendSignal().Connect(this, &EventHandler::OnSelectionDataSend);
+ windowBase->SelectionDataReceivedSignal().Connect(this, &EventHandler::OnSelectionDataReceived);
+ windowBase->StyleChangedSignal().Connect(this, &EventHandler::OnStyleChanged);
}
else
{
{
}
-void EventHandler::SendEvent( StyleChange::Type styleChange )
+void EventHandler::SendEvent(StyleChange::Type styleChange)
{
- DALI_ASSERT_DEBUG( mStyleMonitor && "StyleMonitor Not Available" );
- GetImplementation( mStyleMonitor ).StyleChanged(styleChange);
+ DALI_ASSERT_DEBUG(mStyleMonitor && "StyleMonitor Not Available");
+ GetImplementation(mStyleMonitor).StyleChanged(styleChange);
}
-void EventHandler::SendEvent( const DamageArea& area )
+void EventHandler::SendEvent(const DamageArea& area)
{
- mDamageObserver.OnDamaged( area );
+ mDamageObserver.OnDamaged(area);
}
void EventHandler::Pause()
mPaused = false;
}
-void EventHandler::OnTouchEvent( Integration::Point& point, uint32_t timeStamp )
+void EventHandler::OnTouchEvent(Integration::Point& point, uint32_t timeStamp)
{
- for ( ObserverContainer::iterator iter = mObservers.begin(), endIter = mObservers.end(); iter != endIter; ++iter )
+ for(ObserverContainer::iterator iter = mObservers.begin(), endIter = mObservers.end(); iter != endIter; ++iter)
{
- (*iter)->OnTouchPoint( point, timeStamp );
+ (*iter)->OnTouchPoint(point, timeStamp);
}
}
-void EventHandler::OnWheelEvent( Integration::WheelEvent& wheelEvent )
+void EventHandler::OnWheelEvent(Integration::WheelEvent& wheelEvent)
{
- for ( ObserverContainer::iterator iter = mObservers.begin(), endIter = mObservers.end(); iter != endIter; ++iter )
+ for(ObserverContainer::iterator iter = mObservers.begin(), endIter = mObservers.end(); iter != endIter; ++iter)
{
- (*iter)->OnWheelEvent( wheelEvent );
+ (*iter)->OnWheelEvent(wheelEvent);
}
}
-void EventHandler::OnKeyEvent( Integration::KeyEvent& keyEvent )
+void EventHandler::OnKeyEvent(Integration::KeyEvent& keyEvent)
{
- for ( ObserverContainer::iterator iter = mObservers.begin(), endIter = mObservers.end(); iter != endIter; ++iter )
+ for(ObserverContainer::iterator iter = mObservers.begin(), endIter = mObservers.end(); iter != endIter; ++iter)
{
- (*iter)->OnKeyEvent( keyEvent );
+ (*iter)->OnKeyEvent(keyEvent);
}
}
-void EventHandler::OnFocusChanged( bool focusIn )
+void EventHandler::OnFocusChanged(bool focusIn)
{
// If the window gains focus and we hid the keyboard then show it again.
- if( focusIn )
+ if(TextClipboard::IsAvailable())
{
- Dali::Clipboard clipboard = Clipboard::Get();
- if ( clipboard )
+ if(focusIn)
{
- clipboard.HideClipboard();
+ Dali::TextClipboard clipboard = TextClipboard::Get();
+ if(clipboard)
+ {
+ clipboard.HideClipboard();
+ }
}
- }
- else
- {
- // Hiding clipboard event will be ignored once because window focus out event is always received on showing clipboard
- Dali::Clipboard clipboard = Clipboard::Get();
- if ( clipboard )
+ else
{
- Clipboard& clipBoardImpl( GetImplementation( clipboard ) );
- clipBoardImpl.HideClipboard(true);
+ // Hiding clipboard event will be ignored once because window focus out event is always received on showing clipboard
+ Dali::TextClipboard clipboard = TextClipboard::Get();
+ if(clipboard)
+ {
+ TextClipboard& clipBoardImpl(GetImplementation(clipboard));
+ clipBoardImpl.HideClipboard(true);
+ }
}
}
}
-void EventHandler::OnRotation( const RotationEvent& event )
+void EventHandler::OnRotation(const RotationEvent& event)
{
- for ( ObserverContainer::iterator iter = mObservers.begin(), endIter = mObservers.end(); iter != endIter; ++iter )
+ for(ObserverContainer::iterator iter = mObservers.begin(), endIter = mObservers.end(); iter != endIter; ++iter)
{
- (*iter)->OnRotation( event );
+ (*iter)->OnRotation(event);
}
}
-void EventHandler::OnWindowDamaged( const DamageArea& area )
+void EventHandler::OnWindowDamaged(const DamageArea& area)
{
- SendEvent( area );
+ SendEvent(area);
}
-void EventHandler::OnSelectionDataSend( void* event )
+void EventHandler::OnSelectionDataSend(void* event)
{
- Dali::Clipboard clipboard = Clipboard::Get();
- if( clipboard )
+ Dali::TextClipboard clipboard = TextClipboard::Get();
+ if(clipboard)
{
- Clipboard& clipBoardImpl( GetImplementation( clipboard ) );
- clipBoardImpl.ExcuteBuffered( true, event );
+ TextClipboard& clipBoardImpl(GetImplementation(clipboard));
+ clipBoardImpl.ExcuteSend(event);
}
}
-void EventHandler::OnSelectionDataReceived( void* event )
+void EventHandler::OnSelectionDataReceived(void* event)
{
// We have got the selected content, inform the clipboard event listener (if we have one).
- Dali::Clipboard clipboard = Clipboard::Get();
- char* selectionData = NULL;
- if( clipboard )
+ Dali::TextClipboard clipboard = TextClipboard::Get();
+ char* selectionData = NULL;
+ size_t dataLength = 0u;
+
+ if(clipboard)
+ {
+ int len = 0;
+ TextClipboard& clipBoardImpl(GetImplementation(clipboard));
+ clipBoardImpl.ExcuteReceive(event, selectionData, len);
+ dataLength = static_cast<size_t>(len);
+ }
+
+ if(!mClipboardEventNotifier)
{
- Clipboard& clipBoardImpl( GetImplementation( clipboard ) );
- selectionData = clipBoardImpl.ExcuteBuffered( false, event );
+ mClipboardEventNotifier = TextClipboardEventNotifier::Get();
}
- if( selectionData && mClipboardEventNotifier )
+ if(selectionData && mClipboardEventNotifier && dataLength > 0)
{
- ClipboardEventNotifier& clipboardEventNotifier( ClipboardEventNotifier::GetImplementation( mClipboardEventNotifier ) );
- std::string content( selectionData, strlen( selectionData ) );
+ TextClipboardEventNotifier& clipboardEventNotifier(TextClipboardEventNotifier::GetImplementation(mClipboardEventNotifier));
+ std::string content;
+ size_t stringLength = strlen(selectionData);
+
+ if(stringLength < dataLength)
+ {
+ content.append(selectionData, stringLength);
+ }
+ else
+ {
+ content.append(selectionData, dataLength);
+ }
- clipboardEventNotifier.SetContent( content );
+ clipboardEventNotifier.SetContent(content);
clipboardEventNotifier.EmitContentSelectedSignal();
- DALI_LOG_INFO( gSelectionEventLogFilter, Debug::General, "EcoreEventSelectionNotify: Content(%d): %s\n" , strlen(selectionData), selectionData );
+ DALI_LOG_INFO(gSelectionEventLogFilter, Debug::General, "EcoreEventSelectionNotify: Content(%s) strlen(%d) dataLength(%d)\n", selectionData, strlen(selectionData), dataLength);
}
}
-void EventHandler::OnStyleChanged( StyleChange::Type styleChange )
+void EventHandler::OnStyleChanged(StyleChange::Type styleChange)
{
- SendEvent( styleChange );
+ SendEvent(styleChange);
}
-void EventHandler::AddObserver( Observer& observer )
+void EventHandler::AddObserver(Observer& observer)
{
- ObserverContainer::iterator match ( find(mObservers.begin(), mObservers.end(), &observer) );
+ ObserverContainer::iterator match(find(mObservers.begin(), mObservers.end(), &observer));
- if ( match == mObservers.end() )
+ if(match == mObservers.end())
{
- mObservers.push_back( &observer );
+ mObservers.push_back(&observer);
}
}
-void EventHandler::RemoveObserver( Observer& observer )
+void EventHandler::RemoveObserver(Observer& observer)
{
- ObserverContainer::iterator match ( find(mObservers.begin(), mObservers.end(), &observer) );
+ ObserverContainer::iterator match(find(mObservers.begin(), mObservers.end(), &observer));
- if ( match != mObservers.end() )
+ if(match != mObservers.end())
{
- mObservers.erase( match );
+ mObservers.erase(match);
}
}