diff options
author | Caolán McNamara <caolanm@redhat.com> | 2012-08-15 11:19:06 +0100 |
---|---|---|
committer | Caolán McNamara <caolanm@redhat.com> | 2012-09-28 08:48:35 +0100 |
commit | 0296b3a6948bec92687ab7960bd7ae4c8454e702 (patch) | |
tree | 6c8cddad1c6ee580ddb57d7076ed66ce9d663da6 /vcl | |
parent | 7d8169706b754d7617cf4a1065dc40e698fa0702 (diff) |
ditch over complex property buckets
A fairly small fixed number of properties are needed, so simplify
Change-Id: Iedce02264816666dbac53d7ad3cfb64be8e1c8bb
Diffstat (limited to 'vcl')
-rw-r--r-- | vcl/inc/brdwin.hxx | 4 | ||||
-rw-r--r-- | vcl/inc/vcl/builder.hxx | 7 | ||||
-rw-r--r-- | vcl/inc/vcl/layout.hxx | 6 | ||||
-rw-r--r-- | vcl/inc/vcl/vclenum.hxx | 6 | ||||
-rw-r--r-- | vcl/inc/vcl/window.hxx | 123 | ||||
-rw-r--r-- | vcl/inc/window.h | 10 | ||||
-rw-r--r-- | vcl/source/window/brdwin.cxx | 16 | ||||
-rw-r--r-- | vcl/source/window/builder.cxx | 74 | ||||
-rw-r--r-- | vcl/source/window/layout.cxx | 48 | ||||
-rw-r--r-- | vcl/source/window/window.cxx | 34 | ||||
-rw-r--r-- | vcl/source/window/window2.cxx | 204 |
11 files changed, 355 insertions, 177 deletions
diff --git a/vcl/inc/brdwin.hxx b/vcl/inc/brdwin.hxx index d2dea40befc8..af26438e21b6 100644 --- a/vcl/inc/brdwin.hxx +++ b/vcl/inc/brdwin.hxx @@ -188,10 +188,6 @@ public: Rectangle GetMenuRect() const; virtual Size GetOptimalSize(WindowSizeType eType) const; - virtual void setChildAnyProperty(const rtl::OString &rString, - const ::com::sun::star::uno::Any &rValue); - virtual ::com::sun::star::uno::Any getWidgetAnyProperty(const rtl::OString &rString) const; - }; // ======================================================================= diff --git a/vcl/inc/vcl/builder.hxx b/vcl/inc/vcl/builder.hxx index c9d0ee063279..f5a100604eb3 100644 --- a/vcl/inc/vcl/builder.hxx +++ b/vcl/inc/vcl/builder.hxx @@ -48,10 +48,12 @@ private: { rtl::OString m_sID; Window *m_pWindow; + sal_Int32 m_nPosition; bool m_bOwned; WinAndId(const rtl::OString &rId, Window *pWindow) : m_sID(rId) , m_pWindow(pWindow) + , m_nPosition(-1) , m_bOwned(true) { } @@ -126,7 +128,7 @@ public: ~VclBuilder(); Window *get_widget_root(); Window *get_by_name(rtl::OString sID); - rtl::OString get_by_window(const Window *pWindow); + rtl::OString get_by_window(const Window *pWindow) const; //for the purposes of retrofitting this to the existing code //look up sID, clone its properties into replacement and //splice replacement into the tree instead of it, without @@ -151,6 +153,9 @@ private: void handleAdjustment(const rtl::OString &rID, stringmap &rProperties); void handleTabChild(Window *pParent, xmlreader::XmlReader &reader); + sal_Int32 get_window_packing_position(const Window *pWindow) const; + void set_window_packing_position(const Window *pWindow, sal_Int32 nPosition); + //Helpers to retrofit all the existing code the the builder static void swapGuts(Window &rOrig, Window &rReplacement); static sal_uInt16 getPositionWithinParent(Window &rWindow); diff --git a/vcl/inc/vcl/layout.hxx b/vcl/inc/vcl/layout.hxx index e9ed52e44742..aa78852e4cbb 100644 --- a/vcl/inc/vcl/layout.hxx +++ b/vcl/inc/vcl/layout.hxx @@ -58,12 +58,6 @@ private: int m_nBorderWidth; }; -enum VclPackType -{ - VCL_PACK_START = 0, - VCL_PACK_END = 1 -}; - class VCL_DLLPUBLIC VclBox : public VclContainer { protected: diff --git a/vcl/inc/vcl/vclenum.hxx b/vcl/inc/vcl/vclenum.hxx index e497fc410514..a6558934c3ba 100644 --- a/vcl/inc/vcl/vclenum.hxx +++ b/vcl/inc/vcl/vclenum.hxx @@ -200,6 +200,12 @@ enum VclAlign VCL_ALIGN_CENTER }; +enum VclPackType +{ + VCL_PACK_START = 0, + VCL_PACK_END = 1 +}; + #endif // _VCL_VCLENUM_HXX /* vim:set shiftwidth=4 softtabstop=4 expandtab: */ diff --git a/vcl/inc/vcl/window.hxx b/vcl/inc/vcl/window.hxx index 312f8122ef39..ea82e8aa3340 100644 --- a/vcl/inc/vcl/window.hxx +++ b/vcl/inc/vcl/window.hxx @@ -47,8 +47,6 @@ #include <com/sun/star/uno/Reference.hxx> #include <boost/shared_ptr.hpp> -#include <map> - class VirtualDevice; struct ImplDelData; struct ImplWinData; @@ -386,10 +384,6 @@ private: // WindowImpl* mpWindowImpl; - //^^^la la la, I can't hear you^^^ - typedef std::map< ::rtl::OString, ::com::sun::star::uno::Any > ChildPropertyMap; - ChildPropertyMap m_aWidgetProperties; - SAL_DLLPRIVATE void ImplInitWindowData( WindowType nType ); #ifdef DBG_UTIL @@ -1164,45 +1158,96 @@ public: void set_vexpand(bool bExpand); /* + * Gets whether the widget would like to use any available extra space. + */ + bool get_expand() const; + + /* + * Sets whether the widget would like to use any available extra space. + */ + void set_expand(bool bExpand); + + /* + * Gets whether the widget should receive extra space when the parent grows + */ + bool get_fill() const; + + /* + * Sets whether the widget should receive extra space when the parent grows + */ + void set_fill(bool bFill); + + /* + * Gets how the widget is packed with reference to the start or end of the parent + */ + VclPackType get_pack_type() const; + + /* + * Sets how the widget is packed with reference to the start or end of the parent + */ + void set_pack_type(VclPackType ePackType); + + /* + * Sets extra space to put between the widget and its neighbors + */ + sal_Int32 get_padding() const; + + /* + * Sets extra space to put between the widget and its neighbors + */ + void set_padding(sal_Int32 nPadding); + + /* + * Gets the number of columns that the widget spans + */ + sal_Int32 get_grid_width() const; + + /* + * Sets the number of columns that the widget spans + */ + void set_grid_width(sal_Int32 nCols); + + /* + * Gets the column number to attach the left side of the widget to + */ + sal_Int32 get_grid_left_attach() const; + + /* + * Sets the column number to attach the left side of the widget to + */ + void set_grid_left_attach(sal_Int32 nAttach); + + /* + * Gets the number of row that the widget spans + */ + sal_Int32 get_grid_height() const; + + /* + * Sets the number of row that the widget spans + */ + void set_grid_height(sal_Int32 nRows); + + /* + * Gets the row number to attach the top side of the widget to + */ + sal_Int32 get_grid_top_attach() const; + + /* + * Sets the row number to attach the top side of the widget to + */ + void set_grid_top_attach(sal_Int32 nAttach); + + + /* * Sets a widget property * * @return false if property is unknown */ virtual bool set_property(const rtl::OString &rKey, const rtl::OString &rValue); - virtual void setChildAnyProperty(const rtl::OString &rString, const ::com::sun::star::uno::Any &rValue); - virtual ::com::sun::star::uno::Any getWidgetAnyProperty(const rtl::OString &rString) const; - - template <typename T> T getWidgetProperty(const rtl::OString &rString, const T &rDefaultValue = T()) const - { - T nValue = rDefaultValue; - ::com::sun::star::uno::Any aAny = getWidgetAnyProperty(rString); - if (aAny.hasValue()) - aAny >>= nValue; - return nValue; - } - template <typename T> void setChildProperty(const rtl::OString &rString, const T &rValue) - { - ::com::sun::star::uno::Any aAny; - aAny <<= rValue; - setChildAnyProperty(rString, aAny); - } - void setChildProperty(const rtl::OString &rString, const bool &rValue) - { - setChildProperty<sal_Bool>(rString, rValue); - } - bool getWidgetProperty(const rtl::OString &rString, const bool &rValue = false) const - { - return getWidgetProperty<sal_Bool>(rString, rValue); - } - - //does nothing yet - template <typename T> T getWidgetStyleProperty(const rtl::OString &, const T &rDefaultValue = T()) const - { - T nValue = rDefaultValue; - return nValue; - } - + /* + * Move this widget to be the nNewPosition'd child of its parent + */ void reorderWithinParent(sal_uInt16 nNewPosition); /* diff --git a/vcl/inc/window.h b/vcl/inc/window.h index af7443cbe613..cf27c16ed00e 100644 --- a/vcl/inc/window.h +++ b/vcl/inc/window.h @@ -317,6 +317,12 @@ public: AlwaysInputMode meAlwaysInputMode; VclAlign meHalign; VclAlign meValign; + VclPackType mePackType; + sal_Int32 mnPadding; + sal_Int32 mnGridHeight; + sal_Int32 mnGridLeftAttach; + sal_Int32 mnGridTopAttach; + sal_Int32 mnGridWidth; sal_uInt8 mbFrame:1, mbBorderWin:1, mbOverlapWin:1, @@ -392,7 +398,9 @@ public: mbHelpTextDynamic:1, mbFakeFocusSet:1, mbHexpand:1, - mbVexpand:1; + mbVexpand:1, + mbExpand:1, + mbFill:1; ::com::sun::star::uno::Reference< ::com::sun::star::uno::XInterface > mxDNDListenerContainer; }; diff --git a/vcl/source/window/brdwin.cxx b/vcl/source/window/brdwin.cxx index 45b83b098e71..6d05ba906783 100644 --- a/vcl/source/window/brdwin.cxx +++ b/vcl/source/window/brdwin.cxx @@ -2354,20 +2354,4 @@ Size ImplBorderWindow::GetOptimalSize(WindowSizeType eType) const return Size(0, 0); } -void ImplBorderWindow::setChildAnyProperty(const rtl::OString &rString, const ::com::sun::star::uno::Any &rValue) -{ - Window* pClientWindow = ImplGetClientWindow(); - if (pClientWindow) - pClientWindow->setChildAnyProperty(rString, rValue); -} - -::com::sun::star::uno::Any ImplBorderWindow::getWidgetAnyProperty(const rtl::OString &rString) const -{ - ::com::sun::star::uno::Any aAny; - Window* pClientWindow = ImplGetClientWindow(); - if (pClientWindow) - aAny = pClientWindow->getWidgetAnyProperty(rString); - return aAny; -} - /* vim:set shiftwidth=4 softtabstop=4 expandtab: */ diff --git a/vcl/source/window/builder.cxx b/vcl/source/window/builder.cxx index 43f4030a974e..0176bfadfe23 100644 --- a/vcl/source/window/builder.cxx +++ b/vcl/source/window/builder.cxx @@ -599,8 +599,8 @@ void VclBuilder::handleChild(Window *pParent, xmlreader::XmlReader &reader) for (size_t i = 0; i < aChilds.size(); ++i) { - sal_uInt16 nPosition = aChilds[i]->getWidgetProperty<sal_uInt16>(sPosition, 0xFFFF); - if (nPosition == 0xFFFF) + sal_Int32 nPosition = get_window_packing_position(aChilds[i]); + if (nPosition == -1) continue; reorderWithinParent(*aChilds[i], nPosition); } @@ -832,29 +832,44 @@ void VclBuilder::applyPackingProperty(Window *pCurrent, xmlreader::XmlReader::TEXT_NORMALIZED, &name, &nsId); rtl::OString sValue(name.begin, name.length); - if ( sKey.equalsL(RTL_CONSTASCII_STRINGPARAM("expand")) || - sKey.equalsL(RTL_CONSTASCII_STRINGPARAM("fill")) ) + if (sKey.equalsL(RTL_CONSTASCII_STRINGPARAM("expand"))) { bool bTrue = (sValue[0] == 't' || sValue[0] == 'T' || sValue[0] == '1'); - pCurrent->setChildProperty(sKey, bTrue); + pCurrent->set_expand(bTrue); } - else if (sKey.equalsL(RTL_CONSTASCII_STRINGPARAM("position"))) + else if (sKey.equalsL(RTL_CONSTASCII_STRINGPARAM("fill"))) { - pCurrent->setChildProperty(sKey, static_cast<sal_uInt16>(sValue.toInt32())); + bool bTrue = (sValue[0] == 't' || sValue[0] == 'T' || sValue[0] == '1'); + pCurrent->set_fill(bTrue); } else if (sKey.equalsL(RTL_CONSTASCII_STRINGPARAM("pack-type"))) { - sal_Int32 nPackType = (sValue[0] == 'e' || sValue[0] == 'e') ? VCL_PACK_END : VCL_PACK_START; - pCurrent->setChildProperty(sKey, nPackType); + VclPackType ePackType = (sValue[0] == 'e' || sValue[0] == 'e') ? VCL_PACK_END : VCL_PACK_START; + pCurrent->set_pack_type(ePackType); + } + else if (sKey.equalsL(RTL_CONSTASCII_STRINGPARAM("left-attach"))) + { + pCurrent->set_grid_left_attach(sValue.toInt32()); + } + else if (sKey.equalsL(RTL_CONSTASCII_STRINGPARAM("top-attach"))) + { + pCurrent->set_grid_top_attach(sValue.toInt32()); } - else if ( - sKey.equalsL(RTL_CONSTASCII_STRINGPARAM("left-attach")) || - sKey.equalsL(RTL_CONSTASCII_STRINGPARAM("top-attach")) || - sKey.equalsL(RTL_CONSTASCII_STRINGPARAM("width")) || - sKey.equalsL(RTL_CONSTASCII_STRINGPARAM("height")) - ) + else if (sKey.equalsL(RTL_CONSTASCII_STRINGPARAM("width"))) { - pCurrent->setChildProperty(sKey, sValue.toInt32()); + pCurrent->set_grid_width(sValue.toInt32()); + } + else if (sKey.equalsL(RTL_CONSTASCII_STRINGPARAM("height"))) + { + pCurrent->set_grid_height(sValue.toInt32()); + } + else if (sKey.equalsL(RTL_CONSTASCII_STRINGPARAM("padding"))) + { + pCurrent->set_padding(sValue.toInt32()); + } + else if (sKey.equalsL(RTL_CONSTASCII_STRINGPARAM("position"))) + { + set_window_packing_position(pCurrent, sValue.toInt32()); } else fprintf(stderr, "unknown packing %s\n", sKey.getStr()); @@ -934,9 +949,9 @@ Window *VclBuilder::get_by_name(rtl::OString sID) return NULL; } -rtl::OString VclBuilder::get_by_window(const Window *pWindow) +rtl::OString VclBuilder::get_by_window(const Window *pWindow) const { - for (std::vector<WinAndId>::iterator aI = m_aChildren.begin(), + for (std::vector<WinAndId>::const_iterator aI = m_aChildren.begin(), aEnd = m_aChildren.end(); aI != aEnd; ++aI) { if (aI->m_pWindow == pWindow) @@ -946,6 +961,28 @@ rtl::OString VclBuilder::get_by_window(const Window *pWindow) return rtl::OString(); } +sal_Int32 VclBuilder::get_window_packing_position(const Window *pWindow) const +{ + for (std::vector<WinAndId>::const_iterator aI = m_aChildren.begin(), + aEnd = m_aChildren.end(); aI != aEnd; ++aI) + { + if (aI->m_pWindow == pWindow) + return aI->m_nPosition; + } + + return -1; +} + +void VclBuilder::set_window_packing_position(const Window *pWindow, sal_Int32 nPosition) +{ + for (std::vector<WinAndId>::iterator aI = m_aChildren.begin(), + aEnd = m_aChildren.end(); aI != aEnd; ++aI) + { + if (aI->m_pWindow == pWindow) + aI->m_nPosition = nPosition; + } +} + VclBuilder::ListStore *VclBuilder::get_model_by_name(rtl::OString sID) { for (std::vector<ModelAndId>::iterator aI = m_aModels.begin(), @@ -994,7 +1031,6 @@ void VclBuilder::swapGuts(Window &rOrig, Window &rReplacement) Window *pOrigsNext = rOrig.mpWindowImpl->mpNext; Window *pOrigsPrev = rOrig.mpWindowImpl->mpPrev; std::swap(rOrig.mpWindowImpl, rReplacement.mpWindowImpl); - std::swap(rOrig.m_aWidgetProperties, rReplacement.m_aWidgetProperties); assert(rReplacement.mpWindowImpl->mpPrev == pOrigsPrev); assert(rReplacement.mpWindowImpl->mpNext == pOrigsNext); if (pOrigsNext) diff --git a/vcl/source/window/layout.cxx b/vcl/source/window/layout.cxx index d3a8ab4757c7..6c9305c4f56c 100644 --- a/vcl/source/window/layout.cxx +++ b/vcl/source/window/layout.cxx @@ -170,7 +170,7 @@ void VclBox::setAllocation(const Size &rAllocation) if (!pChild->IsVisible()) continue; ++nVisibleChildren; - bool bExpand = pChild->getWidgetProperty<sal_Bool>(sExpand); + bool bExpand = pChild->get_expand(); if (bExpand) ++nExpandChildren; } @@ -210,12 +210,12 @@ void VclBox::setAllocation(const Size &rAllocation) if (!pChild->IsVisible()) continue; - sal_Int32 ePacking = pChild->getWidgetProperty<sal_Int32>(sPackType); + sal_Int32 ePacking = pChild->get_pack_type(); if (ePacking != ePackType) continue; - long nPadding = pChild->getWidgetProperty<sal_Int32>(sPadding); + long nPadding = pChild->get_padding(); Size aBoxSize; if (m_bHomogeneous) @@ -225,7 +225,7 @@ void VclBox::setAllocation(const Size &rAllocation) aBoxSize = pChild->get_preferred_size(); long nPrimaryDimension = getPrimaryDimension(aBoxSize); nPrimaryDimension += nPadding; - bool bExpand = pChild->getWidgetProperty<bool>(sExpand); + bool bExpand = pChild->get_expand(); if (bExpand) setPrimaryDimension(aBoxSize, nPrimaryDimension + nExtraSpace); } @@ -235,7 +235,7 @@ void VclBox::setAllocation(const Size &rAllocation) Size aChildSize(aBoxSize); long nPrimaryCoordinate = getPrimaryCoordinate(aPos); - bool bFill = pChild->getWidgetProperty<sal_Bool>(sFill, sal_True); + bool bFill = pChild->get_fill(); if (bFill) { setPrimaryDimension(aChildSize, std::max(static_cast<long>(1), @@ -287,10 +287,8 @@ Size VclButtonBox::calculateRequisition() const { sal_uInt16 nVisibleChildren = 0; - rtl::OString sChildMinWidth(RTL_CONSTASCII_STRINGPARAM("child-min-width")); - sal_Int32 nChildMinWidth = getWidgetStyleProperty<sal_Int32>(sChildMinWidth, DEFAULT_CHILD_MIN_WIDTH); - rtl::OString sChildMinHeight(RTL_CONSTASCII_STRINGPARAM("child-min-height")); - sal_Int32 nChildMinHeight = getWidgetStyleProperty<sal_Int32>(sChildMinHeight, DEFAULT_CHILD_MIN_HEIGHT); + sal_Int32 nChildMinWidth = DEFAULT_CHILD_MIN_WIDTH; //to-do, pull from theme + sal_Int32 nChildMinHeight = DEFAULT_CHILD_MIN_HEIGHT; //to-do, pull from theme Size aSize(nChildMinWidth, nChildMinHeight); for (Window *pChild = GetWindow(WINDOW_FIRSTCHILD); pChild; pChild = pChild->GetWindow(WINDOW_NEXT)) @@ -413,12 +411,12 @@ VclGrid::array_type VclGrid::assembleGrid() const if (!pChild->IsVisible()) continue; - sal_Int32 nLeftAttach = pChild->getWidgetProperty<sal_Int32>(sLeftAttach); - sal_Int32 nWidth = pChild->getWidgetProperty<sal_Int32>(sWidth, 1); + sal_Int32 nLeftAttach = pChild->get_grid_left_attach(); + sal_Int32 nWidth = pChild->get_grid_width(); sal_Int32 nMaxXPos = nLeftAttach+nWidth-1; - sal_Int32 nTopAttach = pChild->getWidgetProperty<sal_Int32>(sTopAttach); - sal_Int32 nHeight = pChild->getWidgetProperty<sal_Int32>(sHeight, 1); + sal_Int32 nTopAttach = pChild->get_grid_top_attach(); + sal_Int32 nHeight = pChild->get_grid_height(); sal_Int32 nMaxYPos = nTopAttach+nHeight-1; sal_Int32 nCurrentMaxXPos = A.shape()[0]-1; @@ -448,11 +446,11 @@ VclGrid::array_type VclGrid::assembleGrid() const const Window *pChild = A[x][y]; if (pChild) { - sal_Int32 nWidth = pChild->getWidgetProperty<sal_Int32>(sWidth, 1); + sal_Int32 nWidth = pChild->get_grid_width(); for (sal_Int32 nSpanX = 0; nSpanX < nWidth; ++nSpanX) aNonEmptyCols[x+nSpanX] = true; - sal_Int32 nHeight = pChild->getWidgetProperty<sal_Int32>(sHeight, 1); + sal_Int32 nHeight = pChild->get_grid_height(); for (sal_Int32 nSpanY = 0; nSpanY < nHeight; ++nSpanY) aNonEmptyRows[y+nSpanY] = true; } @@ -514,11 +512,11 @@ void VclGrid::calcMaxs(const array_type &A, std::vector<long> &rWidths, std::vec continue; Size aChildSize = pChild->get_preferred_size(); - sal_Int32 nWidth = pChild->getWidgetProperty<sal_Int32>(sWidth, 1); + sal_Int32 nWidth = pChild->get_grid_width(); for (sal_Int32 nSpanX = 0; nSpanX < nWidth; ++nSpanX) rWidths[x+nSpanX] = std::max(rWidths[x+nSpanX], aChildSize.Width()/nWidth); - sal_Int32 nHeight = pChild->getWidgetProperty<sal_Int32>(sHeight, 1); + sal_Int32 nHeight = pChild->get_grid_height(); for (sal_Int32 nSpanY = 0; nSpanY < nHeight; ++nSpanY) rHeights[y+nSpanY] = std::max(rHeights[y+nSpanY], aChildSize.Height()/nHeight); } @@ -619,12 +617,12 @@ void VclGrid::setAllocation(const Size& rAllocation) { Size aChildAlloc(0, 0); - sal_Int32 nWidth = pChild->getWidgetProperty<sal_Int32>(sWidth, 1); + sal_Int32 nWidth = pChild->get_grid_width(); for (sal_Int32 nSpanX = 0; nSpanX < nWidth; ++nSpanX) aChildAlloc.Width() += aWidths[x+nSpanX]; aChildAlloc.Width() += get_column_spacing()*(nWidth-1); - sal_Int32 nHeight = pChild->getWidgetProperty<sal_Int32>(sHeight, 1); + sal_Int32 nHeight = pChild->get_grid_height(); for (sal_Int32 nSpanY = 0; nSpanY < nHeight; ++nSpanY) aChildAlloc.Height() += aHeights[y+nSpanY]; aChildAlloc.Height() += get_row_spacing()*(nHeight-1); @@ -715,14 +713,10 @@ bool VclGrid::set_property(const rtl::OString &rKey, const rtl::OString &rValue) void setGridAttach(Window &rWidget, sal_Int32 nLeft, sal_Int32 nTop, sal_Int32 nWidth, sal_Int32 nHeight) { - rtl::OString sLeftAttach(RTL_CONSTASCII_STRINGPARAM("left-attach")); - rWidget.setChildProperty<sal_Int32>(sLeftAttach, nLeft); - rtl::OString sTopAttach(RTL_CONSTASCII_STRINGPARAM("top-attach")); - rWidget.setChildProperty<sal_Int32>(sTopAttach, nTop); - rtl::OString sWidth(RTL_CONSTASCII_STRINGPARAM("width")); - rWidget.setChildProperty<sal_Int32>(sWidth, nWidth); - rtl::OString sHeight(RTL_CONSTASCII_STRINGPARAM("height")); - rWidget.setChildProperty<sal_Int32>(sHeight, nHeight); + rWidget.set_grid_left_attach(nLeft); + rWidget.set_grid_top_attach(nTop); + rWidget.set_grid_width(nWidth); + rWidget.set_grid_height(nHeight); } const Window *VclBin::get_child() const diff --git a/vcl/source/window/window.cxx b/vcl/source/window/window.cxx index 543dfe07557b..997499125e48 100644 --- a/vcl/source/window/window.cxx +++ b/vcl/source/window/window.cxx @@ -634,6 +634,14 @@ void Window::ImplInitWindowData( WindowType nType ) mpWindowImpl->mnDlgCtrlFlags = 0; // DialogControl-Flags mpWindowImpl->mnLockCount = 0; // LockCount mpWindowImpl->meAlwaysInputMode = AlwaysInputNone; // neither AlwaysEnableInput nor AlwaysDisableInput called + mpWindowImpl->meHalign = VCL_ALIGN_FILL; + mpWindowImpl->meValign = VCL_ALIGN_FILL; + mpWindowImpl->mePackType = VCL_PACK_START; + mpWindowImpl->mnPadding = 0; + mpWindowImpl->mnGridHeight = 1; + mpWindowImpl->mnGridLeftAttach = 0; + mpWindowImpl->mnGridTopAttach = 0; + mpWindowImpl->mnGridWidth = 1; mpWindowImpl->mbFrame = sal_False; // sal_True: Window is a frame window mpWindowImpl->mbBorderWin = sal_False; // sal_True: Window is a border window mpWindowImpl->mbOverlapWin = sal_False; // sal_True: Window is a overlap window @@ -711,8 +719,8 @@ void Window::ImplInitWindowData( WindowType nType ) mpWindowImpl->mbFakeFocusSet = sal_False; // sal_True: pretend as if the window has focus. mpWindowImpl->mbHexpand = false; mpWindowImpl->mbVexpand = false; - mpWindowImpl->meHalign = VCL_ALIGN_FILL; - mpWindowImpl->meValign = VCL_ALIGN_FILL; + mpWindowImpl->mbExpand = false; + mpWindowImpl->mbFill = true; mbEnableRTL = Application::GetSettings().GetLayoutRTL(); // sal_True: this outdev will be mirrored if RTL window layout (UI mirroring) is globally active @@ -5411,28 +5419,6 @@ void Window::SetStyle( WinBits nStyle ) } } -void Window::set_height_request(sal_Int32 nHeightRequest) -{ - DBG_CHKTHIS( Window, ImplDbgCheckWindow ); - - if ( mpWindowImpl->mnHeightRequest != nHeightRequest ) - { - mpWindowImpl->mnHeightRequest = nHeightRequest; - queue_resize(); - } -} - -void Window::set_width_request(sal_Int32 nWidthRequest) -{ - DBG_CHKTHIS( Window, ImplDbgCheckWindow ); - - if ( mpWindowImpl->mnWidthRequest != nWidthRequest ) - { - mpWindowImpl->mnWidthRequest = nWidthRequest; - queue_resize(); - } -} - // ----------------------------------------------------------------------- void Window::SetExtendedStyle( WinBits nExtendedStyle ) diff --git a/vcl/source/window/window2.cxx b/vcl/source/window/window2.cxx index b966a19de7cd..f760f130f423 100644 --- a/vcl/source/window/window2.cxx +++ b/vcl/source/window/window2.cxx @@ -1761,34 +1761,6 @@ void Window::queue_resize() pParent->Resize(); } -void Window::setChildAnyProperty(const rtl::OString &rString, const uno::Any &rValue) -{ - m_aWidgetProperties[rString] <<= rValue; -} - -uno::Any Window::getWidgetAnyProperty(const rtl::OString &rString) const -{ - uno::Any aAny; - ChildPropertyMap::const_iterator aI = m_aWidgetProperties.find(rString); - if (aI != m_aWidgetProperties.end()) - aAny = aI->second; - return aAny; -} - -Size Window::get_preferred_size() const -{ - Size aRet(mpWindowImpl->mnWidthRequest, mpWindowImpl->mnHeightRequest); - if (aRet.Width() == -1 || aRet.Height() == -1) - { - Size aOptimal = GetOptimalSize(WINDOWSIZE_PREFERRED); - if (aRet.Width() == -1) - aRet.Width() = aOptimal.Width(); - if (aRet.Height() == -1) - aRet.Height() = aOptimal.Height(); - } - return aRet; -} - void Window::take_properties(Window &rOther) { if (!mpWindowImpl) @@ -1838,6 +1810,14 @@ void Window::take_properties(Window &rOther) mpWindowImpl->mnDlgCtrlFlags = pWindowImpl->mnDlgCtrlFlags; mpWindowImpl->mnLockCount = pWindowImpl->mnLockCount; mpWindowImpl->meAlwaysInputMode = pWindowImpl->meAlwaysInputMode; + mpWindowImpl->meHalign = pWindowImpl->meHalign; + mpWindowImpl->meValign = pWindowImpl->meValign; + mpWindowImpl->mePackType = pWindowImpl->mePackType; + mpWindowImpl->mnPadding = pWindowImpl->mnPadding; + mpWindowImpl->mnGridHeight = pWindowImpl->mnGridHeight; + mpWindowImpl->mnGridLeftAttach = pWindowImpl->mnGridLeftAttach; + mpWindowImpl->mnGridTopAttach = pWindowImpl->mnGridTopAttach; + mpWindowImpl->mnGridWidth = pWindowImpl->mnGridWidth; mpWindowImpl->mbFrame = pWindowImpl->mbFrame; mpWindowImpl->mbBorderWin = pWindowImpl->mbBorderWin; mpWindowImpl->mbOverlapWin = pWindowImpl->mbOverlapWin; @@ -1914,10 +1894,8 @@ void Window::take_properties(Window &rOther) mpWindowImpl->mbFakeFocusSet = pWindowImpl->mbFakeFocusSet; mpWindowImpl->mbHexpand = pWindowImpl->mbHexpand; mpWindowImpl->mbVexpand = pWindowImpl->mbVexpand; - mpWindowImpl->meHalign = pWindowImpl->meHalign; - mpWindowImpl->meValign = pWindowImpl->meValign; - - std::swap(m_aWidgetProperties, rOther.m_aWidgetProperties); + mpWindowImpl->mbExpand = pWindowImpl->mbExpand; + mpWindowImpl->mbFill = pWindowImpl->mbFill; bool bHasBorderWindow = mpWindowImpl->mpBorderWindow; bool bOtherHasBorderWindow = pWindowImpl->mpBorderWindow; @@ -2018,44 +1996,190 @@ bool Window::set_property(const rtl::OString &rKey, const rtl::OString &rValue) return true; } +void Window::set_height_request(sal_Int32 nHeightRequest) +{ + DBG_CHKTHIS( Window, ImplDbgCheckWindow ); + + WindowImpl *pWindowImpl = mpWindowImpl->mpBorderWindow ? mpWindowImpl->mpBorderWindow->mpWindowImpl : mpWindowImpl; + + if ( pWindowImpl->mnHeightRequest != nHeightRequest ) + { + pWindowImpl->mnHeightRequest = nHeightRequest; + queue_resize(); + } +} + +void Window::set_width_request(sal_Int32 nWidthRequest) +{ + DBG_CHKTHIS( Window, ImplDbgCheckWindow ); + + WindowImpl *pWindowImpl = mpWindowImpl->mpBorderWindow ? mpWindowImpl->mpBorderWindow->mpWindowImpl : mpWindowImpl; + + if ( pWindowImpl->mnWidthRequest != nWidthRequest ) + { + pWindowImpl->mnWidthRequest = nWidthRequest; + queue_resize(); + } +} + +Size Window::get_preferred_size() const +{ + WindowImpl *pWindowImpl = mpWindowImpl->mpBorderWindow ? mpWindowImpl->mpBorderWindow->mpWindowImpl : mpWindowImpl; + + Size aRet(pWindowImpl->mnWidthRequest, pWindowImpl->mnHeightRequest); + if (aRet.Width() == -1 || aRet.Height() == -1) + { + Size aOptimal = GetOptimalSize(WINDOWSIZE_PREFERRED); + if (aRet.Width() == -1) + aRet.Width() = aOptimal.Width(); + if (aRet.Height() == -1) + aRet.Height() = aOptimal.Height(); + } + return aRet; +} + VclAlign Window::get_halign() const { - return mpWindowImpl->meHalign; + WindowImpl *pWindowImpl = mpWindowImpl->mpBorderWindow ? mpWindowImpl->mpBorderWindow->mpWindowImpl : mpWindowImpl; + return pWindowImpl->meHalign; } void Window::set_halign(VclAlign eAlign) { - mpWindowImpl->meHalign = eAlign; + WindowImpl *pWindowImpl = mpWindowImpl->mpBorderWindow ? mpWindowImpl->mpBorderWindow->mpWindowImpl : mpWindowImpl; + pWindowImpl->meHalign = eAlign; } VclAlign Window::get_valign() const { - return mpWindowImpl->meValign; + WindowImpl *pWindowImpl = mpWindowImpl->mpBorderWindow ? mpWindowImpl->mpBorderWindow->mpWindowImpl : mpWindowImpl; + return pWindowImpl->meValign; } void Window::set_valign(VclAlign eAlign) { - mpWindowImpl->meValign = eAlign; + WindowImpl *pWindowImpl = mpWindowImpl->mpBorderWindow ? mpWindowImpl->mpBorderWindow->mpWindowImpl : mpWindowImpl; + pWindowImpl->meValign = eAlign; } bool Window::get_hexpand() const { - return mpWindowImpl->mbHexpand; + WindowImpl *pWindowImpl = mpWindowImpl->mpBorderWindow ? mpWindowImpl->mpBorderWindow->mpWindowImpl : mpWindowImpl; + return pWindowImpl->mbHexpand; } void Window::set_hexpand(bool bExpand) { - mpWindowImpl->mbHexpand = bExpand; + WindowImpl *pWindowImpl = mpWindowImpl->mpBorderWindow ? mpWindowImpl->mpBorderWindow->mpWindowImpl : mpWindowImpl; + pWindowImpl->mbHexpand = bExpand; } bool Window::get_vexpand() const { - return mpWindowImpl->mbVexpand; + WindowImpl *pWindowImpl = mpWindowImpl->mpBorderWindow ? mpWindowImpl->mpBorderWindow->mpWindowImpl : mpWindowImpl; + return pWindowImpl->mbVexpand; } void Window::set_vexpand(bool bExpand) { - mpWindowImpl->mbVexpand = bExpand; + WindowImpl *pWindowImpl = mpWindowImpl->mpBorderWindow ? mpWindowImpl->mpBorderWindow->mpWindowImpl : mpWindowImpl; + pWindowImpl->mbVexpand = bExpand; +} + +bool Window::get_expand() const +{ + WindowImpl *pWindowImpl = mpWindowImpl->mpBorderWindow ? mpWindowImpl->mpBorderWindow->mpWindowImpl : mpWindowImpl; + return pWindowImpl->mbExpand; +} + +void Window::set_expand(bool bExpand) +{ + WindowImpl *pWindowImpl = mpWindowImpl->mpBorderWindow ? mpWindowImpl->mpBorderWindow->mpWindowImpl : mpWindowImpl; + pWindowImpl->mbExpand = bExpand; +} + +VclPackType Window::get_pack_type() const +{ + WindowImpl *pWindowImpl = mpWindowImpl->mpBorderWindow ? mpWindowImpl->mpBorderWindow->mpWindowImpl : mpWindowImpl; + return pWindowImpl->mePackType; +} + +void Window::set_pack_type(VclPackType ePackType) +{ + WindowImpl *pWindowImpl = mpWindowImpl->mpBorderWindow ? mpWindowImpl->mpBorderWindow->mpWindowImpl : mpWindowImpl; + pWindowImpl->mePackType = ePackType; +} + +sal_Int32 Window::get_padding() const +{ + WindowImpl *pWindowImpl = mpWindowImpl->mpBorderWindow ? mpWindowImpl->mpBorderWindow->mpWindowImpl : mpWindowImpl; + return pWindowImpl->mnPadding; +} + +void Window::set_padding(sal_Int32 nPadding) +{ + WindowImpl *pWindowImpl = mpWindowImpl->mpBorderWindow ? mpWindowImpl->mpBorderWindow->mpWindowImpl : mpWindowImpl; + pWindowImpl->mnPadding = nPadding; +} + +bool Window::get_fill() const +{ + WindowImpl *pWindowImpl = mpWindowImpl->mpBorderWindow ? mpWindowImpl->mpBorderWindow->mpWindowImpl : mpWindowImpl; + return pWindowImpl->mbFill; +} + +void Window::set_fill(bool bFill) +{ + WindowImpl *pWindowImpl = mpWindowImpl->mpBorderWindow ? mpWindowImpl->mpBorderWindow->mpWindowImpl : mpWindowImpl; + pWindowImpl->mbFill = bFill; +} + +sal_Int32 Window::get_grid_width() const +{ + WindowImpl *pWindowImpl = mpWindowImpl->mpBorderWindow ? mpWindowImpl->mpBorderWindow->mpWindowImpl : mpWindowImpl; + return pWindowImpl->mnGridWidth; +} + +void Window::set_grid_width(sal_Int32 nCols) +{ + WindowImpl *pWindowImpl = mpWindowImpl->mpBorderWindow ? mpWindowImpl->mpBorderWindow->mpWindowImpl : mpWindowImpl; + pWindowImpl->mnGridWidth = nCols; +} + +sal_Int32 Window::get_grid_left_attach() const +{ + WindowImpl *pWindowImpl = mpWindowImpl->mpBorderWindow ? mpWindowImpl->mpBorderWindow->mpWindowImpl : mpWindowImpl; + return pWindowImpl->mnGridLeftAttach; +} + +void Window::set_grid_left_attach(sal_Int32 nAttach) +{ + WindowImpl *pWindowImpl = mpWindowImpl->mpBorderWindow ? mpWindowImpl->mpBorderWindow->mpWindowImpl : mpWindowImpl; + pWindowImpl->mnGridLeftAttach = nAttach; +} + +sal_Int32 Window::get_grid_height() const +{ + WindowImpl *pWindowImpl = mpWindowImpl->mpBorderWindow ? mpWindowImpl->mpBorderWindow->mpWindowImpl : mpWindowImpl; + return pWindowImpl->mnGridHeight; +} + +void Window::set_grid_height(sal_Int32 nRows) +{ + WindowImpl *pWindowImpl = mpWindowImpl->mpBorderWindow ? mpWindowImpl->mpBorderWindow->mpWindowImpl : mpWindowImpl; + pWindowImpl->mnGridHeight = nRows; +} + +sal_Int32 Window::get_grid_top_attach() const +{ + WindowImpl *pWindowImpl = mpWindowImpl->mpBorderWindow ? mpWindowImpl->mpBorderWindow->mpWindowImpl : mpWindowImpl; + return pWindowImpl->mnGridTopAttach; +} + +void Window::set_grid_top_attach(sal_Int32 nAttach) +{ + WindowImpl *pWindowImpl = mpWindowImpl->mpBorderWindow ? mpWindowImpl->mpBorderWindow->mpWindowImpl : mpWindowImpl; + pWindowImpl->mnGridTopAttach = nAttach; } /* vim:set shiftwidth=4 softtabstop=4 expandtab: */ |