/*
- * Copyright (c) 2019 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.
*/
// CLASS HEADER
-#include "toolkit-window.h"
+#include "toolkit-window-impl.h"
// EXTERNAL INCLUDES
#include <dali/public-api/actors/actor.h>
#include <dali/public-api/actors/layer.h>
-#include <dali/public-api/common/stage.h>
#include <dali/public-api/object/base-object.h>
-#include <dali/integration-api/adaptors/scene-holder.h>
-#include <toolkit-scene-holder-impl.h>
-
#define DALI_WINDOW_H
-#include <dali/integration-api/adaptors/adaptor.h>
+#include <dali/integration-api/adaptor-framework/adaptor.h>
#include <toolkit-adaptor-impl.h>
-// INTERNAL INCLUDES
-#include "test-render-surface.h"
-
using AdaptorImpl = Dali::Internal::Adaptor::Adaptor;
namespace Dali
{
namespace Adaptor
{
-class Window : public SceneHolder
-{
-public:
-
- Window( const PositionSize& positionSize )
- : SceneHolder( positionSize )
- {
- }
- virtual ~Window() = default;
+Window::Window( const PositionSize& positionSize )
+: SceneHolder( positionSize ),
+ mFocusChangeSignal(),
+ mResizeSignal(),
+ mRotationAngle(90), // dummy angle for test coverage
+ mVisibilityChangedSignal()
+{
+}
- static Window* New(const PositionSize& positionSize, const std::string& name, const std::string& className, bool isTransparent)
- {
- return new Window( positionSize );
- }
-};
+Window* Window::New(const PositionSize& positionSize, const std::string& name, const std::string& className, bool isTransparent)
+{
+ return new Window( positionSize );
+}
} // Adaptor
} // Internal
return static_cast<Internal::Adaptor::Window&>(object);
}
-Window::Window()
+inline const Internal::Adaptor::Window& GetImplementation(const Dali::Window& window)
{
+ DALI_ASSERT_ALWAYS( window && "Window handle is empty" );
+ const BaseObject& object = window.GetBaseObject();
+ return static_cast<const Internal::Adaptor::Window&>(object);
}
-Window::~Window()
+Window::Window()
{
}
-Window::Window(const Window& handle)
-: BaseHandle( handle )
+Window::~Window()
{
}
-Window& Window::operator=(const Window& rhs)
-{
- BaseHandle::operator=(rhs);
- return *this;
-}
+Window::Window( const Window& copy ) = default;
+
+Window& Window::operator=( const Window& rhs ) = default;
+
+Window::Window( Window&& rhs ) = default;
+
+Window& Window::operator=( Window&& rhs ) = default;
Dali::Window Window::New( PositionSize windowPosition, const std::string& name, bool isTransparent )
{
Dali::Window result( window );
- Dali::Integration::SceneHolder sceneHolder( static_cast<Dali::Internal::Adaptor::SceneHolder*>( window ) );
- Dali::Internal::Adaptor::Adaptor::Get().WindowCreatedSignal().Emit( sceneHolder );
+ // This will also emit the window created signals
+ AdaptorImpl::GetImpl( AdaptorImpl::Get() ).AddWindow( window );
return result;
}
-Dali::Layer Window::GetRootLayer() const
-{
- return Dali::Stage::GetCurrent().GetRootLayer();
-}
-
Window::Window( Internal::Adaptor::Window* window )
: BaseHandle( window )
{
return GetImplementation( *this ).GetScene();
}
-Integration::RenderSurface& Window::GetRenderSurface()
+Dali::RenderSurfaceInterface& Window::GetRenderSurface()
{
return GetImplementation( *this ).GetRenderSurface();
}
+void Window::Add( Actor actor )
+{
+ GetImplementation( *this ).Add( actor );
+}
+
+void Window::Remove( Actor actor )
+{
+ GetImplementation( *this ).Remove( actor );
+}
+
+Dali::Layer Window::GetRootLayer() const
+{
+ return GetImplementation( *this ).GetRootLayer();
+}
+
+void Window::SetBackgroundColor( const Vector4& color )
+{
+ GetImplementation( *this ).SetBackgroundColor( color );
+}
+
+Vector4 Window::GetBackgroundColor() const
+{
+ return GetImplementation( *this ).GetBackgroundColor();
+}
+
+void Window::Raise()
+{
+ GetImplementation( *this ).mFocusChangeSignal.Emit(*this, true);
+}
+
+void Window::Hide()
+{
+ GetImplementation( *this ).mVisibilityChangedSignal.Emit( *this, false );
+}
+
+FocusChangeSignalType& Window::FocusChangeSignal()
+{
+ return GetImplementation( *this ).mFocusChangeSignal;
+}
+
+ResizeSignalType& Window::ResizeSignal()
+{
+ return GetImplementation( *this ).mResizeSignal;
+}
+
+Window::KeyEventSignalType& Window::KeyEventSignal()
+{
+ return GetImplementation( *this ).KeyEventSignal();
+}
+
+Window::TouchEventSignalType& Window::TouchedSignal()
+{
+ return GetImplementation( *this ).TouchedSignal();
+}
+
namespace DevelWindow
{
Window Get( Actor actor )
{
- return Window();
+ Internal::Adaptor::Window* windowImpl = nullptr;
+
+ if ( Dali::Adaptor::IsAvailable() )
+ {
+ windowImpl = static_cast<Internal::Adaptor::Window*>( AdaptorImpl::GetImpl( AdaptorImpl::Get() ).GetWindow( actor ) );
+ }
+
+ return Dali::Window( windowImpl );
}
-EventProcessingFinishedSignalType& EventProcessingFinishedSignal( Window window )
+Window DownCast( BaseHandle handle )
{
- return GetImplementation( window ).GetScene().EventProcessingFinishedSignal();
+ Internal::Adaptor::Window* windowImpl = nullptr;
+ if ( Dali::Adaptor::IsAvailable() )
+ {
+ windowImpl = dynamic_cast<Dali::Internal::Adaptor::Window*>( handle.GetObjectPtr());
+ }
+ return Dali::Window( windowImpl );
}
-KeyEventSignalType& KeyEventSignal( Window window )
+void SetPositionSize(Window window, PositionSize positionSize)
{
- return GetImplementation( window ).KeyEventSignal();
+ Uint16Pair newSize(positionSize.width, positionSize.height);
+ GetImplementation( window ).mResizeSignal.Emit(window,newSize);
}
-KeyEventGeneratedSignalType& KeyEventGeneratedSignal( Window window )
+int GetPhysicalOrientation(Window window)
{
- return GetImplementation( window ).KeyEventGeneratedSignal();
+ return GetImplementation( window ).mRotationAngle;
}
-TouchSignalType& TouchSignal( Window window )
+void AddFrameRenderedCallback( Window window, std::unique_ptr< CallbackBase > callback, int32_t frameId )
{
- return GetImplementation( window ).TouchSignal();
+ CallbackBase::Execute( *callback, frameId );
+}
+
+void AddFramePresentedCallback( Window window, std::unique_ptr< CallbackBase > callback, int32_t frameId )
+{
+ CallbackBase::Execute( *callback, frameId );
+}
+
+EventProcessingFinishedSignalType& EventProcessingFinishedSignal( Window window )
+{
+ return GetImplementation( window ).GetScene().EventProcessingFinishedSignal();
+}
+
+KeyEventGeneratedSignalType& KeyEventGeneratedSignal( Window window )
+{
+ return GetImplementation( window ).KeyEventGeneratedSignal();
}
WheelEventSignalType& WheelEventSignal( Window window )
{
return GetImplementation( window ).WheelEventSignal();
}
+
+VisibilityChangedSignalType& VisibilityChangedSignal( Window window )
+{
+ return GetImplementation( window ).mVisibilityChangedSignal;
+}
+
} // namespace DevelWindow
} // Dali