2 * Copyright (c) 2023 Samsung Electronics Co., Ltd.
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
8 * http://www.apache.org/licenses/LICENSE-2.0
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
19 #include <dali-toolkit/internal/visuals/animated-vector-image/vector-animation-manager.h>
22 #include <dali/integration-api/adaptor-framework/adaptor.h>
23 #include <dali/integration-api/debug.h>
24 #include <dali/integration-api/trace.h>
27 #include <dali-toolkit/internal/visuals/animated-vector-image/vector-animation-thread.h>
37 #if defined(DEBUG_ENABLED)
38 Debug::Filter* gVectorAnimationLogFilter = Debug::Filter::New(Debug::NoLogging, false, "LOG_VECTOR_ANIMATION");
41 DALI_INIT_TRACE_FILTER(gTraceFilter, DALI_TRACE_IMAGE_PERFORMANCE_MARKER, false);
43 } // unnamed namespace
45 VectorAnimationManager::VectorAnimationManager()
47 mLifecycleObservers(),
48 mVectorAnimationThread(nullptr),
49 mProcessorRegistered(false)
53 VectorAnimationManager::~VectorAnimationManager()
55 mEventCallbacks.clear();
57 if(mProcessorRegistered && Adaptor::IsAvailable())
59 Adaptor::Get().UnregisterProcessor(*this, true);
62 for(auto observer : mLifecycleObservers)
64 observer->VectorAnimationManagerDestroyed();
68 void VectorAnimationManager::AddObserver(VectorAnimationManager::LifecycleObserver& observer)
70 DALI_ASSERT_DEBUG(mLifecycleObservers.end() == std::find(mLifecycleObservers.begin(), mLifecycleObservers.end(), &observer));
71 mLifecycleObservers.push_back(&observer);
74 void VectorAnimationManager::RemoveObserver(VectorAnimationManager::LifecycleObserver& observer)
76 auto iterator = std::find(mLifecycleObservers.begin(), mLifecycleObservers.end(), &observer);
77 if(iterator != mLifecycleObservers.end())
79 mLifecycleObservers.erase(iterator);
83 VectorAnimationThread& VectorAnimationManager::GetVectorAnimationThread()
85 if(!mVectorAnimationThread)
87 mVectorAnimationThread = std::unique_ptr<VectorAnimationThread>(new VectorAnimationThread());
88 mVectorAnimationThread->Start();
90 return *mVectorAnimationThread;
93 void VectorAnimationManager::RegisterEventCallback(CallbackBase* callback)
95 mEventCallbacks.emplace_back(std::unique_ptr<Dali::CallbackBase>(callback));
97 if(!mProcessorRegistered)
99 Adaptor::Get().RegisterProcessor(*this, true); // Use post processor to trigger after layoutting
100 mProcessorRegistered = true;
104 void VectorAnimationManager::UnregisterEventCallback(CallbackBase* callback)
106 auto iter = std::find_if(mEventCallbacks.begin(),
107 mEventCallbacks.end(),
108 [callback](const std::unique_ptr<CallbackBase>& element) {
109 return element.get() == callback;
111 if(iter != mEventCallbacks.end())
113 mEventCallbacks.erase(iter);
115 if(mEventCallbacks.empty())
117 if(Adaptor::IsAvailable())
119 Adaptor::Get().UnregisterProcessor(*this, true);
120 mProcessorRegistered = false;
126 void VectorAnimationManager::Process(bool postProcessor)
129 if(gTraceFilter && gTraceFilter->IsTraceEnabled())
131 if(mEventCallbacks.size() > 0u)
133 std::ostringstream oss;
134 oss << "[" << mEventCallbacks.size() << "]";
135 DALI_TRACE_BEGIN_WITH_MESSAGE(gTraceFilter, "DALI_VECTOR_ANIMATION_MANAGER_PROCESS", oss.str().c_str());
140 for(auto&& iter : mEventCallbacks)
142 CallbackBase::Execute(*iter);
146 if(gTraceFilter && gTraceFilter->IsTraceEnabled())
148 if(mEventCallbacks.size() > 0u)
150 std::ostringstream oss;
151 oss << "[" << mEventCallbacks.size() << "]";
152 DALI_TRACE_END_WITH_MESSAGE(gTraceFilter, "DALI_VECTOR_ANIMATION_MANAGER_PROCESS", oss.str().c_str());
156 mEventCallbacks.clear();
158 Adaptor::Get().UnregisterProcessor(*this, true);
159 mProcessorRegistered = false;
162 } // namespace Internal
164 } // namespace Toolkit