X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=dali%2Finternal%2Fcommon%2Fcore-impl.h;h=6e02bb4876f5620474161db4c3c140ae18e9127e;hb=b43741a90b40ca9dfbd33d6a9d390d3c09230e89;hp=091408fd956fab7dd12fad66e4b58ba33c8a11b8;hpb=67edc0b3c42e3e9e330c51636045fcdf36adbb24;p=platform%2Fcore%2Fuifw%2Fdali-core.git diff --git a/dali/internal/common/core-impl.h b/dali/internal/common/core-impl.h old mode 100644 new mode 100755 index 091408f..6e02bb4 --- a/dali/internal/common/core-impl.h +++ b/dali/internal/common/core-impl.h @@ -2,7 +2,7 @@ #define DALI_INTERNAL_CORE_H /* - * Copyright (c) 2016 Samsung Electronics Co., Ltd. + * Copyright (c) 2019 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. @@ -19,28 +19,32 @@ */ // INTERNAL INCLUDES +#include #include #include +#include #include +#include #include #include -#include -#include #include +#include +#include namespace Dali { namespace Integration { +class Processor; class RenderController; class PlatformAbstraction; -class GestureManager; class GlAbstraction; class GlSyncAbstraction; -class SystemOverlay; +class GlContextHelperAbstraction; class UpdateStatus; class RenderStatus; +class RenderSurface; struct Event; struct TouchData; } @@ -53,26 +57,23 @@ class AnimationPlaylist; class PropertyNotificationManager; class EventProcessor; class GestureEventProcessor; -class ResourceClient; -class ResourceManager; class ShaderFactory; class TouchResampler; class RelayoutController; +class EventThreadServices; namespace SceneGraph { class UpdateManager; class RenderManager; class DiscardQueue; -class TextureCacheDispatcher; -class GeometryBatcher; class RenderTaskProcessor; } /** * Internal class for Dali::Integration::Core */ -class Core +class Core : public EventThreadServices { public: @@ -83,8 +84,12 @@ public: Integration::PlatformAbstraction& platform, Integration::GlAbstraction& glAbstraction, Integration::GlSyncAbstraction& glSyncAbstraction, - Integration::GestureManager& gestureManager, - ResourcePolicy::DataRetention dataRetentionPolicy ); + Integration::GlContextHelperAbstraction& glContextHelperAbstraction, + ResourcePolicy::DataRetention dataRetentionPolicy, + Integration::RenderToFrameBuffer renderToFboEnabled, + Integration::DepthBufferAvailable depthBufferAvailable, + Integration::StencilBufferAvailable stencilBufferAvailable, + Integration::PartialUpdateAvailable partialUpdateAvailable ); /** * Destructor @@ -92,6 +97,11 @@ public: ~Core(); /** + * @copydoc Dali::Integration::Core::Initialize() + */ + void Initialize(); + + /** * @copydoc Dali::Integration::Core::GetContextNotifier() */ Integration::ContextNotifierInterface* GetContextNotifier(); @@ -112,93 +122,114 @@ public: void RecoverFromContextLoss(); /** - * @copydoc Dali::Integration::Core::SurfaceResized(unsigned int, unsigned int) + * @copydoc Dali::Integration::Core::SurfaceDeleted(Integration::RenderSurface*) */ - void SurfaceResized(unsigned int width, unsigned int height); + void SurfaceDeleted( Integration::RenderSurface* surface ); /** - * @copydoc Dali::Integration::Core::SetTopMargin( unsigned int margin ) + * @copydoc Dali::Integration::Core::SetMinimumFrameTimeInterval(uint32_t) */ - void SetTopMargin( unsigned int margin ); + void SetMinimumFrameTimeInterval(uint32_t interval); /** - * @copydoc Dali::Integration::Core::SetDpi(unsigned int, unsigned int) + * @copydoc Dali::Integration::Core::Update() */ - void SetDpi(unsigned int dpiHorizontal, unsigned int dpiVertical); + void Update( float elapsedSeconds, uint32_t lastVSyncTimeMilliseconds, uint32_t nextVSyncTimeMilliseconds, Integration::UpdateStatus& status, bool renderToFboEnabled, bool isRenderingToFbo ); /** - * @copydoc Dali::Integration::Core::SetMinimumFrameTimeInterval(unsigned int) + * @copydoc Dali::Integration::Core::Render() */ - void SetMinimumFrameTimeInterval(unsigned int interval); + void Render( Integration::RenderStatus& status, bool forceClear ); /** - * @copydoc Dali::Integration::Core::Update() + * @copydoc Dali::Integration::Core::SceneCreated() */ - void Update( float elapsedSeconds, unsigned int lastVSyncTimeMilliseconds, unsigned int nextVSyncTimeMilliseconds, Integration::UpdateStatus& status ); + void SceneCreated(); /** - * @copydoc Dali::Integration::Core::Render() + * @copydoc Dali::Integration::Core::QueueEvent(const Integration::Event&) */ - void Render( Integration::RenderStatus& status ); + void QueueEvent( const Integration::Event& event ); /** - * @copydoc Dali::Integration::Core::Suspend() + * @copydoc Dali::Integration::Core::ProcessEvents() */ - void Suspend(); + void ProcessEvents(); /** - * @copydoc Dali::Integration::Core::Resume() + * @copydoc Dali::Integration::Core::GetMaximumUpdateCount() */ - void Resume(); + uint32_t GetMaximumUpdateCount() const; /** - * @copydoc Dali::Integration::Core::SceneCreated() + * @copydoc Dali::Integration::Core::RegisterProcessor */ - void SceneCreated(); + void RegisterProcessor( Dali::Integration::Processor& processor ); /** - * @copydoc Dali::Integration::Core::QueueEvent(const Integration::Event&) + * @copydoc Dali::Integration::Core::UnregisterProcessor */ - void QueueEvent( const Integration::Event& event ); + void UnregisterProcessor( Dali::Integration::Processor& processor ); /** - * @copydoc Dali::Integration::Core::ProcessEvents() + * @copydoc Dali::Internal::ThreadLocalStorage::AddScene() */ - void ProcessEvents(); + void AddScene( Scene* scene ); /** - * @copydoc Dali::Integration::Core::GetMaximumUpdateCount() + * @copydoc Dali::Internal::ThreadLocalStorage::RemoveScene() */ - unsigned int GetMaximumUpdateCount() const; + void RemoveScene( Scene* scene ); + +public: // Implementation of EventThreadServices /** - * @copydoc Dali::Integration::Core::GetSystemOverlay() + * @copydoc EventThreadServices::RegisterObject */ - Integration::SystemOverlay& GetSystemOverlay(); + void RegisterObject( BaseObject* object) override; - // Stereoscopy + /** + * @copydoc EventThreadServices::UnregisterObject + */ + void UnregisterObject( BaseObject* object) override; /** - * @copydoc Dali::Integration::Core::SetViewMode() + * @copydoc EventThreadServices::GetUpdateManager */ - void SetViewMode( ViewMode viewMode ); + SceneGraph::UpdateManager& GetUpdateManager() override; /** - * @copydoc Dali::Integration::Core::GetViewMode() + * @copydoc EventThreadServices::GetRenderController */ - ViewMode GetViewMode() const; + Integration::RenderController& GetRenderController() override; /** - * @copydoc Dali::Integration::Core::SetStereoBase() + * @copydoc EventThreadServices::ReserveMessageSlot */ - void SetStereoBase( float stereoBase ); + uint32_t* ReserveMessageSlot( uint32_t size, bool updateScene ) override; /** - * @copydoc Dali::Integration::Core::GetStereoBase() + * @copydoc EventThreadServices::GetEventBufferIndex */ - float GetStereoBase() const; + BufferIndex GetEventBufferIndex() const override; -private: // for use by ThreadLocalStorage + /** + * @copydoc EventThreadServices::ForceNextUpdate + */ + void ForceNextUpdate() override; + + /** + * @copydoc EventThreadServices::IsNextUpdateForced + */ + bool IsNextUpdateForced() override; + +private: + /** + * Run each registered processor + */ + void RunProcessors(); + + // for use by ThreadLocalStorage /** * Returns the current stage. @@ -213,12 +244,6 @@ private: // for use by ThreadLocalStorage Integration::PlatformAbstraction& GetPlatform(); /** - * Returns the update manager. - * @return A reference to the update manager. - */ - SceneGraph::UpdateManager& GetUpdateManager(); - - /** * Returns the render manager. * @return A reference to the render manager. */ @@ -231,18 +256,6 @@ private: // for use by ThreadLocalStorage NotificationManager& GetNotificationManager(); /** - * Returns the Resource Manager. - * @return A reference to the Resource Manager. - */ - ResourceManager& GetResourceManager(); - - /** - * Returns the Resource client. - * @return A reference to the Resource Client. - */ - ResourceClient& GetResourceClient(); - - /** * Returns the Shader factory * @return A reference to the Shader binary factory. */ @@ -260,13 +273,37 @@ private: // for use by ThreadLocalStorage */ RelayoutController& GetRelayoutController(); + /** + * @brief Gets the Object registry. + * @return A reference to the object registry + */ + ObjectRegistry& GetObjectRegistry() const; + + /** + * @brief Gets the event thread services. + * @return A reference to the event thread services + */ + EventThreadServices& GetEventThreadServices(); + + /** + * @brief Gets the property notification manager. + * @return A reference to the property notification manager + */ + PropertyNotificationManager& GetPropertyNotificationManager() const; + + /** + * @brief Gets the animation play list. + * @return A reference to the animation play list + */ + AnimationPlaylist& GetAnimationPlaylist() const; + private: /** * Undefined copy and assignment operators */ - Core(const Core& core); // No definition - Core& operator=(const Core& core); // No definition + Core(const Core& core) = delete; // No definition + Core& operator=(const Core& core) = delete; // No definition /** * Create Thread local storage @@ -279,24 +316,27 @@ private: Integration::PlatformAbstraction& mPlatform; ///< The interface providing platform specific services. IntrusivePtr mStage; ///< The current stage - GestureEventProcessor* mGestureEventProcessor; ///< The gesture event processor - EventProcessor* mEventProcessor; ///< The event processor - SceneGraph::UpdateManager* mUpdateManager; ///< Update manager - SceneGraph::RenderManager* mRenderManager; ///< Render manager - SceneGraph::DiscardQueue* mDiscardQueue; ///< Used to cleanup nodes & resources when no longer in use. - SceneGraph::TextureCacheDispatcher* mTextureCacheDispatcher; ///< Used to send messages to TextureCache - LockedResourceQueue* mTextureUploadedQueue; ///< Stores resource ids which require post processing after render - NotificationManager* mNotificationManager; ///< Notification manager AnimationPlaylistOwner mAnimationPlaylist; ///< For 'Fire and forget' animation support OwnerPointer mPropertyNotificationManager; ///< For safe signal emmision of property changed notifications - ShaderFactory* mShaderFactory; ///< Shader resource factory - ResourceClient* mResourceClient; ///< Asynchronous Resource Loading - ResourceManager* mResourceManager; ///< Asynchronous Resource Loading IntrusivePtr< RelayoutController > mRelayoutController; ///< Size negotiation relayout controller - SceneGraph::GeometryBatcher* mGeometryBatcher; ///< Instance of the geometry batcher - SceneGraph::RenderTaskProcessor* mRenderTaskProcessor; ///< Handles the processing of render tasks - bool mIsActive : 1; ///< Whether Core is active or suspended + + OwnerPointer mRenderTaskProcessor; ///< Handles the processing of render tasks + OwnerPointer mRenderManager; ///< Render manager + OwnerPointer mUpdateManager; ///< Update manager + OwnerPointer mDiscardQueue; ///< Used to cleanup nodes & resources when no longer in use. + OwnerPointer mShaderFactory; ///< Shader resource factory + OwnerPointer mNotificationManager; ///< Notification manager + OwnerPointer mGestureEventProcessor; ///< The gesture event processor + Dali::Vector mProcessors; ///< Registered processors (not owned) + + using SceneContainer = std::vector; + SceneContainer mScenes; ///< A container of scenes that bound to a surface for rendering, owned by Core + + // The object registry + ObjectRegistryPtr mObjectRegistry; + bool mProcessingEvent : 1; ///< True during ProcessEvents() + bool mForceNextUpdate:1; ///< True if the next rendering is really required. friend class ThreadLocalStorage;