svx/source/table/tablelayouter.cxx |   14 ++++++++++++--
 1 file changed, 12 insertions(+), 2 deletions(-)

New commits:
commit b8c9c63cdc44eba348b52dd3cb2e70d379d23187
Author: Gokul <gswaminat...@kacst.edu.sa>
Date:   Tue Jan 15 11:41:53 2013 +0300

    fdo#42387 Fixed Merging of cells in RTL Tables in impress
    
    The problem was in calculating the cell area, the width should be
    subtracted to Right end of cell instead it was adding width to Left
    end of the origin cell
    
    Change-Id: I3f31e0c4e0acae84ab5052823fc49932255137d3
    Reviewed-on: https://gerrit.libreoffice.org/1686
    Reviewed-by: Noel Power <noel.po...@suse.com>
    Tested-by: Noel Power <noel.po...@suse.com>
    Reviewed-on: https://gerrit.libreoffice.org/1911
    Tested-by: Lior Kaplan <kaplanl...@gmail.com>
    Reviewed-by: Miklos Vajna <vmik...@suse.cz>

diff --git a/svx/source/table/tablelayouter.cxx 
b/svx/source/table/tablelayouter.cxx
index 599bf61..15d85e9 100644
--- a/svx/source/table/tablelayouter.cxx
+++ b/svx/source/table/tablelayouter.cxx
@@ -126,13 +126,23 @@ bool TableLayouter::getCellArea( const CellPos& rPos, 
basegfx::B2IRectangle& rAr
         if( xCell.is() && !xCell->isMerged() && isValid(rPos) )
         {
             const basegfx::B2ITuple aCellSize( getCellSize( rPos ) );
+            const bool bRTL = meWritingMode == WritingMode_RL_TB;
 
             if( (rPos.mnCol < ((sal_Int32)maColumns.size()) && (rPos.mnRow < 
((sal_Int32)maRows.size()) ) ) )
             {
-                const sal_Int32 x = maColumns[rPos.mnCol].mnPos;
                 const sal_Int32 y = maRows[rPos.mnRow].mnPos;
 
-                rArea = basegfx::B2IRectangle( x, y, x + aCellSize.getX(), y + 
aCellSize.getY()  );
+                if(bRTL)
+                {
+                    ///For RTL Table Calculate the Right End of cell instead 
of Left
+                    const sal_Int32 x = maColumns[rPos.mnCol].mnPos + 
maColumns[rPos.mnCol].mnSize;
+                    rArea = basegfx::B2IRectangle( x-aCellSize.getX(), y, x, y 
+ aCellSize.getY()  );
+                }
+                else
+                {
+                    const sal_Int32 x = maColumns[rPos.mnCol].mnPos;
+                    rArea = basegfx::B2IRectangle( x, y, x + aCellSize.getX(), 
y + aCellSize.getY()  );
+                }
                 return true;
             }
         }
_______________________________________________
Libreoffice-commits mailing list
libreoffice-comm...@lists.freedesktop.org
http://lists.freedesktop.org/mailman/listinfo/libreoffice-commits

Reply via email to