2 * Copyright (c) 2024 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.
18 #include "test-application.h"
22 const Rect<int> TestApplication::DEFAULT_SURFACE_RECT = Rect<int>(0, 0, TestApplication::DEFAULT_SURFACE_WIDTH, TestApplication::DEFAULT_SURFACE_HEIGHT);
24 bool TestApplication::mLoggingEnabled = true;
26 TestApplication::TestApplication(uint32_t surfaceWidth,
27 uint32_t surfaceHeight,
28 uint32_t horizontalDpi,
31 bool enablePartialUpdate)
33 mSurfaceWidth(surfaceWidth),
34 mSurfaceHeight(surfaceHeight),
36 mDpi{horizontalDpi, verticalDpi},
38 mPartialUpdateEnabled(enablePartialUpdate)
46 void TestApplication::Initialize()
53 void TestApplication::CreateCore()
55 // We always need the first update!
56 mStatus.keepUpdating = Integration::KeepUpdating::STAGE_KEEP_RENDERING;
58 Integration::CorePolicyFlags corePolicyFlags = Integration::CorePolicyFlags::DEPTH_BUFFER_AVAILABLE | Integration::CorePolicyFlags::STENCIL_BUFFER_AVAILABLE;
59 if(mPartialUpdateEnabled)
61 corePolicyFlags |= Integration::CorePolicyFlags::PARTIAL_UPDATE_AVAILABLE;
64 mCore = Dali::Integration::Core::New(mRenderController,
69 mCore->ContextCreated();
71 Dali::Integration::Log::LogFunction logFunction(&TestApplication::LogMessage);
72 Dali::Integration::Log::InstallLogFunction(logFunction);
74 Dali::Integration::Trace::LogContextFunction logContextFunction(&TestApplication::LogContext);
75 Dali::Integration::Trace::InstallLogContextFunction(logContextFunction);
77 Dali::Integration::Trace::LogContext(true, "Test");
80 void TestApplication::CreateScene()
82 mScene = Dali::Integration::Scene::New(Size(static_cast<float>(mSurfaceWidth), static_cast<float>(mSurfaceHeight)));
83 mScene.SetDpi(Vector2(static_cast<float>(mDpi.x), static_cast<float>(mDpi.y)));
85 // Create render target for the scene
86 Graphics::RenderTargetCreateInfo rtInfo{};
87 rtInfo.SetExtent({mSurfaceWidth, mSurfaceHeight});
88 rtInfo.SetSurface(&mSurfaceWidth); // Can point to anything, really.
90 mScene.SetSurfaceRenderTarget(rtInfo);
92 mScenes.push_back(mScene);
95 void TestApplication::InitializeCore()
97 mCore->SceneCreated();
101 TestApplication::~TestApplication()
103 Dali::Integration::Log::UninstallLogFunction();
107 void TestApplication::LogContext(bool start, const char* tag, const char* message)
111 fprintf(stderr, "INFO: Trace Start: %s %s\n", tag, message ? message : "");
115 fprintf(stderr, "INFO: Trace End: %s %s\n", tag, message ? message : "");
119 void TestApplication::LogMessage(Dali::Integration::Log::DebugPriority level, std::string& message)
125 case Dali::Integration::Log::DEBUG:
126 fprintf(stderr, "DEBUG: %s", message.c_str());
128 case Dali::Integration::Log::INFO:
129 fprintf(stderr, "INFO: %s", message.c_str());
131 case Dali::Integration::Log::WARNING:
132 fprintf(stderr, "WARN: %s", message.c_str());
134 case Dali::Integration::Log::ERROR:
135 fprintf(stderr, "ERROR: %s", message.c_str());
138 fprintf(stderr, "DEFAULT: %s", message.c_str());
144 Dali::Integration::Core& TestApplication::GetCore()
149 TestPlatformAbstraction& TestApplication::GetPlatform()
151 return mPlatformAbstraction;
154 TestRenderController& TestApplication::GetRenderController()
156 return mRenderController;
159 TestGraphicsController& TestApplication::GetGraphicsController()
161 return mGraphicsController;
164 TestGlAbstraction& TestApplication::GetGlAbstraction()
166 return static_cast<TestGlAbstraction&>(mGraphicsController.GetGlAbstraction());
169 TestGraphicsSyncImplementation& TestApplication::GetGraphicsSyncImpl()
171 return static_cast<TestGraphicsSyncImplementation&>(mGraphicsController.GetGraphicsSyncImpl());
174 void TestApplication::ProcessEvent(const Integration::Event& event)
176 mCore->QueueEvent(event);
177 mCore->ProcessEvents();
180 void TestApplication::SendNotification()
182 mCore->ProcessEvents();
185 void TestApplication::DoUpdate(uint32_t intervalMilliseconds, const char* location, bool uploadOnly)
187 if(GetUpdateStatus() == 0 &&
188 mRenderStatus.NeedsUpdate() == false &&
189 !GetRenderController().WasCalled(TestRenderController::RequestUpdateFunc))
191 fprintf(stderr, "WARNING - Update not required :%s\n", location == NULL ? "NULL" : location);
194 uint32_t nextVSyncTime = mLastVSyncTime + intervalMilliseconds;
195 float elapsedSeconds = static_cast<float>(intervalMilliseconds) * 0.001f;
197 mCore->Update(elapsedSeconds, mLastVSyncTime, nextVSyncTime, mStatus, false, false, uploadOnly);
199 GetRenderController().Initialize();
201 mLastVSyncTime = nextVSyncTime;
204 bool TestApplication::Render(uint32_t intervalMilliseconds, const char* location, bool uploadOnly)
206 DoUpdate(intervalMilliseconds, location, uploadOnly);
209 mRenderStatus.SetNeedsUpdate(false);
210 mRenderStatus.SetNeedsPostRender(false);
212 mCore->PreRender(mRenderStatus, false /*do not force clear*/);
215 for(auto&& scene : mScenes)
217 mCore->RenderScene(mRenderStatus, scene, true /*render the off-screen buffers*/);
218 mCore->RenderScene(mRenderStatus, scene, false /*render the surface*/);
225 return mStatus.KeepUpdating() || mRenderStatus.NeedsUpdate();
228 bool TestApplication::PreRenderWithPartialUpdate(uint32_t intervalMilliseconds, const char* location, std::vector<Rect<int>>& damagedRects)
230 DoUpdate(intervalMilliseconds, location);
232 mCore->PreRender(mRenderStatus, false /*do not force clear*/);
233 mCore->PreRender(mScene, damagedRects);
235 return mStatus.KeepUpdating() || mRenderStatus.NeedsUpdate();
238 bool TestApplication::RenderWithPartialUpdate(std::vector<Rect<int>>& damagedRects, Rect<int>& clippingRect)
240 mCore->RenderScene(mRenderStatus, mScene, true /*render the off-screen buffers*/);
241 mCore->RenderScene(mRenderStatus, mScene, false /*render the surface*/, clippingRect);
246 return mStatus.KeepUpdating() || mRenderStatus.NeedsUpdate();
249 bool TestApplication::RenderWithPartialUpdate(uint32_t intervalMilliseconds, const char* location)
251 DoUpdate(intervalMilliseconds, location);
254 mRenderStatus.SetNeedsUpdate(false);
255 mRenderStatus.SetNeedsPostRender(false);
257 mCore->PreRender(mRenderStatus, false /*do not force clear*/);
259 for(auto&& scene : mScenes)
261 std::vector<Rect<int>> damagedRects;
262 Rect<int> clippingRect{};
264 mCore->PreRender(scene, damagedRects);
265 mCore->RenderScene(mRenderStatus, scene, true /*render the off-screen buffers*/);
266 for(auto&& iter : damagedRects)
268 clippingRect.Merge(iter);
270 mCore->RenderScene(mRenderStatus, scene, false /*render the surface*/, clippingRect);
276 return mStatus.KeepUpdating() || mRenderStatus.NeedsUpdate();
279 uint32_t TestApplication::GetUpdateStatus()
281 return mStatus.KeepUpdating();
284 bool TestApplication::UpdateOnly(uint32_t intervalMilliseconds)
286 DoUpdate(intervalMilliseconds);
287 return mStatus.KeepUpdating();
290 bool TestApplication::GetRenderNeedsUpdate()
292 return mRenderStatus.NeedsUpdate();
295 bool TestApplication::GetRenderNeedsPostRender()
297 return mRenderStatus.NeedsPostRender();
300 bool TestApplication::RenderOnly()
302 // Update Time values
303 mCore->PreRender(mRenderStatus, false /*do not force clear*/);
304 mCore->RenderScene(mRenderStatus, mScene, true /*render the off-screen buffers*/);
305 mCore->RenderScene(mRenderStatus, mScene, false /*render the surface*/);
310 return mRenderStatus.NeedsUpdate();
313 void TestApplication::ResetContext()
315 mCore->ContextDestroyed();
316 mGraphicsController.Initialize();
317 mCore->ContextCreated();
320 uint32_t TestApplication::Wait(uint32_t durationToWait)
324 for(uint32_t i = 0; i <= (durationToWait / RENDER_FRAME_INTERVAL); i++)
327 Render(RENDER_FRAME_INTERVAL);
328 time += RENDER_FRAME_INTERVAL;
333 void TestApplication::AddScene(Integration::Scene scene)
335 mScenes.push_back(scene);
338 void TestApplication::RemoveScene(Integration::Scene scene)
340 mScenes.erase(std::remove(mScenes.begin(), mScenes.end(), scene), mScenes.end());