diff options
author | Caolán McNamara <caolanm@redhat.com> | 2016-06-23 14:31:18 +0100 |
---|---|---|
committer | Caolán McNamara <caolanm@redhat.com> | 2016-06-23 14:31:24 +0100 |
commit | 1413c5d39a45329b47c85511a3161c6f5a43c4f8 (patch) | |
tree | 60d5dff8dfbe71b76bfabb591438dc61f51589ea /vcl | |
parent | 3881fffe4233ce3aa02051b205c114c1cb520d67 (diff) |
map MenuToggleButton to GtkToggleButton with a custom menu property
we don't have non-menu ToggleButtons yet, so thats not done here.
since we first started with GtkPushButton:menu_attrib to indicate
menubuttons gtk has grown menu buttons, but they don't have the
idea of a gtktogglemenu button, so this attribute still has a role
to play I guess
Change-Id: Iebfe5ccf996e22784cf9aaf2bcf367eed79ae686
Diffstat (limited to 'vcl')
-rw-r--r-- | vcl/source/window/builder.cxx | 27 |
1 files changed, 27 insertions, 0 deletions
diff --git a/vcl/source/window/builder.cxx b/vcl/source/window/builder.cxx index fc8069e3a9eb..2f1fd3df4e7f 100644 --- a/vcl/source/window/builder.cxx +++ b/vcl/source/window/builder.cxx @@ -942,6 +942,22 @@ namespace return xWindow; } + VclPtr<Button> extractStockAndBuildMenuToggleButton(vcl::Window *pParent, VclBuilder::stringmap &rMap) + { + WinBits nBits = WB_CLIPCHILDREN|WB_CENTER|WB_VCENTER|WB_3DLOOK; + + nBits |= extractRelief(rMap); + + VclPtr<Button> xWindow = VclPtr<MenuToggleButton>::Create(pParent, nBits); + + if (extractStock(rMap)) + { + xWindow->SetText(getStockText(extractLabel(rMap))); + } + + return xWindow; + } + OString extractUnit(const OString& sPattern) { OString sUnit(sPattern); @@ -1370,6 +1386,17 @@ VclPtr<vcl::Window> VclBuilder::makeObject(vcl::Window *pParent, const OString & setupFromActionName(xButton, rMap, m_xFrame); xWindow = xButton; } + else if (name == "GtkToggleButton") + { + VclPtr<Button> xButton; + OString sMenu = extractCustomProperty(rMap); + assert(sMenu.getLength() && "not implemented yet"); + xButton = extractStockAndBuildMenuToggleButton(pParent, rMap); + m_pParserState->m_aButtonMenuMaps.push_back(ButtonMenuMap(id, sMenu)); + xButton->SetImageAlign(ImageAlign::Left); //default to left + setupFromActionName(xButton, rMap, m_xFrame); + xWindow = xButton; + } else if (name == "GtkRadioButton") { extractGroup(id, rMap); |