[Tizen] Fix window/screen rotation issue. accepted/tizen/unified/20210609.140343 submit/tizen/20210609.012218 submit/tizen/20210609.063802
authorTaehyub Kim <taehyub.kim@samsung.com>
Tue, 8 Jun 2021 03:41:27 +0000 (12:41 +0900)
committerTaehyub Kim <taehyub.kim@samsung.com>
Tue, 8 Jun 2021 03:41:27 +0000 (12:41 +0900)
This reverts commit b79ebe59048894505131a12f9b6337da1fe4f7a2.

dali/internal/render/common/render-algorithms.cpp
dali/internal/render/common/render-algorithms.h

index 972782650cc77ebd3aba60d246ca2c1e0e5a2463..599867086d94243cc3a00686def8e6e26a39d67d 100644 (file)
@@ -383,11 +383,13 @@ inline void SetupDepthBuffer(const RenderItem& item, Graphics::CommandBuffer& co
  * @param[in]     item                     The current RenderItem about to be rendered
  * @param[in,out] commandBuffer            The command buffer to write into
  * @param[in]     instruction              The render-instruction to process.
+ * @param[in]     orientation              The Scene's surface orientation.
  */
 inline void RenderAlgorithms::SetupScissorClipping(
   const RenderItem&        item,
   Graphics::CommandBuffer& commandBuffer,
-  const RenderInstruction& instruction)
+  const RenderInstruction& instruction,
+  int orientation)
 {
   // Get the number of child scissors in the stack (do not include layer or root box).
   size_t         childStackDepth = mScissorStack.size() - 1u;
@@ -456,8 +458,9 @@ inline void RenderAlgorithms::SetupScissorClipping(
       {
         useScissorBox.y = (instruction.mFrameBuffer->GetHeight() - useScissorBox.height) - useScissorBox.y;
       }
-      Graphics::Rect2D scissorBox = {useScissorBox.x, useScissorBox.y, uint32_t(useScissorBox.width), uint32_t(useScissorBox.height)};
-      commandBuffer.SetScissor(scissorBox);
+
+      Graphics::Viewport graphicsViewport = ViewportFromClippingBox(mViewportRectangle, 0);
+      commandBuffer.SetScissor(Rect2DFromClippingBox(useScissorBox, orientation, graphicsViewport));
     }
   }
 }
@@ -468,7 +471,8 @@ inline void RenderAlgorithms::SetupClipping(const RenderItem&
                                             uint32_t&                           lastClippingDepth,
                                             uint32_t&                           lastClippingId,
                                             Integration::StencilBufferAvailable stencilBufferAvailable,
-                                            const RenderInstruction&            instruction)
+                                            const RenderInstruction&            instruction,
+                                            int                                 orientation)
 {
   RenderMode::Type renderMode = RenderMode::AUTO;
   const Renderer*  renderer   = item.mRenderer;
@@ -490,7 +494,7 @@ inline void RenderAlgorithms::SetupClipping(const RenderItem&
       // As both scissor and stencil clips can be nested, we may be simultaneously traversing up the scissor tree, requiring a scissor to be un-done. Whilst simultaneously adding a new stencil clip.
       // We process both based on our current and old clipping depths for each mode.
       // Both methods with return rapidly if there is nothing to be done for that type of clipping.
-      SetupScissorClipping(item, commandBuffer, instruction);
+      SetupScissorClipping(item, commandBuffer, instruction, orientation);
 
       if(stencilBufferAvailable == Integration::StencilBufferAvailable::TRUE)
       {
@@ -637,7 +641,7 @@ inline void RenderAlgorithms::ProcessRenderList(const RenderList&
 
     // Set up clipping based on both the Renderer and Actor APIs.
     // The Renderer API will be used if specified. If AUTO, the Actors automatic clipping feature will be used.
-    SetupClipping(item, secondaryCommandBuffer, usedStencilBuffer, lastClippingDepth, lastClippingId, stencilBufferAvailable, instruction);
+    SetupClipping(item, secondaryCommandBuffer, usedStencilBuffer, lastClippingDepth, lastClippingId, stencilBufferAvailable, instruction, orientation);
 
     if(DALI_LIKELY(item.mRenderer))
     {
index 8cfcacc9f79df041a27115e267db8a0e0a73c072..84d5807a409811d606ab655c95f78842a4b5d350 100644 (file)
@@ -60,7 +60,7 @@ public:
    * @param[in] boundTextures          The textures bound for rendering
    * @param[in] viewport               The viewport for drawing
    * @param[in] rootClippingRect       The clipping rectangle
-   * @param[in] orientation            The surface orientation
+   * @param[in] orientation            The Scene's surface orientation.
    */
   void ProcessRenderInstruction(const SceneGraph::RenderInstruction& instruction,
                                 BufferIndex                          bufferIndex,
@@ -115,11 +115,13 @@ private:
    * @param[in] commandBuffer The command buffer to write into
 
    * @param[in] instruction   The render-instruction to process.
+   * @param[in] orientation   The Scene's surface orientation.
    */
   inline void SetupScissorClipping(
     const Dali::Internal::SceneGraph::RenderItem&        item,
     Graphics::CommandBuffer&                             commandBuffer,
-    const Dali::Internal::SceneGraph::RenderInstruction& instruction);
+    const Dali::Internal::SceneGraph::RenderInstruction& instruction,
+    int orientation);
 
   /**
    * @brief Set up the clipping based on the specified clipping settings.
@@ -130,6 +132,7 @@ private:
    * @param[in/out] lastClippingId           The clipping ID of the last renderer drawn.   Used by the clipping feature.
    * @param[in]     stencilBufferAvailable   Whether the stencil buffer is available
    * @param[in]     instruction              The render-instruction to process.
+   * @param[in]     orientation              The Scene's surface orientation.
    */
   inline void SetupClipping(const Dali::Internal::SceneGraph::RenderItem&        item,
                             Graphics::CommandBuffer&                             commandBuffer,
@@ -137,7 +140,8 @@ private:
                             uint32_t&                                            lastClippingDepth,
                             uint32_t&                                            lastClippingId,
                             Integration::StencilBufferAvailable                  stencilBufferAvailable,
-                            const Dali::Internal::SceneGraph::RenderInstruction& instruction);
+                            const Dali::Internal::SceneGraph::RenderInstruction& instruction,
+                            int                                                  orientation);
 
   /**
    * @brief Process a render-list.