[Tizen] Update RenderState in PreRender
authorEverLEEst(SangHyeon Lee) <sh10233.lee@samsung.com>
Wed, 8 Dec 2021 05:33:52 +0000 (14:33 +0900)
committerEverLEEst(SangHyeon Lee) <sh10233.lee@samsung.com>
Wed, 8 Dec 2021 05:33:52 +0000 (14:33 +0900)
This reverts commit 25c956766ad187b49a8539bee3bab95627f3593f.

automated-tests/src/dali/dali-test-suite-utils/test-application.cpp
dali/integration-api/core.cpp
dali/integration-api/core.h
dali/internal/common/core-impl.cpp
dali/internal/common/core-impl.h
dali/internal/render/common/render-manager.cpp
dali/internal/render/common/render-manager.h

index 440270aec9adb9013716cb23d379b7d1cd0edc80..e71166bd5b86e21c00f7a2937e5a9ed9d56e0656 100644 (file)
@@ -220,7 +220,7 @@ bool TestApplication::PreRenderWithPartialUpdate(uint32_t intervalMilliseconds,
   DoUpdate(intervalMilliseconds, location);
 
   mCore->PreRender(mRenderStatus, false /*do not force clear*/, false /*do not skip rendering*/);
-  mCore->PreRender(mScene, damagedRects);
+  mCore->PreRender(mRenderStatus, mScene, damagedRects);
 
   return mStatus.KeepUpdating() || mRenderStatus.NeedsUpdate();
 }
index 99001f3a2914fa0767dade33349d8c840a0d774c..36b6319c17bb629ea3f025cc6940cbffc71d7864 100644 (file)
@@ -110,9 +110,9 @@ void Core::PreRender(RenderStatus& status, bool forceClear, bool uploadOnly)
   mImpl->PreRender(status, forceClear, uploadOnly);
 }
 
-void Core::PreRender(Integration::Scene& scene, std::vector<Rect<int>>& damagedRects)
+void Core::PreRender(RenderStatus& status, Integration::Scene& scene, std::vector<Rect<int>>& damagedRects)
 {
-  mImpl->PreRender(scene, damagedRects);
+  mImpl->PreRender(status, scene, damagedRects);
 }
 
 void Core::RenderScene(RenderStatus& status, Integration::Scene& scene, bool renderToFbo)
index 1dd070df2f74beb69709d17dc4f393f0624729da..a5051e53a5b35481754e9a4bd000d62873535a39 100644 (file)
@@ -351,7 +351,7 @@ public:
    * @param[in] scene The scene to be rendered.
    * @param[out] damagedRects containing damaged render items rects for this pass.
    */
-  void PreRender(Integration::Scene& scene, std::vector<Rect<int>>& damagedRects);
+  void PreRender(RenderStatus& status, Integration::Scene& scene, std::vector<Rect<int>>& damagedRects);
 
   /**
    * Render a scene in the next frame. This method should be preceded by a call up PreRender.
index 3b50a24c67dcc1c3ee18016aabd84b517951e4b6..8402dd693296f81d0377ab6bd38393a2e0f8f7fa 100644 (file)
@@ -211,9 +211,9 @@ void Core::PreRender(RenderStatus& status, bool forceClear, bool uploadOnly)
   mRenderManager->PreRender(status, forceClear, uploadOnly);
 }
 
-void Core::PreRender(Integration::Scene& scene, std::vector<Rect<int>>& damagedRects)
+void Core::PreRender(RenderStatus& status, Integration::Scene& scene, std::vector<Rect<int>>& damagedRects)
 {
-  mRenderManager->PreRender(scene, damagedRects);
+  mRenderManager->PreRender(status, scene, damagedRects);
 }
 
 void Core::RenderScene(RenderStatus& status, Integration::Scene& scene, bool renderToFbo)
index 9744d0dfccdc19bfe29e84bd8c66cdaadf2c2ad6..7c6cb29678d52099c4bb8d1af2bfb3c25b133f41 100644 (file)
@@ -135,7 +135,7 @@ public:
   /**
    * @copydoc Dali::Integration::Core::PreRender()
    */
-  void PreRender(Integration::Scene& scene, std::vector<Rect<int>>& damagedRects);
+  void PreRender(Integration::RenderStatus& status, Integration::Scene& scene, std::vector<Rect<int>>& damagedRects);
 
   /**
    * @copydoc Dali::Integration::Core::RenderScene()
index 3c9f87c1fa22573280b44b5ba7a7a227b5e10469..d157b764d21903efc05b738d00ec6c5a9fb8d3a2 100644 (file)
@@ -466,7 +466,7 @@ void RenderManager::PreRender(Integration::RenderStatus& status, bool forceClear
   }
 }
 
-void RenderManager::PreRender(Integration::Scene& scene, std::vector<Rect<int>>& damagedRects)
+void RenderManager::PreRender(Integration::RenderStatus& status, Integration::Scene& scene, std::vector<Rect<int>>& damagedRects)
 {
   if(mImpl->partialUpdateAvailable != Integration::PartialUpdateAvailable::TRUE)
   {
@@ -479,9 +479,12 @@ void RenderManager::PreRender(Integration::Scene& scene, std::vector<Rect<int>>&
   if(sceneObject->IsRenderingSkipped())
   {
     // We don't need to calculate dirty rects
+    status.SetNeedsUpdate(false);
     return;
   }
 
+  status.SetNeedsUpdate(true);
+
   class DamagedRectsCleaner
   {
   public:
index 8b96203e4452cd1bc934521563856b5de384eb7d..54ed12d068ed06637877a479dba3206dce7daafd 100644 (file)
@@ -337,7 +337,7 @@ public:
    * @param[in] scene The scene to be rendered.
    * @param[out] damagedRects The list of damaged rects for the current render pass.
    */
-  void PreRender(Integration::Scene& scene, std::vector<Rect<int>>& damagedRects);
+  void PreRender(Integration::RenderStatus& status, Integration::Scene& scene, std::vector<Rect<int>>& damagedRects);
 
   // This method should be called from Core::RenderScene()