X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=dali%2Finternal%2Fupdate%2Frender-tasks%2Fscene-graph-render-task-list.cpp;h=255b1b04e52fb58dc2f6769a880aafa5b0869402;hb=6c595946e2d7dddcefa616dfaaed623d23d5242b;hp=8139c2b29967f455debe4a4ebdf275ed3c03a3d3;hpb=fcb0aebae0b60376fde63992685ca2b5d0770643;p=platform%2Fcore%2Fuifw%2Fdali-core.git diff --git a/dali/internal/update/render-tasks/scene-graph-render-task-list.cpp b/dali/internal/update/render-tasks/scene-graph-render-task-list.cpp index 8139c2b..255b1b0 100644 --- a/dali/internal/update/render-tasks/scene-graph-render-task-list.cpp +++ b/dali/internal/update/render-tasks/scene-graph-render-task-list.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2021 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. @@ -20,12 +20,16 @@ // INTERNAL INCLUDES #include +#include ///< For AddInitializeResetter namespace //Unnamed namespace { //Memory pool used to allocate new RenderTaskLists. Memory used by this pool will be released when shutting down DALi -Dali::Internal::MemoryPoolObjectAllocator gRenderTaskListMemoryPool; - +Dali::Internal::MemoryPoolObjectAllocator& GetRenderTaskListMemoryPool() +{ + static Dali::Internal::MemoryPoolObjectAllocator gRenderTaskListMemoryPool; + return gRenderTaskListMemoryPool; +} } // unnamed namespace namespace Dali @@ -36,12 +40,14 @@ namespace SceneGraph { RenderTaskList* RenderTaskList::New() { - return new(gRenderTaskListMemoryPool.AllocateRawThreadSafe()) RenderTaskList(); + return new(GetRenderTaskListMemoryPool().AllocateRawThreadSafe()) RenderTaskList(); } RenderTaskList::RenderTaskList() : mNotificationObject(nullptr), - mRenderMessageDispatcher(nullptr) + mResetterManager(nullptr), + mRenderMessageDispatcher(nullptr), + mOverlayRenderTask(nullptr) { } @@ -49,12 +55,13 @@ RenderTaskList::~RenderTaskList() = default; void RenderTaskList::operator delete(void* ptr) { - gRenderTaskListMemoryPool.FreeThreadSafe(static_cast(ptr)); + GetRenderTaskListMemoryPool().FreeThreadSafe(static_cast(ptr)); } -void RenderTaskList::SetRenderMessageDispatcher(RenderMessageDispatcher* renderMessageDispatcher) +void RenderTaskList::Initialize(ResetterManager& resetterManager, RenderMessageDispatcher& renderMessageDispatcher) { - mRenderMessageDispatcher = renderMessageDispatcher; + mResetterManager = &resetterManager; + mRenderMessageDispatcher = &renderMessageDispatcher; } void RenderTaskList::AddTask(OwnerPointer& newTask) @@ -62,9 +69,22 @@ void RenderTaskList::AddTask(OwnerPointer& newTask) DALI_ASSERT_DEBUG(newTask && "SceneGraph RenderTask is null"); DALI_ASSERT_DEBUG(mRenderMessageDispatcher != NULL && "RenderMessageDispatcher is null"); - newTask->Initialize(*mRenderMessageDispatcher); - // mRenderTasks container takes ownership - mRenderTasks.PushBack(newTask.Release()); + newTask->Initialize(*mResetterManager, *mRenderMessageDispatcher); + + if(mOverlayRenderTask && mRenderTasks[mRenderTasks.Size() - 1] == mOverlayRenderTask) + { + mRenderTasks.Insert(mRenderTasks.End() - 1, newTask.Release()); + } + else + { + mRenderTasks.PushBack(newTask.Release()); + } +} + +void RenderTaskList::AddOverlayTask(OwnerPointer& newTask) +{ + AddTask(newTask); + mOverlayRenderTask = mRenderTasks[mRenderTasks.Size() - 1]; } void RenderTaskList::RemoveTask(RenderTask* task) @@ -107,6 +127,11 @@ CompleteNotificationInterface* RenderTaskList::GetCompleteNotificationInterface( return mNotificationObject; } +uint32_t RenderTaskList::GetMemoryPoolCapacity() +{ + return GetRenderTaskListMemoryPool().GetCapacity(); +} + } // namespace SceneGraph } // namespace Internal