-#ifndef __DALI_INTERNAL_WINDOW_H__
-#define __DALI_INTERNAL_WINDOW_H__
+#ifndef DALI_INTERNAL_WINDOWSYSTEM_COMMON_WINDOW_IMPL_H
+#define DALI_INTERNAL_WINDOWSYSTEM_COMMON_WINDOW_IMPL_H
/*
- * Copyright (c) 2018 Samsung Electronics Co., Ltd.
+ * Copyright (c) 2020 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.
// EXTERNAL INCLUDES
#include <dali/public-api/object/ref-object.h>
#include <dali/public-api/object/base-object.h>
+#include <dali/public-api/actors/layer.h>
+#include <dali/public-api/render-tasks/render-task-list.h>
+#include <dali/public-api/object/property-array.h>
// INTERNAL INCLUDES
-#include <dali/internal/adaptor/common/lifecycle-observer.h>
-#include <dali/internal/window-system/common/indicator-interface.h>
-#include <dali/internal/adaptor/common/adaptor-impl.h>
#include <dali/public-api/adaptor-framework/window.h>
-#include <dali/devel-api/adaptor-framework/drag-and-drop-detector.h>
+#include <dali/public-api/adaptor-framework/key-grab.h>
+#include <dali/devel-api/adaptor-framework/window-devel.h>
+#include <dali/integration-api/adaptor-framework/scene-holder-impl.h>
+#include <dali/internal/adaptor/common/adaptor-impl.h>
+#include <dali/internal/window-system/common/event-handler.h>
namespace Dali
{
class Adaptor;
-
-namespace Integration
-{
-class SystemOverlay;
-}
+class Actor;
+class RenderSurfaceInterface;
namespace Internal
{
namespace Adaptor
{
class Orientation;
-class WindowBase;
class WindowRenderSurface;
+class WindowBase;
class Window;
-typedef IntrusivePtr<Window> WindowPtr;
-typedef IntrusivePtr<Orientation> OrientationPtr;
+using WindowPtr = IntrusivePtr< Window >;
+using OrientationPtr = IntrusivePtr< Orientation >;
+using EventHandlerPtr = IntrusivePtr< EventHandler >;
/**
* Window provides a surface to render onto with orientation & indicator properties.
*/
-class Window : public Dali::BaseObject, public IndicatorInterface::Observer, public LifeCycleObserver
+class Window : public Dali::Internal::Adaptor::SceneHolder, public EventHandler::Observer, public ConnectionTracker
{
public:
- typedef Dali::Window::IndicatorSignalType IndicatorSignalType;
- typedef Dali::Window::FocusSignalType FocusSignalType;
typedef Dali::Window::ResizedSignalType ResizedSignalType;
+ typedef Dali::Window::FocusChangeSignalType FocusChangeSignalType;
+ typedef Dali::Window::ResizeSignalType ResizeSignalType;
+ typedef Dali::DevelWindow::VisibilityChangedSignalType VisibilityChangedSignalType;
+ typedef Dali::DevelWindow::TransitionEffectEventSignalType TransitionEffectEventSignalType;
+ typedef Dali::DevelWindow::KeyboardRepeatSettingsChangedSignalType KeyboardRepeatSettingsChangedSignalType;
typedef Signal< void () > SignalType;
/**
- * Create a new Window. This should only be called once by the Application class
+ * @brief Create a new Window. This should only be called once by the Application class
* @param[in] positionSize The position and size of the window
* @param[in] name The window title
* @param[in] className The window class name
static Window* New(const PositionSize& positionSize, const std::string& name, const std::string& className, bool isTransparent = false);
/**
- * Pass the adaptor back to the overlay. This allows the window to access Core's overlay.
- * @param[in] adaptor An initialized adaptor
- */
- void SetAdaptor(Dali::Adaptor& adaptor);
-
- /**
- * Get the window surface
- * @return The render surface
+ * @brief Create a new Window. This should only be called once by the Application class
+ * @param[in] surface The surface used to render on.
+ * @param[in] positionSize The position and size of the window
+ * @param[in] name The window title
+ * @param[in] className The window class name
+ * @param[in] isTransparent Whether window is transparent
+ * @return A newly allocated Window
*/
- WindowRenderSurface* GetSurface();
+ static Window* New(Any surface, const PositionSize& positionSize, const std::string& name, const std::string& className, bool isTransparent = false);
/**
- * @copydoc Dali::Window::ShowIndicator()
+ * @copydoc Dali::Window::SetClass()
*/
- void ShowIndicator( Dali::Window::IndicatorVisibleMode visibleMode );
+ void SetClass( std::string name, std::string className );
/**
- * @copydoc Dali::Window::SetIndicatorBgOpacity()
+ * @brief Gets the window class name.
+ * @return The class of the window
*/
- void SetIndicatorBgOpacity( Dali::Window::IndicatorBgOpacity opacity );
+ std::string GetClassName() const;
/**
- * Set the indicator visible mode
+ * @copydoc Dali::Window::Raise()
*/
- void SetIndicatorVisibleMode( Dali::Window::IndicatorVisibleMode mode );
+ void Raise();
/**
- * @copydoc Dali::Window::RotateIndicator()
+ * @copydoc Dali::Window::Lower()
*/
- void RotateIndicator( Dali::Window::WindowOrientation orientation );
+ void Lower();
/**
- * @copydoc Dali::Window::SetClass()
+ * @copydoc Dali::Window::Activate()
*/
- void SetClass( std::string name, std::string className );
+ void Activate();
/**
- * @copydoc Dali::Window::Raise()
+ * @copydoc Dali::Window::GetLayerCount()
*/
- void Raise();
+ uint32_t GetLayerCount() const;
/**
- * @copydoc Dali::Window::Lower()
+ * @copydoc Dali::Window::GetLayer()
*/
- void Lower();
+ Dali::Layer GetLayer( uint32_t depth ) const;
/**
- * @copydoc Dali::Window::Activate()
+ * @copydoc Dali::DevelWindow::GetRenderTaskList()
*/
- void Activate();
+ Dali::RenderTaskList GetRenderTaskList() const;
/**
* @copydoc Dali::Window::AddAvailableOrientation()
void RemoveAvailableOrientation(Dali::Window::WindowOrientation orientation);
/**
- * @copydoc Dali::Window::SetAvailableOrientations()
- */
- void SetAvailableOrientations(const std::vector<Dali::Window::WindowOrientation>& orientations);
-
- /**
- * @copydoc Dali::Window::GetAvailableOrientations()
- */
- const std::vector<Dali::Window::WindowOrientation>& GetAvailableOrientations();
-
- /**
* @copydoc Dali::Window::SetPreferredOrientation()
*/
void SetPreferredOrientation(Dali::Window::WindowOrientation orientation);
Dali::Window::WindowOrientation GetPreferredOrientation();
/**
- * @copydoc Dali::Window::GetDragAndDropDetector() const
- */
- Dali::DragAndDropDetector GetDragAndDropDetector() const;
-
- /**
- * @copydoc Dali::Window::GetNativeHandle() const
- */
- Dali::Any GetNativeHandle() const;
-
- /**
* @copydoc Dali::Window::SetAcceptFocus()
*/
void SetAcceptFocus( bool accept );
void Hide();
/**
- * @copydoc Dali::Window::IsVisible() const
- */
- bool IsVisible() const;
-
- /**
* @copydoc Dali::Window::GetSupportedAuxiliaryHintCount()
*/
unsigned int GetSupportedAuxiliaryHintCount() const;
Dali::Window::WindowPosition GetPosition() const;
/**
+ * @copydoc Dali::DevelWindow::SetPositionSize()
+ */
+ void SetPositionSize( PositionSize positionSize );
+
+ /**
+ * @copydoc Dali::Window::GetRootLayer()
+ */
+ Dali::Layer GetRootLayer() const;
+
+ /**
* @copydoc Dali::Window::SetTransparency()
*/
void SetTransparency( bool transparent );
/**
- * Called from Orientation after the Change signal has been sent
+ * @copydoc Dali::KeyGrab::GrabKey()
*/
- void RotationDone( int orientation, int width, int height );
+ bool GrabKey( Dali::KEY key, KeyGrab::KeyGrabMode grabMode );
/**
- * Called when the window becomes iconified or deiconified.
+ * @copydoc Dali::KeyGrab::UngrabKey()
*/
- void OnIconifyChanged( bool iconified );
+ bool UngrabKey( Dali::KEY key );
/**
- * Called when the window focus is changed.
+ * @copydoc Dali::KeyGrab::GrabKeyList()
*/
- void OnFocusChanged( bool focusIn );
+ bool GrabKeyList( const Dali::Vector< Dali::KEY >& key, const Dali::Vector< KeyGrab::KeyGrabMode >& grabMode, Dali::Vector< bool >& result );
/**
- * Called when the output is transformed.
+ * @copydoc Dali::KeyGrab::UngrabKeyList()
*/
- void OnOutputTransformed();
+ bool UngrabKeyList( const Dali::Vector< Dali::KEY >& key, Dali::Vector< bool >& result );
/**
- * Called when the window receives a delete request
+ * @copydoc Dali::DevelWindow::Get()
*/
- void OnDeleteRequest();
+ static Dali::Window Get( Dali::Actor actor );
+
+ /**
+ * @copydoc Dali::DevelWindow::SetParent()
+ */
+ void SetParent( Dali::Window& parent );
+
+ /**
+ * @copydoc Dali::DevelWindow::Unparent()
+ */
+ void Unparent();
+
+ /**
+ * @copydoc Dali::DevelWindow::GetParent()
+ */
+ Dali::Window GetParent();
+
+ /**
+ * @copydoc Dali::DevelWindow::GetCurrentOrientation()
+ */
+ Dali::Window::WindowOrientation GetCurrentOrientation() const;
+
+ /**
+ * @copydoc Dali::DevelWindow::SetAvailableOrientations()
+ */
+ void SetAvailableOrientations( const Dali::Vector<Dali::Window::WindowOrientation>& orientations );
+
+ /**
+ * @copydoc Dali::DevelWindow::SetDamagedAreas()
+ */
+ void SetDamagedAreas(std::vector<Dali::Rect<int>>& areas);
+
+public: // Dali::Internal::Adaptor::SceneHolder
+
+ /**
+ * @copydoc Dali::Internal::Adaptor::SceneHolder::GetNativeHandle
+ */
+ Dali::Any GetNativeHandle() const override;
+
+ /**
+ * @copydoc Dali::Internal::Adaptor::SceneHolder::IsVisible
+ */
+ bool IsVisible() const override;
+
+ /**
+ * @copydoc Dali::DevelWindow::GetNativeId()
+ */
+ int32_t GetNativeId() const;
private:
+
+ /**
+ * @brief Enumeration for orietation mode.
+ * The Orientation Mode is related to screen size.
+ * If screen width is longer than height, the Orientation Mode will have LANDSCAPE.
+ * Otherwise screen width is shorter than height or same, the Orientation Mode will have PORTRAIT.
+ */
+ enum class OrientationMode
+ {
+ PORTRAIT = 0,
+ LANDSCAPE
+ };
+
/**
* Private constructor.
* @sa Window::New()
/**
* Second stage initialization
*/
- void Initialize(const PositionSize& positionSize, const std::string& name, const std::string& className);
+ void Initialize(Any surface, const PositionSize& positionSize, const std::string& name, const std::string& className);
/**
- * Shows / hides the indicator bar.
- * Handles close/open if rotation changes whilst hidden
+ * Called when the window becomes iconified or deiconified.
*/
- void DoShowIndicator( Dali::Window::WindowOrientation lastOrientation );
+ void OnIconifyChanged( bool iconified );
/**
- * Close current indicator and open a connection onto the new indicator service.
- * Effect may not be synchronous if waiting for an indicator update on existing connection.
+ * Called when the window focus is changed.
*/
- void DoRotateIndicator( Dali::Window::WindowOrientation orientation );
+ void OnFocusChanged( bool focusIn );
/**
- * Change the indicator actor's rotation to match the current orientation
+ * Called when the output is transformed.
*/
- void SetIndicatorActorRotation();
+ void OnOutputTransformed();
/**
- * Set the indicator properties on the window
+ * Called when the window receives a delete request.
*/
- void SetIndicatorProperties( bool isShow, Dali::Window::WindowOrientation lastOrientation );
+ void OnDeleteRequest();
-private: // IndicatorInterface::Observer interface
+ /**
+ * Called when the window receives a Transition effect-start/end event.
+ */
+ void OnTransitionEffectEvent( DevelWindow::EffectState state, DevelWindow::EffectType type );
/**
- * @copydoc Dali::Internal::Adaptor::IndicatorInterface::Observer::IndicatorTypeChanged()
+ * @brief Called when window receives a keyboard repeat event.
*/
- virtual void IndicatorTypeChanged( IndicatorInterface::Type type );
+ void OnKeyboardRepeatSettingsChanged();
/**
- * @copydoc Dali::Internal::Adaptor::IndicatorInterface::Observer::IndicatorClosed()
+ * @brief Set available orientation to window base.
*/
- virtual void IndicatorClosed( IndicatorInterface* indicator);
+ void SetAvailableAnlges( const std::vector< int >& angles );
/**
- * @copydoc Dali::Internal::Adaptor::IndicatorInterface::Observer::IndicatorVisibilityChanged()
+ * @brief Convert from window orientation to angle using OrientationMode.
*/
- virtual void IndicatorVisibilityChanged( bool isVisible );
+ int ConvertToAngle( Dali::Window::WindowOrientation orientation );
-private: // Adaptor::Observer interface
+ /**
+ * @brief Convert from angle to window orientation using OrientationMode.
+ */
+ Dali::Window::WindowOrientation ConvertToOrientation( int angle ) const;
/**
- * @copydoc Dali::Internal::Adaptor::Adaptor::Observer::OnStart()
+ * @brief Check available window orientation for Available orientation.
*/
- virtual void OnStart();
+ bool IsOrientationAvailable( Dali::Window::WindowOrientation orientation ) const;
+
+private: // Dali::Internal::Adaptor::SceneHolder
/**
- * @copydoc Dali::Internal::Adaptor::Adaptor::Observer::OnPause()
+ * @copydoc Dali::Internal::Adaptor::SceneHolder::OnAdaptorSet
*/
- virtual void OnPause();
+ void OnAdaptorSet( Dali::Adaptor& adaptor ) override;
/**
- * @copydoc Dali::Internal::Adaptor::Adaptor::Observer::OnResume()
+ * @copydoc Dali::Internal::Adaptor::SceneHolder::OnSurfaceSet
*/
- virtual void OnResume();
+ void OnSurfaceSet( Dali::RenderSurfaceInterface* surface ) override;
/**
- * @copydoc Dali::Internal::Adaptor::Adaptor::Observer::OnStop()
+ * @copydoc Dali::Internal::Adaptor::SceneHolder::OnPause
*/
- virtual void OnStop();
+ void OnPause() override;
/**
- * @copydoc Dali::Internal::Adaptor::Adaptor::Observer::OnDestroy()
+ * @copydoc Dali::Internal::Adaptor::SceneHolder::OnResume
*/
- virtual void OnDestroy();
+ void OnResume() override;
-public: // Signals
+ /**
+ * @copydoc Dali::Internal::Adaptor::SceneHolder::RecalculateTouchPosition
+ */
+ void RecalculateTouchPosition( Integration::Point& point ) override;
+
+private: // Dali::Internal::Adaptor::EventHandler::Observer
/**
- * The user should connect to this signal to get a timing when indicator was shown / hidden.
+ * @copydoc Dali::Internal::Adaptor::EventHandler::Observer::OnTouchPoint
*/
- IndicatorSignalType& IndicatorVisibilityChangedSignal() { return mIndicatorVisibilityChangedSignal; }
+ void OnTouchPoint( Dali::Integration::Point& point, int timeStamp ) override;
/**
- * @copydoc Dali::Window::FocusChangedSignal()
+ * @copydoc Dali::Internal::Adaptor::EventHandler::Observer::OnWheelEvent
*/
- FocusSignalType& FocusChangedSignal() { return mFocusChangedSignal; }
+ void OnWheelEvent( Dali::Integration::WheelEvent& wheelEvent ) override;
/**
+ * @copydoc Dali::Internal::Adaptor::EventHandler::Observer::OnKeyEvent
+ */
+ void OnKeyEvent( Dali::Integration::KeyEvent& keyEvent ) override;
+
+ /**
+ * @copydoc Dali::Internal::Adaptor::EventHandler::Observer::OnRotation
+ */
+ void OnRotation( const RotationEvent& rotation ) override;
+
+public: // Signals
+
+ /**
+ * @copydoc Dali::Window::FocusChangeSignal()
+ */
+ FocusChangeSignalType& FocusChangeSignal() { return mFocusChangeSignal; }
+ /**
* @copydoc Dali::Window::ResizedSignal()
*/
ResizedSignalType& ResizedSignal() { return mResizedSignal; }
/**
+ * @copydoc Dali::Window::ResizedSignal()
+ */
+ ResizeSignalType& ResizeSignal() { return mResizeSignal; }
+
+ /**
* This signal is emitted when the window is requesting to be deleted
*/
SignalType& DeleteRequestSignal() { return mDeleteRequestSignal; }
+ /**
+ * @copydoc Dali::DevelWindow::VisibilityChangedSignal()
+ */
+ VisibilityChangedSignalType& VisibilityChangedSignal() { return mVisibilityChangedSignal; }
+
+ /**
+ * @copydoc Dali::Window::SignalEventProcessingFinished()
+ */
+ Dali::DevelWindow::EventProcessingFinishedSignalType& EventProcessingFinishedSignal() { return mScene.EventProcessingFinishedSignal(); }
+
+ /**
+ * @copydoc Dali::DevelWindow::TransitionEffectEventSignal()
+ */
+ TransitionEffectEventSignalType& TransitionEffectEventSignal() { return mTransitionEffectEventSignal; }
+
+ /**
+ * @copydoc Dali::DevelWindow::KeyboardRepeatSettingsChangedSignal()
+ */
+ KeyboardRepeatSettingsChangedSignalType& KeyboardRepeatSettingsChangedSignal() { return mKeyboardRepeatSettingsChangedSignal; }
+
private:
- WindowRenderSurface* mSurface;
- std::unique_ptr< WindowBase > mWindowBase;
- Dali::Window::IndicatorVisibleMode mIndicatorVisible; ///< public state
- bool mIndicatorIsShown:1; ///< private state
- bool mShowRotatedIndicatorOnClose:1;
- bool mStarted:1;
- bool mIsTransparent:1;
- bool mIsFocusAcceptable:1;
- bool mVisible:1;
- bool mIconified:1;
- bool mOpaqueState:1;
- bool mResizeEnabled:1;
- IndicatorInterface* mIndicator;
- Dali::Window::WindowOrientation mIndicatorOrientation;
- Dali::Window::WindowOrientation mNextIndicatorOrientation;
- Dali::Window::IndicatorBgOpacity mIndicatorOpacityMode;
- Integration::SystemOverlay* mOverlay;
- Adaptor* mAdaptor;
- Dali::DragAndDropDetector mDragAndDropDetector;
- Dali::Window::Type mType;
-
- OrientationPtr mOrientation;
- std::vector<Dali::Window::WindowOrientation> mAvailableOrientations;
- Dali::Window::WindowOrientation mPreferredOrientation;
+ WindowRenderSurface* mWindowSurface; ///< The window rendering surface
+ WindowBase* mWindowBase;
+ std::string mName;
+ std::string mClassName;
+ bool mIsTransparent:1;
+ bool mIsFocusAcceptable:1;
+ bool mIconified:1;
+ bool mOpaqueState:1;
+ bool mResizeEnabled:1;
+ Dali::Window::Type mType;
+ Dali::Window mParentWindow;
+
+ OrientationPtr mOrientation;
+ std::vector< int > mAvailableAngles;
+ int mPreferredAngle;
+
+ int mRotationAngle; ///< The angle of the rotation
+ int mWindowWidth; ///< The width of the window
+ int mWindowHeight; ///< The height of the window
+
+ EventHandlerPtr mEventHandler; ///< The window events handler
+
+ OrientationMode mOrientationMode;
+
+ int mNativeWindowId; ///< The Native Window Id
// Signals
- IndicatorSignalType mIndicatorVisibilityChangedSignal;
- FocusSignalType mFocusChangedSignal;
- ResizedSignalType mResizedSignal;
- SignalType mDeleteRequestSignal;
+ ResizedSignalType mResizedSignal;
+ SignalType mDeleteRequestSignal;
+ FocusChangeSignalType mFocusChangeSignal;
+ ResizeSignalType mResizeSignal;
+ VisibilityChangedSignalType mVisibilityChangedSignal;
+ TransitionEffectEventSignalType mTransitionEffectEventSignal;
+ KeyboardRepeatSettingsChangedSignalType mKeyboardRepeatSettingsChangedSignal;
};
} // namespace Adaptor
} // namespace Dali
-#endif // __DALI_INTERNAL_WINDOW_H__
+#endif // DALI_INTERNAL_WINDOWSYSTEM_COMMON_WINDOW_IMPL_H