Blame SOURCES/0001-implement-dialog-control-over-enhanced-shape-control.patch

a9add1
From e9680d99c4403bd07ab4d50939a5d7791bceb98c Mon Sep 17 00:00:00 2001
a9add1
From: =?UTF-8?q?Caol=C3=A1n=20McNamara?= <caolanm@redhat.com>
a9add1
Date: Tue, 13 Oct 2015 13:16:31 +0100
a9add1
Subject: [PATCH] implement dialog control over enhanced shape control points
a9add1
a9add1
use case is a desire to enable viewing and setting rounded rectangle radiuses
a9add1
to an exact known value
a9add1
a9add1
Change-Id: I7e6a4db0699076950adf5869a61825159766c46a
a9add1
(cherry picked from commit b859d84e471fdb70b61607d2d919a7907d074bd0)
a9add1
---
a9add1
 cui/source/inc/transfrm.hxx           |   6 +
a9add1
 cui/source/tabpages/transfrm.cxx      | 137 ++++++++++++++-
a9add1
 cui/uiconfig/ui/slantcornertabpage.ui | 310 ++++++++++++++++++++++++++++++----
a9add1
 include/svx/EnhancedCustomShape2d.hxx |   1 +
a9add1
 4 files changed, 416 insertions(+), 38 deletions(-)
a9add1
a9add1
diff --git a/cui/source/inc/transfrm.hxx b/cui/source/inc/transfrm.hxx
a9add1
index 2945d28..2fe2524 100644
a9add1
--- a/cui/source/inc/transfrm.hxx
a9add1
+++ b/cui/source/inc/transfrm.hxx
a9add1
@@ -239,6 +239,12 @@ private:
a9add1
     VclPtr<VclFrame>            m_pFlAngle;
a9add1
     VclPtr<MetricField>         m_pMtrAngle;
a9add1
 
a9add1
+    VclPtr<VclFrame>            m_aControlGroups[2];
a9add1
+    VclPtr<VclContainer>        m_aControlGroupX[2];
a9add1
+    VclPtr<MetricField>         m_aControlX[2];
a9add1
+    VclPtr<VclContainer>        m_aControlGroupY[2];
a9add1
+    VclPtr<MetricField>         m_aControlY[2];
a9add1
+
a9add1
     const SfxItemSet&   rOutAttrs;
a9add1
 
a9add1
     const SdrView*      pView;
a9add1
diff --git a/cui/source/tabpages/transfrm.cxx b/cui/source/tabpages/transfrm.cxx
a9add1
index 950a4b2..43375c2 100644
a9add1
--- a/cui/source/tabpages/transfrm.cxx
a9add1
+++ b/cui/source/tabpages/transfrm.cxx
a9add1
@@ -18,6 +18,8 @@
a9add1
  */
a9add1
 
a9add1
 #include <sfx2/app.hxx>
a9add1
+#include <svx/EnhancedCustomShape2d.hxx>
a9add1
+#include <svx/svdundo.hxx>
a9add1
 #include <svx/svdview.hxx>
a9add1
 #include <svx/svdobj.hxx>
a9add1
 #include <svx/svdpagv.hxx>
a9add1
@@ -430,6 +432,15 @@ SvxSlantTabPage::SvxSlantTabPage(vcl::Window* pParent, const SfxItemSet& rInAttr
a9add1
     get(m_pFlAngle, "FL_SLANT");
a9add1
     get(m_pMtrAngle, "MTR_FLD_ANGLE");
a9add1
 
a9add1
+    for (int i = 0; i < 2; ++i)
a9add1
+    {
a9add1
+        get(m_aControlGroups[i], "controlgroups" + OString::number(i+1));
a9add1
+        get(m_aControlGroupX[i], "controlgroupx" + OString::number(i+1));
a9add1
+        get(m_aControlX[i], "controlx" + OString::number(i+1));
a9add1
+        get(m_aControlGroupY[i], "controlgroupy" + OString::number(i+1));
a9add1
+        get(m_aControlY[i], "controly" + OString::number(i+1));
a9add1
+    }
a9add1
+
a9add1
     // this page needs ExchangeSupport
a9add1
     SetExchangeSupport();
a9add1
 
a9add1
@@ -450,6 +461,14 @@ void SvxSlantTabPage::dispose()
a9add1
     m_pMtrRadius.clear();
a9add1
     m_pFlAngle.clear();
a9add1
     m_pMtrAngle.clear();
a9add1
+    for (int i = 0; i < 2; ++i)
a9add1
+    {
a9add1
+        m_aControlGroups[i].clear();
a9add1
+        m_aControlGroupX[i].clear();
a9add1
+        m_aControlX[i].clear();
a9add1
+        m_aControlGroupY[i].clear();
a9add1
+        m_aControlY[i].clear();
a9add1
+    }
a9add1
     SvxTabPage::dispose();
a9add1
 }
a9add1
 
a9add1
@@ -506,10 +525,56 @@ bool SvxSlantTabPage::FillItemSet(SfxItemSet* rAttrs)
a9add1
         rAttrs->Put( SfxBoolItem( SID_ATTR_TRANSFORM_SHEAR_VERTICAL, false ) );
a9add1
     }
a9add1
 
a9add1
-    return bModified;
a9add1
-}
a9add1
+    bool bControlPointsChanged = false;
a9add1
+    for (int i = 0; i < 2; ++i)
a9add1
+    {
a9add1
+        bControlPointsChanged |= (m_aControlX[i]->IsValueChangedFromSaved() ||
a9add1
+                                  m_aControlY[i]->IsValueChangedFromSaved());
a9add1
+    }
a9add1
+
a9add1
+    if (!bControlPointsChanged)
a9add1
+        return bModified;
a9add1
+
a9add1
+    SdrObject* pObj = pView->GetMarkedObjectList().GetMark(0)->GetMarkedSdrObj();
a9add1
+    SdrModel* pModel = pObj->GetModel();
a9add1
+    SdrUndoAction* pUndo = pModel->IsUndoEnabled() ?
a9add1
+                pModel->GetSdrUndoFactory().CreateUndoAttrObject(*pObj) :
a9add1
+                nullptr;
a9add1
 
a9add1
+    if (pUndo)
a9add1
+        pModel->BegUndo(pUndo->GetComment());
a9add1
+
a9add1
+    EnhancedCustomShape2d aShape(pObj);
a9add1
+    Rectangle aLogicRect = aShape.GetLogicRect();
a9add1
+
a9add1
+    for (int i = 0; i < 2; ++i)
a9add1
+    {
a9add1
+        if (m_aControlX[i]->IsValueChangedFromSaved() || m_aControlY[i]->IsValueChangedFromSaved())
a9add1
+        {
a9add1
+            Point aNewPosition(GetCoreValue(*m_aControlX[i], ePoolUnit),
a9add1
+                               GetCoreValue(*m_aControlY[i], ePoolUnit));
a9add1
+            aNewPosition.Move(aLogicRect.Left(), aLogicRect.Top());
a9add1
+
a9add1
+            css::awt::Point aPosition;
a9add1
+            aPosition.X = aNewPosition.X();
a9add1
+            aPosition.Y = aNewPosition.Y();
a9add1
+
a9add1
+            aShape.SetHandleControllerPosition(i, aPosition);
a9add1
+        }
a9add1
+    }
a9add1
+
a9add1
+    pObj->SetChanged();
a9add1
+    pObj->BroadcastObjectChange();
a9add1
+    bModified = true;
a9add1
+
a9add1
+    if (pUndo)
a9add1
+    {
a9add1
+        pModel->AddUndo(pUndo);
a9add1
+        pModel->EndUndo();
a9add1
+    }
a9add1
 
a9add1
+    return bModified;
a9add1
+}
a9add1
 
a9add1
 void SvxSlantTabPage::Reset(const SfxItemSet* rAttrs)
a9add1
 {
a9add1
@@ -561,17 +626,76 @@ void SvxSlantTabPage::Reset(const SfxItemSet* rAttrs)
a9add1
     }
a9add1
 
a9add1
     m_pMtrAngle->SaveValue();
a9add1
-}
a9add1
-
a9add1
 
a9add1
+    const SdrMarkList& rMarkList = pView->GetMarkedObjectList();
a9add1
+    if (rMarkList.GetMarkCount() == 1)
a9add1
+    {
a9add1
+        SdrObject* pObj = rMarkList.GetMark(0)->GetMarkedSdrObj();
a9add1
+        SdrObjKind eKind = (SdrObjKind) pObj->GetObjIdentifier();
a9add1
+        if (eKind == OBJ_CUSTOMSHAPE)
a9add1
+        {
a9add1
+            EnhancedCustomShape2d aShape(pObj);
a9add1
+            Point aInitialPosition;
a9add1
+            for (int i = 0; i < 2; ++i)
a9add1
+            {
a9add1
+                if (!aShape.GetHandlePosition(i, aInitialPosition))
a9add1
+                    break;
a9add1
+                m_aControlGroups[i]->Enable();
a9add1
+                css::awt::Point aPosition;
a9add1
+
a9add1
+                aPosition.X = SAL_MAX_INT32;
a9add1
+                aPosition.Y = SAL_MAX_INT32;
a9add1
+                aShape.SetHandleControllerPosition(i, aPosition);
a9add1
+                Point aMaxPosition;
a9add1
+                aShape.GetHandlePosition(i, aMaxPosition);
a9add1
+
a9add1
+                aPosition.X = SAL_MIN_INT32;
a9add1
+                aPosition.Y = SAL_MIN_INT32;
a9add1
+                aShape.SetHandleControllerPosition(i, aPosition);
a9add1
+                Point aMinPosition;
a9add1
+                aShape.GetHandlePosition(i, aMinPosition);
a9add1
+
a9add1
+                Rectangle aLogicRect = aShape.GetLogicRect();
a9add1
+                aMaxPosition.Move(-aLogicRect.Left(), -aLogicRect.Top());
a9add1
+                aMinPosition.Move(-aLogicRect.Left(), -aLogicRect.Top());
a9add1
+
a9add1
+                aPosition.X = aInitialPosition.X();
a9add1
+                aPosition.Y = aInitialPosition.Y();
a9add1
+                aInitialPosition.Move(-aLogicRect.Left(), -aLogicRect.Top());
a9add1
+                aShape.SetHandleControllerPosition(i, aPosition);
a9add1
+
a9add1
+                SetMetricValue(*m_aControlX[i], aInitialPosition.X(), ePoolUnit);
a9add1
+                SetMetricValue(*m_aControlY[i], aInitialPosition.Y(), ePoolUnit);
a9add1
+
a9add1
+                if (aMaxPosition.X() == aMinPosition.X())
a9add1
+                    m_aControlGroupX[i]->Disable();
a9add1
+                else
a9add1
+                {
a9add1
+                    m_aControlX[i]->SetMin(aMinPosition.X(), FUNIT_MM);
a9add1
+                    m_aControlX[i]->SetMax(aMaxPosition.X(), FUNIT_MM);
a9add1
+                }
a9add1
+                if (aMaxPosition.Y() == aMinPosition.Y())
a9add1
+                    m_aControlGroupY[i]->Disable();
a9add1
+                else
a9add1
+                {
a9add1
+                    m_aControlY[i]->SetMin(aMinPosition.Y(), FUNIT_MM);
a9add1
+                    m_aControlY[i]->SetMax(aMaxPosition.Y(), FUNIT_MM);
a9add1
+                }
a9add1
+            }
a9add1
+        }
a9add1
+    }
a9add1
+    for (int i = 0; i < 2; ++i)
a9add1
+    {
a9add1
+        m_aControlX[i]->SaveValue();
a9add1
+        m_aControlY[i]->SaveValue();
a9add1
+    }
a9add1
+}
a9add1
 
a9add1
 VclPtr<SfxTabPage> SvxSlantTabPage::Create( vcl::Window* pWindow, const SfxItemSet* rOutAttrs )
a9add1
 {
a9add1
     return VclPtr<SvxSlantTabPage>::Create( pWindow, *rOutAttrs );
a9add1
 }
a9add1
 
a9add1
-
a9add1
-
a9add1
 void SvxSlantTabPage::ActivatePage( const SfxItemSet& rSet )
a9add1
 {
a9add1
     SfxRectangleItem const * pRectItem = NULL;
a9add1
@@ -620,7 +744,6 @@ SvxPositionSizeTabPage::SvxPositionSizeTabPage(vcl::Window* pParent, const SfxIt
a9add1
     , mfOldWidth(0.0)
a9add1
     , mfOldHeight(0.0)
a9add1
 {
a9add1
-
a9add1
     get(m_pFlPosition, "FL_POSITION");
a9add1
     get(m_pMtrPosX, "MTR_FLD_POS_X");
a9add1
     get(m_pMtrPosY, "MTR_FLD_POS_Y");
a9add1
diff --git a/cui/uiconfig/ui/slantcornertabpage.ui b/cui/uiconfig/ui/slantcornertabpage.ui
a9add1
index 37b7b0e..b3ce646 100644
a9add1
--- a/cui/uiconfig/ui/slantcornertabpage.ui
a9add1
+++ b/cui/uiconfig/ui/slantcornertabpage.ui
a9add1
@@ -13,12 +13,132 @@
a9add1
     <property name="step_increment">1</property>
a9add1
     <property name="page_increment">10</property>
a9add1
   </object>
a9add1
-  <object class="GtkBox" id="SlantAndCornerRadius">
a9add1
+  <object class="GtkGrid" id="SlantAndCornerRadius">
a9add1
     <property name="visible">True</property>
a9add1
     <property name="can_focus">False</property>
a9add1
     <property name="border_width">6</property>
a9add1
-    <property name="orientation">vertical</property>
a9add1
-    <property name="spacing">12</property>
a9add1
+    <property name="row_spacing">24</property>
a9add1
+    <property name="column_spacing">12</property>
a9add1
+    <child>
a9add1
+      <object class="GtkFrame" id="controlgroups1">
a9add1
+        <property name="visible">True</property>
a9add1
+        <property name="sensitive">False</property>
a9add1
+        <property name="can_focus">False</property>
a9add1
+        <property name="label_xalign">0</property>
a9add1
+        <property name="shadow_type">none</property>
a9add1
+        <child>
a9add1
+          <object class="GtkAlignment" id="alignment3">
a9add1
+            <property name="visible">True</property>
a9add1
+            <property name="can_focus">False</property>
a9add1
+            <property name="top_padding">6</property>
a9add1
+            <property name="left_padding">12</property>
a9add1
+            <child>
a9add1
+              <object class="GtkGrid" id="grid1">
a9add1
+                <property name="visible">True</property>
a9add1
+                <property name="can_focus">False</property>
a9add1
+                <property name="row_spacing">12</property>
a9add1
+                <property name="column_spacing">6</property>
a9add1
+                <child>
a9add1
+                  <object class="GtkBox" id="controlgroupx1">
a9add1
+                    <property name="visible">True</property>
a9add1
+                    <property name="can_focus">False</property>
a9add1
+                    <property name="spacing">12</property>
a9add1
+                    <child>
a9add1
+                      <object class="GtkLabel" id="label5">
a9add1
+                        <property name="visible">True</property>
a9add1
+                        <property name="can_focus">False</property>
a9add1
+                        <property name="label" translatable="yes">_X:</property>
a9add1
+                        <property name="use_underline">True</property>
a9add1
+                        <property name="mnemonic_widget">controlx1:0.00cm</property>
a9add1
+                        <property name="xalign">0</property>
a9add1
+                      </object>
a9add1
+                      <packing>
a9add1
+                        <property name="expand">False</property>
a9add1
+                        <property name="fill">True</property>
a9add1
+                        <property name="position">0</property>
a9add1
+                      </packing>
a9add1
+                    </child>
a9add1
+                    <child>
a9add1
+                      <object class="GtkSpinButton" id="controlx1:0.00cm">
a9add1
+                        <property name="visible">True</property>
a9add1
+                        <property name="can_focus">True</property>
a9add1
+                        <property name="invisible_char">•</property>
a9add1
+                        <property name="text" translatable="yes">0.00</property>
a9add1
+                        <property name="digits">2</property>
a9add1
+                      </object>
a9add1
+                      <packing>
a9add1
+                        <property name="expand">False</property>
a9add1
+                        <property name="fill">True</property>
a9add1
+                        <property name="position">1</property>
a9add1
+                      </packing>
a9add1
+                    </child>
a9add1
+                  </object>
a9add1
+                  <packing>
a9add1
+                    <property name="left_attach">0</property>
a9add1
+                    <property name="top_attach">0</property>
a9add1
+                  </packing>
a9add1
+                </child>
a9add1
+                <child>
a9add1
+                  <object class="GtkBox" id="controlgroupy1">
a9add1
+                    <property name="visible">True</property>
a9add1
+                    <property name="can_focus">False</property>
a9add1
+                    <property name="spacing">12</property>
a9add1
+                    <child>
a9add1
+                      <object class="GtkLabel" id="label6">
a9add1
+                        <property name="visible">True</property>
a9add1
+                        <property name="can_focus">False</property>
a9add1
+                        <property name="label" translatable="yes">_Y:</property>
a9add1
+                        <property name="use_underline">True</property>
a9add1
+                        <property name="mnemonic_widget">controly1:0.00cm</property>
a9add1
+                        <property name="xalign">0</property>
a9add1
+                      </object>
a9add1
+                      <packing>
a9add1
+                        <property name="expand">False</property>
a9add1
+                        <property name="fill">True</property>
a9add1
+                        <property name="position">0</property>
a9add1
+                      </packing>
a9add1
+                    </child>
a9add1
+                    <child>
a9add1
+                      <object class="GtkSpinButton" id="controly1:0.00cm">
a9add1
+                        <property name="visible">True</property>
a9add1
+                        <property name="can_focus">True</property>
a9add1
+                        <property name="invisible_char">•</property>
a9add1
+                        <property name="text" translatable="yes">0.00</property>
a9add1
+                        <property name="digits">2</property>
a9add1
+                      </object>
a9add1
+                      <packing>
a9add1
+                        <property name="expand">False</property>
a9add1
+                        <property name="fill">True</property>
a9add1
+                        <property name="position">1</property>
a9add1
+                      </packing>
a9add1
+                    </child>
a9add1
+                  </object>
a9add1
+                  <packing>
a9add1
+                    <property name="left_attach">0</property>
a9add1
+                    <property name="top_attach">1</property>
a9add1
+                  </packing>
a9add1
+                </child>
a9add1
+              </object>
a9add1
+            </child>
a9add1
+          </object>
a9add1
+        </child>
a9add1
+        <child type="label">
a9add1
+          <object class="GtkLabel" id="label3">
a9add1
+            <property name="visible">True</property>
a9add1
+            <property name="can_focus">False</property>
a9add1
+            <property name="label" translatable="yes">Control Point 1</property>
a9add1
+            <property name="xalign">0</property>
a9add1
+            <attributes>
a9add1
+              <attribute name="weight" value="bold"/>
a9add1
+            </attributes>
a9add1
+          </object>
a9add1
+        </child>
a9add1
+      </object>
a9add1
+      <packing>
a9add1
+        <property name="left_attach">0</property>
a9add1
+        <property name="top_attach">1</property>
a9add1
+      </packing>
a9add1
+    </child>
a9add1
     <child>
a9add1
       <object class="GtkFrame" id="FL_RADIUS">
a9add1
         <property name="visible">True</property>
a9add1
@@ -32,37 +152,36 @@
a9add1
             <property name="top_padding">6</property>
a9add1
             <property name="left_padding">12</property>
a9add1
             <child>
a9add1
-              <object class="GtkBox" id="box2">
a9add1
+              <object class="GtkGrid" id="grid2">
a9add1
                 <property name="visible">True</property>
a9add1
                 <property name="can_focus">False</property>
a9add1
-                <property name="spacing">12</property>
a9add1
+                <property name="column_spacing">12</property>
a9add1
                 <child>
a9add1
                   <object class="GtkLabel" id="FT_RADIUS">
a9add1
                     <property name="visible">True</property>
a9add1
                     <property name="can_focus">False</property>
a9add1
-                    <property name="xalign">0</property>
a9add1
                     <property name="label" translatable="yes">_Radius:</property>
a9add1
                     <property name="use_underline">True</property>
a9add1
                     <property name="mnemonic_widget">MTR_FLD_RADIUS:0.00cm</property>
a9add1
+                    <property name="xalign">0</property>
a9add1
                   </object>
a9add1
                   <packing>
a9add1
-                    <property name="expand">False</property>
a9add1
-                    <property name="fill">True</property>
a9add1
-                    <property name="position">0</property>
a9add1
+                    <property name="left_attach">0</property>
a9add1
+                    <property name="top_attach">0</property>
a9add1
                   </packing>
a9add1
                 </child>
a9add1
                 <child>
a9add1
                   <object class="GtkSpinButton" id="MTR_FLD_RADIUS:0.00cm">
a9add1
                     <property name="visible">True</property>
a9add1
-                    <property name="can_focus">False</property>
a9add1
+                    <property name="can_focus">True</property>
a9add1
                     <property name="invisible_char">•</property>
a9add1
+                    <property name="text" translatable="yes">0.00</property>
a9add1
                     <property name="adjustment">adjustmentRADIUS</property>
a9add1
                     <property name="digits">2</property>
a9add1
                   </object>
a9add1
                   <packing>
a9add1
-                    <property name="expand">False</property>
a9add1
-                    <property name="fill">True</property>
a9add1
-                    <property name="position">1</property>
a9add1
+                    <property name="left_attach">1</property>
a9add1
+                    <property name="top_attach">0</property>
a9add1
                   </packing>
a9add1
                 </child>
a9add1
               </object>
a9add1
@@ -73,8 +192,8 @@
a9add1
           <object class="GtkLabel" id="label1">
a9add1
             <property name="visible">True</property>
a9add1
             <property name="can_focus">False</property>
a9add1
-            <property name="xalign">0</property>
a9add1
             <property name="label" translatable="yes">Corner Radius</property>
a9add1
+            <property name="xalign">0</property>
a9add1
             <attributes>
a9add1
               <attribute name="weight" value="bold"/>
a9add1
             </attributes>
a9add1
@@ -82,9 +201,8 @@
a9add1
         </child>
a9add1
       </object>
a9add1
       <packing>
a9add1
-        <property name="expand">False</property>
a9add1
-        <property name="fill">True</property>
a9add1
-        <property name="position">0</property>
a9add1
+        <property name="left_attach">0</property>
a9add1
+        <property name="top_attach">0</property>
a9add1
       </packing>
a9add1
     </child>
a9add1
     <child>
a9add1
@@ -100,37 +218,36 @@
a9add1
             <property name="top_padding">6</property>
a9add1
             <property name="left_padding">12</property>
a9add1
             <child>
a9add1
-              <object class="GtkBox" id="box3">
a9add1
+              <object class="GtkGrid" id="grid3">
a9add1
                 <property name="visible">True</property>
a9add1
                 <property name="can_focus">False</property>
a9add1
-                <property name="spacing">12</property>
a9add1
+                <property name="column_spacing">12</property>
a9add1
                 <child>
a9add1
                   <object class="GtkLabel" id="FT_ANGLE">
a9add1
                     <property name="visible">True</property>
a9add1
                     <property name="can_focus">False</property>
a9add1
-                    <property name="xalign">0</property>
a9add1
                     <property name="label" translatable="yes">_Angle:</property>
a9add1
                     <property name="use_underline">True</property>
a9add1
                     <property name="mnemonic_widget">MTR_FLD_ANGLE:0.00degrees</property>
a9add1
+                    <property name="xalign">0</property>
a9add1
                   </object>
a9add1
                   <packing>
a9add1
-                    <property name="expand">False</property>
a9add1
-                    <property name="fill">True</property>
a9add1
-                    <property name="position">0</property>
a9add1
+                    <property name="left_attach">0</property>
a9add1
+                    <property name="top_attach">0</property>
a9add1
                   </packing>
a9add1
                 </child>
a9add1
                 <child>
a9add1
                   <object class="GtkSpinButton" id="MTR_FLD_ANGLE:0.00degrees">
a9add1
                     <property name="visible">True</property>
a9add1
-                    <property name="can_focus">False</property>
a9add1
+                    <property name="can_focus">True</property>
a9add1
                     <property name="invisible_char">•</property>
a9add1
+                    <property name="text" translatable="yes">0.00</property>
a9add1
                     <property name="adjustment">adjustmentSLANT</property>
a9add1
                     <property name="digits">2</property>
a9add1
                   </object>
a9add1
                   <packing>
a9add1
-                    <property name="expand">False</property>
a9add1
-                    <property name="fill">True</property>
a9add1
-                    <property name="position">1</property>
a9add1
+                    <property name="left_attach">1</property>
a9add1
+                    <property name="top_attach">0</property>
a9add1
                   </packing>
a9add1
                 </child>
a9add1
               </object>
a9add1
@@ -141,8 +258,128 @@
a9add1
           <object class="GtkLabel" id="label2">
a9add1
             <property name="visible">True</property>
a9add1
             <property name="can_focus">False</property>
a9add1
-            <property name="xalign">0</property>
a9add1
             <property name="label" translatable="yes">Slant</property>
a9add1
+            <property name="xalign">0</property>
a9add1
+            <attributes>
a9add1
+              <attribute name="weight" value="bold"/>
a9add1
+            </attributes>
a9add1
+          </object>
a9add1
+        </child>
a9add1
+      </object>
a9add1
+      <packing>
a9add1
+        <property name="left_attach">1</property>
a9add1
+        <property name="top_attach">0</property>
a9add1
+      </packing>
a9add1
+    </child>
a9add1
+    <child>
a9add1
+      <object class="GtkFrame" id="controlgroups2">
a9add1
+        <property name="visible">True</property>
a9add1
+        <property name="sensitive">False</property>
a9add1
+        <property name="can_focus">False</property>
a9add1
+        <property name="label_xalign">0</property>
a9add1
+        <property name="shadow_type">none</property>
a9add1
+        <child>
a9add1
+          <object class="GtkAlignment" id="alignment4">
a9add1
+            <property name="visible">True</property>
a9add1
+            <property name="can_focus">False</property>
a9add1
+            <property name="top_padding">6</property>
a9add1
+            <property name="left_padding">12</property>
a9add1
+            <child>
a9add1
+              <object class="GtkGrid" id="grid4">
a9add1
+                <property name="visible">True</property>
a9add1
+                <property name="can_focus">False</property>
a9add1
+                <property name="row_spacing">12</property>
a9add1
+                <property name="column_spacing">6</property>
a9add1
+                <child>
a9add1
+                  <object class="GtkBox" id="controlgroupx2">
a9add1
+                    <property name="visible">True</property>
a9add1
+                    <property name="can_focus">False</property>
a9add1
+                    <property name="spacing">12</property>
a9add1
+                    <child>
a9add1
+                      <object class="GtkLabel" id="label4">
a9add1
+                        <property name="visible">True</property>
a9add1
+                        <property name="can_focus">False</property>
a9add1
+                        <property name="label" translatable="yes">_X:</property>
a9add1
+                        <property name="use_underline">True</property>
a9add1
+                        <property name="mnemonic_widget">controlx2:0.00cm</property>
a9add1
+                        <property name="xalign">0</property>
a9add1
+                      </object>
a9add1
+                      <packing>
a9add1
+                        <property name="expand">False</property>
a9add1
+                        <property name="fill">True</property>
a9add1
+                        <property name="position">0</property>
a9add1
+                      </packing>
a9add1
+                    </child>
a9add1
+                    <child>
a9add1
+                      <object class="GtkSpinButton" id="controlx2:0.00cm">
a9add1
+                        <property name="visible">True</property>
a9add1
+                        <property name="can_focus">True</property>
a9add1
+                        <property name="invisible_char">•</property>
a9add1
+                        <property name="text" translatable="yes">0.00</property>
a9add1
+                        <property name="digits">2</property>
a9add1
+                      </object>
a9add1
+                      <packing>
a9add1
+                        <property name="expand">False</property>
a9add1
+                        <property name="fill">True</property>
a9add1
+                        <property name="position">1</property>
a9add1
+                      </packing>
a9add1
+                    </child>
a9add1
+                  </object>
a9add1
+                  <packing>
a9add1
+                    <property name="left_attach">0</property>
a9add1
+                    <property name="top_attach">0</property>
a9add1
+                  </packing>
a9add1
+                </child>
a9add1
+                <child>
a9add1
+                  <object class="GtkBox" id="controlgroupy2">
a9add1
+                    <property name="visible">True</property>
a9add1
+                    <property name="can_focus">False</property>
a9add1
+                    <property name="spacing">12</property>
a9add1
+                    <child>
a9add1
+                      <object class="GtkLabel" id="label7">
a9add1
+                        <property name="visible">True</property>
a9add1
+                        <property name="can_focus">False</property>
a9add1
+                        <property name="label" translatable="yes">_Y:</property>
a9add1
+                        <property name="use_underline">True</property>
a9add1
+                        <property name="mnemonic_widget">controly2:0.00cm</property>
a9add1
+                        <property name="xalign">0</property>
a9add1
+                      </object>
a9add1
+                      <packing>
a9add1
+                        <property name="expand">False</property>
a9add1
+                        <property name="fill">True</property>
a9add1
+                        <property name="position">0</property>
a9add1
+                      </packing>
a9add1
+                    </child>
a9add1
+                    <child>
a9add1
+                      <object class="GtkSpinButton" id="controly2:0.00cm">
a9add1
+                        <property name="visible">True</property>
a9add1
+                        <property name="can_focus">True</property>
a9add1
+                        <property name="invisible_char">•</property>
a9add1
+                        <property name="text" translatable="yes">0.00</property>
a9add1
+                        <property name="digits">2</property>
a9add1
+                      </object>
a9add1
+                      <packing>
a9add1
+                        <property name="expand">False</property>
a9add1
+                        <property name="fill">True</property>
a9add1
+                        <property name="position">1</property>
a9add1
+                      </packing>
a9add1
+                    </child>
a9add1
+                  </object>
a9add1
+                  <packing>
a9add1
+                    <property name="left_attach">0</property>
a9add1
+                    <property name="top_attach">1</property>
a9add1
+                  </packing>
a9add1
+                </child>
a9add1
+              </object>
a9add1
+            </child>
a9add1
+          </object>
a9add1
+        </child>
a9add1
+        <child type="label">
a9add1
+          <object class="GtkLabel" id="label8">
a9add1
+            <property name="visible">True</property>
a9add1
+            <property name="can_focus">False</property>
a9add1
+            <property name="label" translatable="yes">Control Point 2</property>
a9add1
+            <property name="xalign">0</property>
a9add1
             <attributes>
a9add1
               <attribute name="weight" value="bold"/>
a9add1
             </attributes>
a9add1
@@ -150,16 +387,19 @@
a9add1
         </child>
a9add1
       </object>
a9add1
       <packing>
a9add1
-        <property name="expand">False</property>
a9add1
-        <property name="fill">True</property>
a9add1
-        <property name="position">1</property>
a9add1
+        <property name="left_attach">1</property>
a9add1
+        <property name="top_attach">1</property>
a9add1
       </packing>
a9add1
     </child>
a9add1
   </object>
a9add1
   <object class="GtkSizeGroup" id="sizegroup1">
a9add1
     <widgets>
a9add1
+      <widget name="label5"/>
a9add1
+      <widget name="label6"/>
a9add1
       <widget name="FT_RADIUS"/>
a9add1
       <widget name="FT_ANGLE"/>
a9add1
+      <widget name="label4"/>
a9add1
+      <widget name="label7"/>
a9add1
     </widgets>
a9add1
   </object>
a9add1
   <object class="GtkSizeGroup" id="sizegroup2">
a9add1
@@ -168,4 +408,12 @@
a9add1
       <widget name="MTR_FLD_ANGLE:0.00degrees"/>
a9add1
     </widgets>
a9add1
   </object>
a9add1
+  <object class="GtkSizeGroup" id="sizegroup5">
a9add1
+    <widgets>
a9add1
+      <widget name="controlx1:0.00cm"/>
a9add1
+      <widget name="controly1:0.00cm"/>
a9add1
+      <widget name="controlx2:0.00cm"/>
a9add1
+      <widget name="controly2:0.00cm"/>
a9add1
+    </widgets>
a9add1
+  </object>
a9add1
 </interface>
a9add1
diff --git a/include/svx/EnhancedCustomShape2d.hxx b/include/svx/EnhancedCustomShape2d.hxx
a9add1
index b9ed6f2..b1cc1b7 100644
a9add1
--- a/include/svx/EnhancedCustomShape2d.hxx
a9add1
+++ b/include/svx/EnhancedCustomShape2d.hxx
a9add1
@@ -191,6 +191,7 @@ class SVX_DLLPUBLIC EnhancedCustomShape2d : public SfxItemSet
a9add1
         SdrObject*              CreateObject( bool bLineGeometryNeededOnly );
a9add1
         void                    ApplyGluePoints( SdrObject* pObj );
a9add1
         Rectangle               GetTextRect() const;
a9add1
+        Rectangle               GetLogicRect() const { return aLogicRect; }
a9add1
 
a9add1
         sal_uInt32              GetHdlCount() const;
a9add1
         bool                    GetHandlePosition( const sal_uInt32 nIndex, Point& rReturnPosition ) const;
a9add1
-- 
a9add1
2.4.3
a9add1