2 * Copyright (c) 2021 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-graphics-application.h"
19 #include <test-graphics-sync-impl.h>
23 bool TestGraphicsApplication::mLoggingEnabled = true;
25 TestGraphicsApplication::TestGraphicsApplication(uint32_t surfaceWidth,
26 uint32_t surfaceHeight,
27 uint32_t horizontalDpi,
30 bool enablePartialUpdate)
32 mSurfaceWidth(surfaceWidth),
33 mSurfaceHeight(surfaceHeight),
35 mDpi{horizontalDpi, verticalDpi},
37 mPartialUpdateEnabled(enablePartialUpdate)
45 void TestGraphicsApplication::Initialize()
52 void TestGraphicsApplication::CreateCore()
54 Dali::Integration::Log::LogFunction logFunction(&TestGraphicsApplication::LogMessage);
55 Dali::Integration::Log::InstallLogFunction(logFunction);
57 Dali::Integration::Trace::LogContextFunction logContextFunction(&TestGraphicsApplication::LogContext);
58 Dali::Integration::Trace::InstallLogContextFunction(logContextFunction);
60 // We always need the first update!
61 mStatus.keepUpdating = Integration::KeepUpdating::STAGE_KEEP_RENDERING;
63 mGraphics.Initialize();
64 mGraphicsController.InitializeGLES(mGlAbstraction);
65 mGraphicsController.Initialize(mGraphicsSyncImplementation, mGlContextHelperAbstraction, mGraphics);
67 mCore = Dali::Integration::Core::New(mRenderController,
70 Integration::RenderToFrameBuffer::FALSE,
71 Integration::DepthBufferAvailable::TRUE,
72 Integration::StencilBufferAvailable::TRUE,
73 mPartialUpdateEnabled ? Integration::PartialUpdateAvailable::TRUE : Integration::PartialUpdateAvailable::FALSE);
75 mCore->ContextCreated();
77 Dali::Integration::Trace::LogContext(true, "Test");
80 void TestGraphicsApplication::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 Graphics::RenderTargetCreateInfo createInfo{};
86 createInfo.SetSurface({nullptr})
87 .SetExtent({mSurfaceWidth, mSurfaceHeight})
88 .SetPreTransform(0 | Graphics::RenderTargetTransformFlagBits::TRANSFORM_IDENTITY_BIT);
89 mRenderTarget = mGraphicsController.CreateRenderTarget(createInfo, nullptr);
90 mScene.SetSurfaceRenderTarget(mRenderTarget.get());
93 void TestGraphicsApplication::InitializeCore()
95 mCore->SceneCreated();
99 TestGraphicsApplication::~TestGraphicsApplication()
101 Dali::Integration::Log::UninstallLogFunction();
105 void TestGraphicsApplication::LogContext(bool start, const char* tag)
109 fprintf(stderr, "INFO: Trace Start: %s\n", tag);
113 fprintf(stderr, "INFO: Trace End: %s\n", tag);
117 void TestGraphicsApplication::LogMessage(Dali::Integration::Log::DebugPriority level, std::string& message)
123 case Dali::Integration::Log::DebugInfo:
124 fprintf(stderr, "INFO: %s", message.c_str());
126 case Dali::Integration::Log::DebugWarning:
127 fprintf(stderr, "WARN: %s", message.c_str());
129 case Dali::Integration::Log::DebugError:
130 fprintf(stderr, "ERROR: %s", message.c_str());
133 fprintf(stderr, "DEFAULT: %s", message.c_str());
139 Dali::Integration::Core& TestGraphicsApplication::GetCore()
144 TestPlatformAbstraction& TestGraphicsApplication::GetPlatform()
146 return mPlatformAbstraction;
149 TestRenderController& TestGraphicsApplication::GetRenderController()
151 return mRenderController;
154 Graphics::Controller& TestGraphicsApplication::GetGraphicsController()
156 return mGraphicsController;
159 TestGlAbstraction& TestGraphicsApplication::GetGlAbstraction()
161 return static_cast<TestGlAbstraction&>(mGraphicsController.GetGlAbstraction());
164 TestGlContextHelperAbstraction& TestGraphicsApplication::GetGlContextHelperAbstraction()
166 return static_cast<TestGlContextHelperAbstraction&>(mGraphicsController.GetGlContextHelperAbstraction());
169 void TestGraphicsApplication::ProcessEvent(const Integration::Event& event)
171 mCore->QueueEvent(event);
172 mCore->ProcessEvents();
175 void TestGraphicsApplication::SendNotification()
177 mCore->ProcessEvents();
180 void TestGraphicsApplication::DoUpdate(uint32_t intervalMilliseconds, const char* location)
182 if(GetUpdateStatus() == 0 &&
183 mRenderStatus.NeedsUpdate() == false &&
184 !GetRenderController().WasCalled(TestRenderController::RequestUpdateFunc))
186 fprintf(stderr, "WARNING - Update not required :%s\n", location == NULL ? "NULL" : location);
189 uint32_t nextVSyncTime = mLastVSyncTime + intervalMilliseconds;
190 float elapsedSeconds = static_cast<float>(intervalMilliseconds) * 0.001f;
192 mCore->Update(elapsedSeconds, mLastVSyncTime, nextVSyncTime, mStatus, false, false);
194 GetRenderController().Initialize();
196 mLastVSyncTime = nextVSyncTime;
199 bool TestGraphicsApplication::Render(uint32_t intervalMilliseconds, const char* location)
201 DoUpdate(intervalMilliseconds, location);
204 mRenderStatus.SetNeedsUpdate(false);
205 mRenderStatus.SetNeedsPostRender(false);
207 mCore->PreRender(mRenderStatus, false /*do not force clear*/, false /*do not skip rendering*/);
208 mCore->RenderScene(mRenderStatus, mScene, true /*render the off-screen buffers*/);
209 mCore->RenderScene(mRenderStatus, mScene, false /*render the surface*/);
210 mCore->PostRender(false /*do not skip rendering*/);
214 return mStatus.KeepUpdating() || mRenderStatus.NeedsUpdate();
217 bool TestGraphicsApplication::PreRenderWithPartialUpdate(uint32_t intervalMilliseconds, const char* location, std::vector<Rect<int>>& damagedRects)
219 DoUpdate(intervalMilliseconds, location);
221 mCore->PreRender(mRenderStatus, false /*do not force clear*/, false /*do not skip rendering*/);
222 mCore->PreRender(mScene, damagedRects);
224 return mStatus.KeepUpdating() || mRenderStatus.NeedsUpdate();
227 bool TestGraphicsApplication::RenderWithPartialUpdate(std::vector<Rect<int>>& damagedRects, Rect<int>& clippingRect)
229 mCore->RenderScene(mRenderStatus, mScene, true /*render the off-screen buffers*/, clippingRect);
230 mCore->RenderScene(mRenderStatus, mScene, false /*render the surface*/, clippingRect);
231 mCore->PostRender(false /*do not skip rendering*/);
235 return mStatus.KeepUpdating() || mRenderStatus.NeedsUpdate();
238 uint32_t TestGraphicsApplication::GetUpdateStatus()
240 return mStatus.KeepUpdating();
243 bool TestGraphicsApplication::UpdateOnly(uint32_t intervalMilliseconds)
245 DoUpdate(intervalMilliseconds);
246 return mStatus.KeepUpdating();
249 bool TestGraphicsApplication::GetRenderNeedsUpdate()
251 return mRenderStatus.NeedsUpdate();
254 bool TestGraphicsApplication::GetRenderNeedsPostRender()
256 return mRenderStatus.NeedsPostRender();
259 bool TestGraphicsApplication::RenderOnly()
261 // Update Time values
262 mCore->PreRender(mRenderStatus, false /*do not force clear*/, false /*do not skip rendering*/);
263 mCore->RenderScene(mRenderStatus, mScene, true /*render the off-screen buffers*/);
264 mCore->RenderScene(mRenderStatus, mScene, false /*render the surface*/);
265 mCore->PostRender(false /*do not skip rendering*/);
269 return mRenderStatus.NeedsUpdate();
272 void TestGraphicsApplication::ResetContext()
274 mCore->ContextDestroyed();
275 mGraphicsController.InitializeGLES(mGlAbstraction);
276 mGraphicsController.Initialize(mGraphicsSyncImplementation, mGlContextHelperAbstraction, mGraphics);
277 mCore->ContextCreated();
280 uint32_t TestGraphicsApplication::Wait(uint32_t durationToWait)
284 for(uint32_t i = 0; i <= (durationToWait / RENDER_FRAME_INTERVAL); i++)
287 Render(RENDER_FRAME_INTERVAL);
288 time += RENDER_FRAME_INTERVAL;