X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=dali-toolkit%2Finternal%2Fvisuals%2Fanimated-vector-image%2Fvector-rasterize-thread.h;h=0855f141ac6f3d5a8c4b0bf8e009b29a5927c70b;hb=5775f7664be913cddc27a7b5598b1c1535e981fd;hp=f8d409bd31ea434556646dd8d35aa22e144485ae;hpb=7c1ca2d9ab3bc63f3dc164c4f5d4ea0d8bf5ba3e;p=platform%2Fcore%2Fuifw%2Fdali-toolkit.git diff --git a/dali-toolkit/internal/visuals/animated-vector-image/vector-rasterize-thread.h b/dali-toolkit/internal/visuals/animated-vector-image/vector-rasterize-thread.h index f8d409b..0855f14 100644 --- a/dali-toolkit/internal/visuals/animated-vector-image/vector-rasterize-thread.h +++ b/dali-toolkit/internal/visuals/animated-vector-image/vector-rasterize-thread.h @@ -46,6 +46,8 @@ class VectorRasterizeThread : public Thread { public: + using UploadCompletedSignalType = Dali::VectorAnimationRenderer::UploadCompletedSignalType; + /** * @brief Constructor. * @@ -94,12 +96,6 @@ public: void RenderFrame(); /** - * @brief This callback is called after the first frame is ready. - * @param[in] callback The resource ready callback - */ - void SetResourceReadyCallback( EventThreadCallback* callback ); - - /** * @brief This callback is called after the animation is finished. * @param[in] callback The animation finished callback */ @@ -112,29 +108,18 @@ public: void SetLoopCount( int32_t count ); /** - * @brief Gets the loop count. -1 means to repeat forever. - * @return The number of times to loop - */ - int32_t GetLoopCount() const; - - /** - * @brief Set the playing range. - * @param[in] range Two values between [0,1] to specify minimum and maximum progress. + * @brief Set the playing range in frame number. + * @param[in] startFrame The frame number to specify minimum progress. + * @param[in] endFrame The frame number to specify maximum progress. * The animation will play between those values. */ - void SetPlayRange( Vector2 range ); - - /** - * @brief Gets the playing range. - * @return The play range defined for the animation - */ - Vector2 GetPlayRange() const; + void SetPlayRange( uint32_t startFrame, uint32_t endFrame ); /** * @brief Get the play state * @return The play state */ - DevelImageVisual::PlayState GetPlayState() const; + DevelImageVisual::PlayState::Type GetPlayState() const; /** * @brief Queries whether the resource is ready. @@ -142,6 +127,49 @@ public: */ bool IsResourceReady() const; + /** + * @brief Sets the current frame number of the animation. + * @param[in] frameNumber The new frame number between [0, the maximum frame number] or between the play range if specified. + */ + void SetCurrentFrameNumber( uint32_t frameNumber ); + + /** + * @brief Retrieves the current frame number of the animation. + * @return The current frame number + */ + uint32_t GetCurrentFrameNumber() const; + + /** + * @brief Retrieves the total frame number of the animation. + * @return The total frame number + */ + uint32_t GetTotalFrameNumber() const; + + /** + * @brief Gets the default size of the file,. + * @return The default size of the file + */ + void GetDefaultSize( uint32_t& width, uint32_t& height ) const; + + /** + * @brief Sets the stop behavior of the animation. This is performed when the animation is stopped. + * @param[in] stopBehavior The stop behavior + */ + void SetStopBehavior( DevelImageVisual::StopBehavior::Type stopBehavior ); + + /** + * @brief Sets the looping mode. + * Animation plays forwards and then restarts from the beginning or runs backwards again. + * @param[in] loopingMode The looping mode + */ + void SetLoopingMode( DevelImageVisual::LoopingMode::Type loopingMode ); + + /** + * @brief Connect to this signal to be notified when the texture upload is completed. + * @return The signal to connect to. + */ + UploadCompletedSignalType& UploadCompletedSignal(); + protected: /** @@ -153,20 +181,19 @@ protected: private: /** - * @brief Called by the rasterize thread which ensures a wait if required. - * @return false if the thread should stop. + * @brief Initializes the vector renderer. */ - bool IsThreadReady(); + void Initialize(); /** - * @brief Start rendering + * @brief Rasterizes the current frame. */ - bool StartRender(); + void Rasterize(); /** - * @brief Rasterize the current frame. + * @brief Gets the frame number when the animation is stopped according to the stop behavior. */ - void Rasterize(); + uint32_t GetStoppedFrame( uint32_t startFrame, uint32_t endFrame, uint32_t currentFrame ); // Undefined VectorRasterizeThread( const VectorRasterizeThread& thread ) = delete; @@ -176,15 +203,24 @@ private: private: + enum class PlayState + { + STOPPING, ///< The animation is stopping + STOPPED, ///< The animation has stopped + PLAYING, ///< The animation is playing + PAUSED ///< The animation is paused + }; + std::string mUrl; VectorAnimationRenderer mVectorRenderer; ConditionalWait mConditionalWait; - Dali::Mutex mMutex; - std::unique_ptr< EventThreadCallback > mResourceReadyTrigger; std::unique_ptr< EventThreadCallback > mAnimationFinishedTrigger; Vector2 mPlayRange; - DevelImageVisual::PlayState mPlayState; - float mProgress; + PlayState mPlayState; + DevelImageVisual::StopBehavior::Type mStopBehavior; + DevelImageVisual::LoopingMode::Type mLoopingMode; + int64_t mFrameDurationNanoSeconds; + float mFrameRate; uint32_t mCurrentFrame; uint32_t mTotalFrame; uint32_t mStartFrame; @@ -196,6 +232,9 @@ private: bool mNeedRender; bool mDestroyThread; ///< Whether the thread be destroyed bool mResourceReady; + bool mCurrentFrameUpdated; + bool mForward; + bool mUpdateFrameNumber; const Dali::LogFactoryInterface& mLogFactory; ///< The log factory };