[Libreoffice-commits] core.git: Branch 'feature/chart-opengl' - 3 commits - chart2/source

Markus Mohrhard markus.mohrhard at collabora.co.uk
Sun Feb 16 02:54:58 CET 2014


 chart2/source/view/inc/DummyXShape.hxx         |    7 +++
 chart2/source/view/main/DummyXShape.cxx        |   49 ++++++++++++++++++++++---
 chart2/source/view/main/OpenGLRender.cxx       |    9 +++-
 chart2/source/view/main/OpenGLRender.hxx       |    2 +
 chart2/source/view/main/OpenglShapeFactory.cxx |    2 -
 5 files changed, 60 insertions(+), 9 deletions(-)

New commits:
commit 6d08e1f572b364d4174ba9d663708b7f9ec26139
Author: Markus Mohrhard <markus.mohrhard at collabora.co.uk>
Date:   Sun Feb 16 02:53:17 2014 +0100

    text position for legend improvements
    
    Change-Id: I06d8baf8cfe59999cd6b417fc6e70c1bd6eede27

diff --git a/chart2/source/view/inc/DummyXShape.hxx b/chart2/source/view/inc/DummyXShape.hxx
index 3a9dccb..45f6dc4 100644
--- a/chart2/source/view/inc/DummyXShape.hxx
+++ b/chart2/source/view/inc/DummyXShape.hxx
@@ -332,13 +332,18 @@ class DummyText : public DummyXShape
 {
 public:
     DummyText(const OUString& rText, const tNameSequence& rNames,
-            const tAnySequence& rValues, const uno::Any& rTrans );
+            const tAnySequence& rValues, const uno::Any& rTrans, com::sun::star::uno::Reference<
+            com::sun::star::drawing::XShapes > xTarget);
 
     virtual void render() SAL_OVERRIDE;
 
     virtual void SAL_CALL setPropertyValue( const OUString& aPropertyName, const ::com::sun::star::uno::Any& aValue ) throw(::com::sun::star::beans::UnknownPropertyException, ::com::sun::star::beans::PropertyVetoException, ::com::sun::star::lang::IllegalArgumentException, ::com::sun::star::lang::WrappedTargetException, ::com::sun::star::uno::RuntimeException);
 
+    virtual void SAL_CALL setPosition( const ::com::sun::star::awt::Point& aPosition ) throw(::com::sun::star::uno::RuntimeException);
+
 private:
+    void setTransformatAsProperty(const com::sun::star::drawing::HomogenMatrix3& rMatrix);
+
     OUString maText;
     uno::Any maTrans;
     BitmapEx maBitmap;
diff --git a/chart2/source/view/main/DummyXShape.cxx b/chart2/source/view/main/DummyXShape.cxx
index f71db06..88b6ad9 100644
--- a/chart2/source/view/main/DummyXShape.cxx
+++ b/chart2/source/view/main/DummyXShape.cxx
@@ -714,7 +714,7 @@ private:
 }
 
 DummyText::DummyText(const OUString& rText, const tNameSequence& rNames,
-        const tAnySequence& rValues, const uno::Any& rTrans ):
+        const tAnySequence& rValues, const uno::Any& rTrans, uno::Reference< drawing::XShapes > xTarget ):
     maText(rText),
     maTrans(rTrans)
 {
@@ -744,12 +744,25 @@ DummyText::DummyText(const OUString& rText, const tNameSequence& rNames,
         setPosition(awt::Point(aTrans.Line1.Column3, aTrans.Line2.Column3));
         aTrans.Line1.Column1 = 20 * bmpWidth;
         aTrans.Line2.Column2 = 20 * bmpHeight;
-        uno::Any aNewTrans;
-        aNewTrans <<= aTrans;
-        setPropertyValue("Transformation", aNewTrans);
+        setTransformatAsProperty(aTrans);
     }
     else
+    {
         setSize(awt::Size(20*bmpWidth, 20*bmpHeight));
+        uno::Reference< drawing::XShape > xTargetShape(xTarget, uno::UNO_QUERY);
+        drawing::HomogenMatrix3 aTrans;
+        aTrans.Line1.Column1 = 20 * bmpWidth;
+        aTrans.Line2.Column2 = 20 * bmpHeight;
+        aTrans.Line3.Column3 = 1;
+        if(xTargetShape.is())
+        {
+            const awt::Point rPoint = xTargetShape->getPosition();
+            setPosition(rPoint);
+            aTrans.Line1.Column3 = rPoint.X;
+            aTrans.Line2.Column3 = rPoint.Y;
+        }
+        setTransformatAsProperty(aTrans);
+    }
 }
 
 void DummyText::render()
@@ -788,6 +801,34 @@ void DummyText::setPropertyValue( const OUString& rName, const uno::Any& rValue)
     DummyXShape::setPropertyValue(rName, rValue);
 }
 
+void DummyText::setPosition(const awt::Point& rPosition )
+    throw(uno::RuntimeException)
+{
+    DummyXShape::setPosition(rPosition);
+    if(maTrans.hasValue())
+        return;
+
+    std::map<OUString, uno::Any>::const_iterator itr =
+        maProperties.find("Transformation");
+    if(itr != maProperties.end())
+    {
+        if(itr->second.hasValue())
+        {
+            drawing::HomogenMatrix3 aTrans = itr->second.get<drawing::HomogenMatrix3>();
+            aTrans.Line1.Column3 = rPosition.X;
+            aTrans.Line2.Column3 = rPosition.Y;
+            setTransformatAsProperty(aTrans);
+        }
+    }
+}
+
+void DummyText::setTransformatAsProperty(const drawing::HomogenMatrix3& rMatrix)
+{
+    uno::Any aNewTrans;
+    aNewTrans <<= rMatrix;
+    setPropertyValue("Transformation", aNewTrans);
+}
+
 DummyFormattedText::DummyFormattedText(uno::Sequence< uno::Reference<
         chart2::XFormattedString > >& rFormattedString):
     maFormattedString(rFormattedString)
diff --git a/chart2/source/view/main/OpenglShapeFactory.cxx b/chart2/source/view/main/OpenglShapeFactory.cxx
index c2ae65d..5b19a5b 100644
--- a/chart2/source/view/main/OpenglShapeFactory.cxx
+++ b/chart2/source/view/main/OpenglShapeFactory.cxx
@@ -401,7 +401,7 @@ uno::Reference< drawing::XShape >
                     , const uno::Any& rATransformation )
 {
     dummy::DummyText* pText = new dummy::DummyText( rText, rPropNames, rPropValues,
-            rATransformation );
+            rATransformation, xTarget );
     xTarget->add(pText);
     return pText;
 }
commit 4b26437de2ffe16454007629f313c1e19ebba24d
Author: Markus Mohrhard <markus.mohrhard at collabora.co.uk>
Date:   Sat Feb 15 22:28:09 2014 +0100

    improve bubble positioning
    
    Change-Id: Ifeecb23b0f2ee3218b052aaf688dcd51bcc30d58

diff --git a/chart2/source/view/main/OpenGLRender.cxx b/chart2/source/view/main/OpenGLRender.cxx
index b8c09c3..35a4b87 100755
--- a/chart2/source/view/main/OpenGLRender.cxx
+++ b/chart2/source/view/main/OpenGLRender.cxx
@@ -1031,10 +1031,10 @@ int OpenGLRender::Bubble2DShapePoint(float x, float y, float directionX, float d
     float actualX = (x / OPENGL_SCALE_VALUE);
     float actualY = (y / OPENGL_SCALE_VALUE);
     Bubble2DPointList aBubble2DPointList;
-    aBubble2DPointList.x = actualX;
-    aBubble2DPointList.y = actualY;
     aBubble2DPointList.xScale = directionX / OPENGL_SCALE_VALUE;
     aBubble2DPointList.yScale = directionY / OPENGL_SCALE_VALUE;
+    aBubble2DPointList.x = actualX + aBubble2DPointList.xScale / 2;
+    aBubble2DPointList.y = actualY + aBubble2DPointList.yScale / 2;
 
     m_Bubble2DShapePointList.push_back(aBubble2DPointList);
     return 0;
commit c1e63e576b27b61feed7c7faebca668b377019ea
Author: Markus Mohrhard <markus.mohrhard at collabora.co.uk>
Date:   Sat Feb 15 22:20:23 2014 +0100

    improve text positioning
    
    Change-Id: I9a6d99105ae32a2e03e4756983a87cb4ad174ea2

diff --git a/chart2/source/view/main/OpenGLRender.cxx b/chart2/source/view/main/OpenGLRender.cxx
index 6983622..b8c09c3 100755
--- a/chart2/source/view/main/OpenGLRender.cxx
+++ b/chart2/source/view/main/OpenGLRender.cxx
@@ -1294,6 +1294,9 @@ int OpenGLRender::CreateTextTexture(const BitmapEx& rBitmapEx, const awt::Point&
     aTextInfo.vertex[10] = (rTrans.Line2.Column3 + aSize.Height) / OPENGL_SCALE_VALUE;
     aTextInfo.vertex[11] = m_fZStep;
 
+    aTextInfo.bmpWidth = bmpWidth;
+    aTextInfo.bmpHeight = bmpHeight;
+
     //if has ratotion, we must re caculate the central pos
     if (!rtl::math::approxEqual(0, rotation))
     {
@@ -1328,7 +1331,7 @@ int OpenGLRender::RenderTextShape()
     for (size_t i = 0; i < listNum; i++)
     {
         TextInfo &textInfo = m_TextInfoList.front();
-        PosVecf3 trans = {0, 0, 0};
+        PosVecf3 trans = { (float)-textInfo.bmpWidth/2.0f, (float)-textInfo.bmpHeight/2.0f, 0};
         PosVecf3 angle = {0.0f, 0.0f, float(textInfo.rotation)};
         PosVecf3 scale = {1.0, 1.0, 1.0f};
         MoveModelf(trans, angle, scale);
diff --git a/chart2/source/view/main/OpenGLRender.hxx b/chart2/source/view/main/OpenGLRender.hxx
index 2a934cf..b91d5f3 100755
--- a/chart2/source/view/main/OpenGLRender.hxx
+++ b/chart2/source/view/main/OpenGLRender.hxx
@@ -81,6 +81,8 @@ struct TextInfo
     GLuint texture;
     double rotation;
     float vertex[12];
+    long bmpWidth;
+    long bmpHeight;
 };
 
 typedef std::vector<GLfloat> Area2DPointList;


More information about the Libreoffice-commits mailing list