diff options
author | Caolán McNamara <caolanm@redhat.com> | 2018-06-12 11:22:15 +0100 |
---|---|---|
committer | Caolán McNamara <caolanm@redhat.com> | 2018-06-12 15:53:47 +0200 |
commit | df652aa70869f42ada2f4d8e7d1cacf55c6e6e96 (patch) | |
tree | 92d467081a8955fc71c2e69d2d2ced9a27c1dfde /cui/source | |
parent | 2c771d597f0afcdfa1c246877e57d49ae637fe01 (diff) |
weld SvxTransparenceTabPage
Change-Id: If8c8a6cf74664f9acd360d877c57e8dd9de2f2b5
Reviewed-on: https://gerrit.libreoffice.org/55683
Tested-by: Jenkins <ci@libreoffice.org>
Reviewed-by: Caolán McNamara <caolanm@redhat.com>
Tested-by: Caolán McNamara <caolanm@redhat.com>
Diffstat (limited to 'cui/source')
-rw-r--r-- | cui/source/inc/cuitabarea.hxx | 65 | ||||
-rw-r--r-- | cui/source/tabpages/tptrans.cxx | 352 |
2 files changed, 198 insertions, 219 deletions
diff --git a/cui/source/inc/cuitabarea.hxx b/cui/source/inc/cuitabarea.hxx index da368bf460e0..7a72431bb9a5 100644 --- a/cui/source/inc/cuitabarea.hxx +++ b/cui/source/inc/cuitabarea.hxx @@ -146,42 +146,48 @@ class SvxTransparenceTabPage : public SvxTabPage PageType nPageType; sal_uInt16 nDlgType; + bool bBitmap; + + XFillAttrSetItem aXFillAttr; + SfxItemSet& rXFSet; + + XRectPreview m_aCtlBitmapPreview; + XRectPreview m_aCtlXRectPreview; + // main selection - VclPtr<RadioButton> m_pRbtTransOff; - VclPtr<RadioButton> m_pRbtTransLinear; - VclPtr<RadioButton> m_pRbtTransGradient; + std::unique_ptr<weld::RadioButton> m_xRbtTransOff; + std::unique_ptr<weld::RadioButton> m_xRbtTransLinear; + std::unique_ptr<weld::RadioButton> m_xRbtTransGradient; /// linear transparency - VclPtr<MetricField> m_pMtrTransparent; + std::unique_ptr<weld::MetricSpinButton> m_xMtrTransparent; // gradient transparency - VclPtr<VclGrid> m_pGridGradient; - VclPtr<ListBox> m_pLbTrgrGradientType; - VclPtr<FixedText> m_pFtTrgrCenterX; - VclPtr<MetricField> m_pMtrTrgrCenterX; - VclPtr<FixedText> m_pFtTrgrCenterY; - VclPtr<MetricField> m_pMtrTrgrCenterY; - VclPtr<FixedText> m_pFtTrgrAngle; - VclPtr<MetricField> m_pMtrTrgrAngle; - VclPtr<MetricField> m_pMtrTrgrBorder; - VclPtr<MetricField> m_pMtrTrgrStartValue; - VclPtr<MetricField> m_pMtrTrgrEndValue; + std::unique_ptr<weld::Widget> m_xGridGradient; + std::unique_ptr<weld::ComboBoxText> m_xLbTrgrGradientType; + std::unique_ptr<weld::Label> m_xFtTrgrCenterX; + std::unique_ptr<weld::MetricSpinButton> m_xMtrTrgrCenterX; + std::unique_ptr<weld::Label> m_xFtTrgrCenterY; + std::unique_ptr<weld::MetricSpinButton> m_xMtrTrgrCenterY; + std::unique_ptr<weld::Label> m_xFtTrgrAngle; + std::unique_ptr<weld::MetricSpinButton> m_xMtrTrgrAngle; + std::unique_ptr<weld::MetricSpinButton> m_xMtrTrgrBorder; + std::unique_ptr<weld::MetricSpinButton> m_xMtrTrgrStartValue; + std::unique_ptr<weld::MetricSpinButton> m_xMtrTrgrEndValue; + std::unique_ptr<weld::Widget> m_xCtlBitmapBorder; + std::unique_ptr<weld::Widget> m_xCtlXRectBorder; // preview - VclPtr<SvxXRectPreview> m_pCtlBitmapPreview; - VclPtr<SvxXRectPreview> m_pCtlXRectPreview; - bool bBitmap; - - XFillAttrSetItem aXFillAttr; - SfxItemSet& rXFSet; + std::unique_ptr<weld::CustomWeld> m_xCtlBitmapPreview; + std::unique_ptr<weld::CustomWeld> m_xCtlXRectPreview; - DECL_LINK(ClickTransOffHdl_Impl, Button*, void ); - DECL_LINK(ClickTransLinearHdl_Impl, Button*, void ); - DECL_LINK(ClickTransGradientHdl_Impl, Button*, void ); - DECL_LINK(ModifyTransparentHdl_Impl, Edit&, void); - DECL_LINK(ModifiedTrgrEditHdl_Impl, Edit&, void); - DECL_LINK(ModifiedTrgrListBoxHdl_Impl, ListBox&, void); - void ModifiedTrgrHdl_Impl(void const *); + DECL_LINK(ClickTransOffHdl_Impl, weld::ToggleButton&, void); + DECL_LINK(ClickTransLinearHdl_Impl, weld::ToggleButton&, void); + DECL_LINK(ClickTransGradientHdl_Impl, weld::ToggleButton&, void ); + DECL_LINK(ModifyTransparentHdl_Impl, weld::MetricSpinButton&, void); + DECL_LINK(ModifiedTrgrEditHdl_Impl, weld::MetricSpinButton&, void); + DECL_LINK(ModifiedTrgrListBoxHdl_Impl, weld::ComboBoxText&, void); + void ModifiedTrgrHdl_Impl(const weld::ComboBoxText*); void ActivateLinear(bool bActivate); void ActivateGradient(bool bActivate); @@ -191,9 +197,8 @@ class SvxTransparenceTabPage : public SvxTabPage void InvalidatePreview (bool bEnable = true ); public: - SvxTransparenceTabPage(vcl::Window* pParent, const SfxItemSet& rInAttrs); + SvxTransparenceTabPage(TabPageParent pParent, const SfxItemSet& rInAttrs); virtual ~SvxTransparenceTabPage() override; - virtual void dispose() override; static VclPtr<SfxTabPage> Create(TabPageParent, const SfxItemSet*); static const sal_uInt16* GetRanges() { return pTransparenceRanges; } diff --git a/cui/source/tabpages/tptrans.cxx b/cui/source/tabpages/tptrans.cxx index 1f6fc20da7dd..f75416c0c94b 100644 --- a/cui/source/tabpages/tptrans.cxx +++ b/cui/source/tabpages/tptrans.cxx @@ -59,22 +59,22 @@ const sal_uInt16 SvxTransparenceTabPage::pTransparenceRanges[] = |* \************************************************************************/ -IMPL_LINK_NOARG(SvxTransparenceTabPage, ClickTransOffHdl_Impl, Button*, void) +IMPL_LINK_NOARG(SvxTransparenceTabPage, ClickTransOffHdl_Impl, weld::ToggleButton&, void) { // disable all other controls ActivateLinear(false); ActivateGradient(false); // Preview - rXFSet.ClearItem (XATTR_FILLTRANSPARENCE); - rXFSet.ClearItem (XATTR_FILLFLOATTRANSPARENCE); - m_pCtlXRectPreview->SetAttributes( aXFillAttr.GetItemSet() ); - m_pCtlBitmapPreview->SetAttributes( aXFillAttr.GetItemSet() ); + rXFSet.ClearItem(XATTR_FILLTRANSPARENCE); + rXFSet.ClearItem(XATTR_FILLFLOATTRANSPARENCE); + m_aCtlXRectPreview.SetAttributes( aXFillAttr.GetItemSet() ); + m_aCtlBitmapPreview.SetAttributes( aXFillAttr.GetItemSet() ); - InvalidatePreview( false ); + InvalidatePreview(false); } -IMPL_LINK_NOARG(SvxTransparenceTabPage, ClickTransLinearHdl_Impl, Button*, void) +IMPL_LINK_NOARG(SvxTransparenceTabPage, ClickTransLinearHdl_Impl, weld::ToggleButton&, void) { // enable linear, disable other ActivateLinear(true); @@ -82,10 +82,10 @@ IMPL_LINK_NOARG(SvxTransparenceTabPage, ClickTransLinearHdl_Impl, Button*, void) // preview rXFSet.ClearItem (XATTR_FILLFLOATTRANSPARENCE); - ModifyTransparentHdl_Impl (*m_pMtrTransparent); + ModifyTransparentHdl_Impl(*m_xMtrTransparent); } -IMPL_LINK_NOARG(SvxTransparenceTabPage, ClickTransGradientHdl_Impl, Button*, void) +IMPL_LINK_NOARG(SvxTransparenceTabPage, ClickTransGradientHdl_Impl, weld::ToggleButton&, void) { // enable gradient, disable other ActivateLinear(false); @@ -93,79 +93,56 @@ IMPL_LINK_NOARG(SvxTransparenceTabPage, ClickTransGradientHdl_Impl, Button*, voi // preview rXFSet.ClearItem (XATTR_FILLTRANSPARENCE); - ModifiedTrgrHdl_Impl (nullptr); + ModifiedTrgrHdl_Impl(nullptr); } SvxTransparenceTabPage::~SvxTransparenceTabPage() { - disposeOnce(); -} - -void SvxTransparenceTabPage::dispose() -{ - m_pRbtTransOff.clear(); - m_pRbtTransLinear.clear(); - m_pRbtTransGradient.clear(); - m_pMtrTransparent.clear(); - m_pGridGradient.clear(); - m_pLbTrgrGradientType.clear(); - m_pFtTrgrCenterX.clear(); - m_pMtrTrgrCenterX.clear(); - m_pFtTrgrCenterY.clear(); - m_pMtrTrgrCenterY.clear(); - m_pFtTrgrAngle.clear(); - m_pMtrTrgrAngle.clear(); - m_pMtrTrgrBorder.clear(); - m_pMtrTrgrStartValue.clear(); - m_pMtrTrgrEndValue.clear(); - m_pCtlBitmapPreview.clear(); - m_pCtlXRectPreview.clear(); - SvxTabPage::dispose(); } void SvxTransparenceTabPage::ActivateLinear(bool bActivate) { - m_pMtrTransparent->Enable(bActivate); + m_xMtrTransparent->set_sensitive(bActivate); } -IMPL_LINK_NOARG(SvxTransparenceTabPage, ModifyTransparentHdl_Impl, Edit&, void) +IMPL_LINK_NOARG(SvxTransparenceTabPage, ModifyTransparentHdl_Impl, weld::MetricSpinButton&, void) { - sal_uInt16 nPos = static_cast<sal_uInt16>(m_pMtrTransparent->GetValue()); + sal_uInt16 nPos = m_xMtrTransparent->get_value(FUNIT_PERCENT); rXFSet.Put(XFillTransparenceItem(nPos)); // preview InvalidatePreview(); } -IMPL_LINK(SvxTransparenceTabPage, ModifiedTrgrListBoxHdl_Impl, ListBox&, rListBox, void) +IMPL_LINK(SvxTransparenceTabPage, ModifiedTrgrListBoxHdl_Impl, weld::ComboBoxText&, rListBox, void) { ModifiedTrgrHdl_Impl(&rListBox); } -IMPL_LINK(SvxTransparenceTabPage, ModifiedTrgrEditHdl_Impl, Edit&, rBox, void) +IMPL_LINK_NOARG(SvxTransparenceTabPage, ModifiedTrgrEditHdl_Impl, weld::MetricSpinButton&, void) { - ModifiedTrgrHdl_Impl(&rBox); + ModifiedTrgrHdl_Impl(nullptr); } -void SvxTransparenceTabPage::ModifiedTrgrHdl_Impl(void const * pControl) +void SvxTransparenceTabPage::ModifiedTrgrHdl_Impl(const weld::ComboBoxText* pControl) { - if(pControl == m_pLbTrgrGradientType || pControl == this) + if (pControl == m_xLbTrgrGradientType.get()) { - css::awt::GradientStyle eXGS = static_cast<css::awt::GradientStyle>(m_pLbTrgrGradientType->GetSelectedEntryPos()); + css::awt::GradientStyle eXGS = static_cast<css::awt::GradientStyle>(m_xLbTrgrGradientType->get_active()); SetControlState_Impl( eXGS ); } // preview - sal_uInt8 nStartCol = static_cast<sal_uInt8>((static_cast<sal_uInt16>(m_pMtrTrgrStartValue->GetValue()) * 255) / 100); - sal_uInt8 nEndCol = static_cast<sal_uInt8>((static_cast<sal_uInt16>(m_pMtrTrgrEndValue->GetValue()) * 255) / 100); + sal_uInt8 nStartCol = static_cast<sal_uInt8>((static_cast<sal_uInt16>(m_xMtrTrgrStartValue->get_value(FUNIT_PERCENT)) * 255) / 100); + sal_uInt8 nEndCol = static_cast<sal_uInt8>((static_cast<sal_uInt16>(m_xMtrTrgrEndValue->get_value(FUNIT_PERCENT)) * 255) / 100); XGradient aTmpGradient( Color(nStartCol, nStartCol, nStartCol), Color(nEndCol, nEndCol, nEndCol), - static_cast<css::awt::GradientStyle>(m_pLbTrgrGradientType->GetSelectedEntryPos()), - static_cast<sal_uInt16>(m_pMtrTrgrAngle->GetValue()) * 10, - static_cast<sal_uInt16>(m_pMtrTrgrCenterX->GetValue()), - static_cast<sal_uInt16>(m_pMtrTrgrCenterY->GetValue()), - static_cast<sal_uInt16>(m_pMtrTrgrBorder->GetValue()), + static_cast<css::awt::GradientStyle>(m_xLbTrgrGradientType->get_active()), + static_cast<sal_uInt16>(m_xMtrTrgrAngle->get_value(FUNIT_DEGREE)) * 10, + static_cast<sal_uInt16>(m_xMtrTrgrCenterX->get_value(FUNIT_PERCENT)), + static_cast<sal_uInt16>(m_xMtrTrgrCenterY->get_value(FUNIT_PERCENT)), + static_cast<sal_uInt16>(m_xMtrTrgrBorder->get_value(FUNIT_PERCENT)), 100, 100); XFillFloatTransparenceItem aItem( aTmpGradient); @@ -176,11 +153,11 @@ void SvxTransparenceTabPage::ModifiedTrgrHdl_Impl(void const * pControl) void SvxTransparenceTabPage::ActivateGradient(bool bActivate) { - m_pGridGradient->Enable(bActivate); + m_xGridGradient->set_sensitive(bActivate); - if(bActivate) + if (bActivate) { - css::awt::GradientStyle eXGS = static_cast<css::awt::GradientStyle>(m_pLbTrgrGradientType->GetSelectedEntryPos()); + css::awt::GradientStyle eXGS = static_cast<css::awt::GradientStyle>(m_xLbTrgrGradientType->get_active()); SetControlState_Impl( eXGS ); } } @@ -191,107 +168,102 @@ void SvxTransparenceTabPage::SetControlState_Impl(css::awt::GradientStyle eXGS) { case css::awt::GradientStyle_LINEAR: case css::awt::GradientStyle_AXIAL: - m_pFtTrgrCenterX->Disable(); - m_pMtrTrgrCenterX->Disable(); - m_pFtTrgrCenterY->Disable(); - m_pMtrTrgrCenterY->Disable(); - m_pFtTrgrAngle->Enable(); - m_pMtrTrgrAngle->Enable(); + m_xFtTrgrCenterX->set_sensitive(false); + m_xMtrTrgrCenterX->set_sensitive(false); + m_xFtTrgrCenterY->set_sensitive(false); + m_xMtrTrgrCenterY->set_sensitive(false); + m_xFtTrgrAngle->set_sensitive(true); + m_xMtrTrgrAngle->set_sensitive(true); break; case css::awt::GradientStyle_RADIAL: - m_pFtTrgrCenterX->Enable(); - m_pMtrTrgrCenterX->Enable(); - m_pFtTrgrCenterY->Enable(); - m_pMtrTrgrCenterY->Enable(); - m_pFtTrgrAngle->Disable(); - m_pMtrTrgrAngle->Disable(); + m_xFtTrgrCenterX->set_sensitive(true); + m_xMtrTrgrCenterX->set_sensitive(true); + m_xFtTrgrCenterY->set_sensitive(true); + m_xMtrTrgrCenterY->set_sensitive(true); + m_xFtTrgrAngle->set_sensitive(false); + m_xMtrTrgrAngle->set_sensitive(false); break; case css::awt::GradientStyle_ELLIPTICAL: - m_pFtTrgrCenterX->Enable(); - m_pMtrTrgrCenterX->Enable(); - m_pFtTrgrCenterY->Enable(); - m_pMtrTrgrCenterY->Enable(); - m_pFtTrgrAngle->Enable(); - m_pMtrTrgrAngle->Enable(); + m_xFtTrgrCenterX->set_sensitive(true); + m_xMtrTrgrCenterX->set_sensitive(true); + m_xFtTrgrCenterY->set_sensitive(true); + m_xMtrTrgrCenterY->set_sensitive(true); + m_xFtTrgrAngle->set_sensitive(true); + m_xMtrTrgrAngle->set_sensitive(true); break; case css::awt::GradientStyle_SQUARE: case css::awt::GradientStyle_RECT: - m_pFtTrgrCenterX->Enable(); - m_pMtrTrgrCenterX->Enable(); - m_pFtTrgrCenterY->Enable(); - m_pMtrTrgrCenterY->Enable(); - m_pFtTrgrAngle->Enable(); - m_pMtrTrgrAngle->Enable(); + m_xFtTrgrCenterX->set_sensitive(true); + m_xMtrTrgrCenterX->set_sensitive(true); + m_xFtTrgrCenterY->set_sensitive(true); + m_xMtrTrgrCenterY->set_sensitive(true); + m_xFtTrgrAngle->set_sensitive(true); + m_xMtrTrgrAngle->set_sensitive(true); break; default: break; } } -SvxTransparenceTabPage::SvxTransparenceTabPage(vcl::Window* pParent, const SfxItemSet& rInAttrs) -: SvxTabPage ( pParent, - "TransparencyTabPage", - "cui/ui/transparencytabpage.ui", - rInAttrs), - rOutAttrs ( rInAttrs ), - nPageType ( PageType::Area ), - nDlgType (0), - bBitmap ( false ), - aXFillAttr ( rInAttrs.GetPool() ), - rXFSet ( aXFillAttr.GetItemSet() ) +SvxTransparenceTabPage::SvxTransparenceTabPage(TabPageParent pParent, const SfxItemSet& rInAttrs) + : SvxTabPage(pParent, "cui/ui/transparencytabpage.ui", "TransparencyTabPage", rInAttrs) + , rOutAttrs(rInAttrs) + , nPageType(PageType::Area) + , nDlgType(0) + , bBitmap(false) + , aXFillAttr(rInAttrs.GetPool()) + , rXFSet(aXFillAttr.GetItemSet()) + , m_xRbtTransOff(m_xBuilder->weld_radio_button("RBT_TRANS_OFF")) + , m_xRbtTransLinear(m_xBuilder->weld_radio_button("RBT_TRANS_LINEAR")) + , m_xRbtTransGradient(m_xBuilder->weld_radio_button("RBT_TRANS_GRADIENT")) + , m_xMtrTransparent(m_xBuilder->weld_metric_spin_button("MTR_TRANSPARENT", FUNIT_PERCENT)) + , m_xGridGradient(m_xBuilder->weld_widget("gridGradient")) + , m_xLbTrgrGradientType(m_xBuilder->weld_combo_box_text("LB_TRGR_GRADIENT_TYPES")) + , m_xFtTrgrCenterX(m_xBuilder->weld_label("FT_TRGR_CENTER_X")) + , m_xMtrTrgrCenterX(m_xBuilder->weld_metric_spin_button("MTR_TRGR_CENTER_X", FUNIT_PERCENT)) + , m_xFtTrgrCenterY(m_xBuilder->weld_label("FT_TRGR_CENTER_Y")) + , m_xMtrTrgrCenterY(m_xBuilder->weld_metric_spin_button("MTR_TRGR_CENTER_Y", FUNIT_PERCENT)) + , m_xFtTrgrAngle(m_xBuilder->weld_label("FT_TRGR_ANGLE")) + , m_xMtrTrgrAngle(m_xBuilder->weld_metric_spin_button("MTR_TRGR_ANGLE", FUNIT_DEGREE)) + , m_xMtrTrgrBorder(m_xBuilder->weld_metric_spin_button("MTR_TRGR_BORDER", FUNIT_PERCENT)) + , m_xMtrTrgrStartValue(m_xBuilder->weld_metric_spin_button("MTR_TRGR_START_VALUE", FUNIT_PERCENT)) + , m_xMtrTrgrEndValue(m_xBuilder->weld_metric_spin_button("MTR_TRGR_END_VALUE", FUNIT_PERCENT)) + , m_xCtlBitmapBorder(m_xBuilder->weld_widget("bitmap_border")) + , m_xCtlXRectBorder(m_xBuilder->weld_widget("trans_border")) + , m_xCtlBitmapPreview(new weld::CustomWeld(*m_xBuilder, "CTL_BITMAP_PREVIEW", m_aCtlBitmapPreview)) + , m_xCtlXRectPreview(new weld::CustomWeld(*m_xBuilder, "CTL_TRANS_PREVIEW", m_aCtlXRectPreview)) { - get(m_pRbtTransOff,"RBT_TRANS_OFF"); - get(m_pRbtTransLinear,"RBT_TRANS_LINEAR"); - get(m_pRbtTransGradient,"RBT_TRANS_GRADIENT"); - - get(m_pMtrTransparent,"MTR_TRANSPARENT"); - - get(m_pGridGradient,"gridGradient"); - get(m_pLbTrgrGradientType,"LB_TRGR_GRADIENT_TYPES"); - get(m_pFtTrgrCenterX,"FT_TRGR_CENTER_X"); - get(m_pMtrTrgrCenterX,"MTR_TRGR_CENTER_X"); - get(m_pFtTrgrCenterY,"FT_TRGR_CENTER_Y"); - get(m_pMtrTrgrCenterY,"MTR_TRGR_CENTER_Y"); - get(m_pFtTrgrAngle,"FT_TRGR_ANGLE"); - get(m_pMtrTrgrAngle,"MTR_TRGR_ANGLE"); - get(m_pMtrTrgrBorder,"MTR_TRGR_BORDER"); - get(m_pMtrTrgrStartValue,"MTR_TRGR_START_VALUE"); - get(m_pMtrTrgrEndValue,"MTR_TRGR_END_VALUE"); - - get(m_pCtlBitmapPreview,"CTL_BITMAP_PREVIEW"); - get(m_pCtlXRectPreview,"CTL_TRANS_PREVIEW"); - // main selection - m_pRbtTransOff->SetClickHdl(LINK(this, SvxTransparenceTabPage, ClickTransOffHdl_Impl)); - m_pRbtTransLinear->SetClickHdl(LINK(this, SvxTransparenceTabPage, ClickTransLinearHdl_Impl)); - m_pRbtTransGradient->SetClickHdl(LINK(this, SvxTransparenceTabPage, ClickTransGradientHdl_Impl)); + m_xRbtTransOff->connect_toggled(LINK(this, SvxTransparenceTabPage, ClickTransOffHdl_Impl)); + m_xRbtTransLinear->connect_toggled(LINK(this, SvxTransparenceTabPage, ClickTransLinearHdl_Impl)); + m_xRbtTransGradient->connect_toggled(LINK(this, SvxTransparenceTabPage, ClickTransGradientHdl_Impl)); // linear transparency - m_pMtrTransparent->SetValue( 50 ); - m_pMtrTransparent->SetModifyHdl(LINK(this, SvxTransparenceTabPage, ModifyTransparentHdl_Impl)); + m_xMtrTransparent->set_value(50, FUNIT_PERCENT); + m_xMtrTransparent->connect_value_changed(LINK(this, SvxTransparenceTabPage, ModifyTransparentHdl_Impl)); // gradient transparency - m_pMtrTrgrEndValue->SetValue( 100 ); - m_pMtrTrgrStartValue->SetValue( 0 ); - Link<Edit&,void> aLink = LINK( this, SvxTransparenceTabPage, ModifiedTrgrEditHdl_Impl); - m_pLbTrgrGradientType->SetSelectHdl( LINK( this, SvxTransparenceTabPage, ModifiedTrgrListBoxHdl_Impl) ); - m_pMtrTrgrCenterX->SetModifyHdl( aLink ); - m_pMtrTrgrCenterY->SetModifyHdl( aLink ); - m_pMtrTrgrAngle->SetModifyHdl( aLink ); - m_pMtrTrgrBorder->SetModifyHdl( aLink ); - m_pMtrTrgrStartValue->SetModifyHdl( aLink ); - m_pMtrTrgrEndValue->SetModifyHdl( aLink ); + m_xMtrTrgrEndValue->set_value(100, FUNIT_PERCENT); + m_xMtrTrgrStartValue->set_value(0, FUNIT_PERCENT); + Link<weld::MetricSpinButton&,void> aLink = LINK( this, SvxTransparenceTabPage, ModifiedTrgrEditHdl_Impl); + m_xLbTrgrGradientType->connect_changed(LINK(this, SvxTransparenceTabPage, ModifiedTrgrListBoxHdl_Impl)); + m_xMtrTrgrCenterX->connect_value_changed( aLink ); + m_xMtrTrgrCenterY->connect_value_changed( aLink ); + m_xMtrTrgrAngle->connect_value_changed( aLink ); + m_xMtrTrgrBorder->connect_value_changed( aLink ); + m_xMtrTrgrStartValue->connect_value_changed( aLink ); + m_xMtrTrgrEndValue->connect_value_changed( aLink ); // this page needs ExchangeSupport SetExchangeSupport(); } -VclPtr<SfxTabPage> SvxTransparenceTabPage::Create(TabPageParent pWindow, const SfxItemSet* rAttrs) +VclPtr<SfxTabPage> SvxTransparenceTabPage::Create(TabPageParent pParent, const SfxItemSet* rAttrs) { - return VclPtr<SvxTransparenceTabPage>::Create(pWindow.pParent, *rAttrs); + return VclPtr<SvxTransparenceTabPage>::Create(pParent, *rAttrs); } bool SvxTransparenceTabPage::FillItemSet(SfxItemSet* rAttrs) @@ -310,11 +282,11 @@ bool SvxTransparenceTabPage::FillItemSet(SfxItemSet* rAttrs) bool bSwitchOffLinear(false); bool bSwitchOffGradient(false); - if(m_pMtrTransparent->IsEnabled()) + if (m_xMtrTransparent->get_sensitive()) { // linear transparence - sal_uInt16 nPos = static_cast<sal_uInt16>(m_pMtrTransparent->GetValue()); - if(m_pMtrTransparent->IsValueChangedFromSaved() || !bLinearActive) + sal_uInt16 nPos = m_xMtrTransparent->get_value(FUNIT_PERCENT); + if (m_xMtrTransparent->get_value_changed_from_saved() || !bLinearActive) { XFillTransparenceItem aItem(nPos); SdrPercentItem aShadowItem(makeSdrShadowTransparenceItem(nPos)); @@ -328,28 +300,28 @@ bool SvxTransparenceTabPage::FillItemSet(SfxItemSet* rAttrs) } } } - else if(m_pLbTrgrGradientType->IsEnabled()) + else if (m_xLbTrgrGradientType->get_active()) { // transparence gradient, fill ItemSet from values - if(!bGradActive - || m_pLbTrgrGradientType->IsValueChangedFromSaved() - || m_pMtrTrgrAngle->IsValueChangedFromSaved() - || m_pMtrTrgrCenterX->IsValueChangedFromSaved() - || m_pMtrTrgrCenterY->IsValueChangedFromSaved() - || m_pMtrTrgrBorder->IsValueChangedFromSaved() - || m_pMtrTrgrStartValue->IsValueChangedFromSaved() - || m_pMtrTrgrEndValue->IsValueChangedFromSaved() ) + if (!bGradActive + || m_xLbTrgrGradientType->get_value_changed_from_saved() + || m_xMtrTrgrAngle->get_value_changed_from_saved() + || m_xMtrTrgrCenterX->get_value_changed_from_saved() + || m_xMtrTrgrCenterY->get_value_changed_from_saved() + || m_xMtrTrgrBorder->get_value_changed_from_saved() + || m_xMtrTrgrStartValue->get_value_changed_from_saved() + || m_xMtrTrgrEndValue->get_value_changed_from_saved()) { - sal_uInt8 nStartCol = static_cast<sal_uInt8>((static_cast<sal_uInt16>(m_pMtrTrgrStartValue->GetValue()) * 255) / 100); - sal_uInt8 nEndCol = static_cast<sal_uInt8>((static_cast<sal_uInt16>(m_pMtrTrgrEndValue->GetValue()) * 255) / 100); + sal_uInt8 nStartCol = static_cast<sal_uInt8>((static_cast<sal_uInt16>(m_xMtrTrgrStartValue->get_value(FUNIT_PERCENT)) * 255) / 100); + sal_uInt8 nEndCol = static_cast<sal_uInt8>((static_cast<sal_uInt16>(m_xMtrTrgrEndValue->get_value(FUNIT_PERCENT)) * 255) / 100); XGradient aTmpGradient( Color(nStartCol, nStartCol, nStartCol), Color(nEndCol, nEndCol, nEndCol), - static_cast<css::awt::GradientStyle>(m_pLbTrgrGradientType->GetSelectedEntryPos()), - static_cast<sal_uInt16>(m_pMtrTrgrAngle->GetValue()) * 10, - static_cast<sal_uInt16>(m_pMtrTrgrCenterX->GetValue()), - static_cast<sal_uInt16>(m_pMtrTrgrCenterY->GetValue()), - static_cast<sal_uInt16>(m_pMtrTrgrBorder->GetValue()), + static_cast<css::awt::GradientStyle>(m_xLbTrgrGradientType->get_active()), + static_cast<sal_uInt16>(m_xMtrTrgrAngle->get_value(FUNIT_DEGREE)) * 10, + static_cast<sal_uInt16>(m_xMtrTrgrCenterX->get_value(FUNIT_PERCENT)), + static_cast<sal_uInt16>(m_xMtrTrgrCenterY->get_value(FUNIT_PERCENT)), + static_cast<sal_uInt16>(m_xMtrTrgrBorder->get_value(FUNIT_PERCENT)), 100, 100); XFillFloatTransparenceItem aItem(aTmpGradient); @@ -412,37 +384,37 @@ void SvxTransparenceTabPage::Reset(const SfxItemSet* rAttrs) // transparence gradient const XGradient& rGradient = static_cast<const XFillFloatTransparenceItem*>(pGradientItem)->GetGradientValue(); css::awt::GradientStyle eXGS(rGradient.GetGradientStyle()); - m_pLbTrgrGradientType->SelectEntryPos(sal::static_int_cast< sal_Int32 >(eXGS)); - m_pMtrTrgrAngle->SetValue(rGradient.GetAngle() / 10); - m_pMtrTrgrBorder->SetValue(rGradient.GetBorder()); - m_pMtrTrgrCenterX->SetValue(rGradient.GetXOffset()); - m_pMtrTrgrCenterY->SetValue(rGradient.GetYOffset()); - m_pMtrTrgrStartValue->SetValue(static_cast<sal_uInt16>(((static_cast<sal_uInt16>(rGradient.GetStartColor().GetRed()) + 1) * 100) / 255)); - m_pMtrTrgrEndValue->SetValue(static_cast<sal_uInt16>(((static_cast<sal_uInt16>(rGradient.GetEndColor().GetRed()) + 1) * 100) / 255)); + m_xLbTrgrGradientType->set_active(sal::static_int_cast< sal_Int32 >(eXGS)); + m_xMtrTrgrAngle->set_value(rGradient.GetAngle() / 10, FUNIT_DEGREE); + m_xMtrTrgrBorder->set_value(rGradient.GetBorder(), FUNIT_PERCENT); + m_xMtrTrgrCenterX->set_value(rGradient.GetXOffset(), FUNIT_PERCENT); + m_xMtrTrgrCenterY->set_value(rGradient.GetYOffset(), FUNIT_PERCENT); + m_xMtrTrgrStartValue->set_value(static_cast<sal_uInt16>(((static_cast<sal_uInt16>(rGradient.GetStartColor().GetRed()) + 1) * 100) / 255), FUNIT_PERCENT); + m_xMtrTrgrEndValue->set_value(static_cast<sal_uInt16>(((static_cast<sal_uInt16>(rGradient.GetEndColor().GetRed()) + 1) * 100) / 255), FUNIT_PERCENT); // linear transparence sal_uInt16 nTransp = static_cast<const XFillTransparenceItem*>(pLinearItem)->GetValue(); - m_pMtrTransparent->SetValue(bLinearActive ? nTransp : 50); - ModifyTransparentHdl_Impl(*m_pMtrTransparent); + m_xMtrTransparent->set_value(bLinearActive ? nTransp : 50, FUNIT_PERCENT); + ModifyTransparentHdl_Impl(*m_xMtrTransparent); // select the correct radio button if(bGradActive) { // transparence gradient, set controls appropriate to item - m_pRbtTransGradient->Check(); - ClickTransGradientHdl_Impl(nullptr); + m_xRbtTransGradient->set_active(true); + ClickTransGradientHdl_Impl(*m_xRbtTransGradient); } else if(bLinearActive) { // linear transparence - m_pRbtTransLinear->Check(); - ClickTransLinearHdl_Impl(nullptr); + m_xRbtTransLinear->set_active(true); + ClickTransLinearHdl_Impl(*m_xRbtTransLinear); } else { // no transparence - m_pRbtTransOff->Check(); - ClickTransOffHdl_Impl(nullptr); + m_xRbtTransOff->set_active(true); + ClickTransOffHdl_Impl(*m_xRbtTransOff); ModifiedTrgrHdl_Impl(nullptr); } @@ -454,14 +426,14 @@ void SvxTransparenceTabPage::Reset(const SfxItemSet* rAttrs) void SvxTransparenceTabPage::ChangesApplied() { - m_pMtrTransparent->SaveValue(); - m_pLbTrgrGradientType->SaveValue(); - m_pMtrTrgrCenterX->SaveValue(); - m_pMtrTrgrCenterY->SaveValue(); - m_pMtrTrgrAngle->SaveValue(); - m_pMtrTrgrBorder->SaveValue(); - m_pMtrTrgrStartValue->SaveValue(); - m_pMtrTrgrEndValue->SaveValue(); + m_xMtrTransparent->save_value(); + m_xLbTrgrGradientType->save_value(); + m_xMtrTrgrCenterX->save_value(); + m_xMtrTrgrCenterY->save_value(); + m_xMtrTrgrAngle->save_value(); + m_xMtrTrgrBorder->save_value(); + m_xMtrTrgrStartValue->save_value(); + m_xMtrTrgrEndValue->save_value(); } void SvxTransparenceTabPage::ActivatePage(const SfxItemSet& rSet) @@ -493,18 +465,20 @@ void SvxTransparenceTabPage::PointChanged(weld::DrawingArea*, RectPoint) // Preview-Methods -bool SvxTransparenceTabPage::InitPreview ( const SfxItemSet& rSet ) +bool SvxTransparenceTabPage::InitPreview(const SfxItemSet& rSet) { // set transparencetype for preview - if ( m_pRbtTransOff->IsChecked() ) + if (m_xRbtTransOff->get_active()) { - ClickTransOffHdl_Impl(nullptr); - } else if ( m_pRbtTransLinear->IsChecked() ) + ClickTransOffHdl_Impl(*m_xRbtTransOff); + } + else if (m_xRbtTransLinear->get_active()) { - ClickTransLinearHdl_Impl(nullptr); - } else if ( m_pRbtTransGradient->IsChecked() ) + ClickTransLinearHdl_Impl(*m_xRbtTransLinear); + } + else if (m_xRbtTransGradient->get_active()) { - ClickTransGradientHdl_Impl(nullptr); + ClickTransGradientHdl_Impl(*m_xRbtTransGradient); } // Get fillstyle for preview @@ -515,24 +489,24 @@ bool SvxTransparenceTabPage::InitPreview ( const SfxItemSet& rSet ) rXFSet.Put ( rSet.Get(XATTR_FILLBACKGROUND) ); rXFSet.Put ( rSet.Get(XATTR_FILLBITMAP) ); - m_pCtlXRectPreview->SetAttributes( aXFillAttr.GetItemSet() ); - m_pCtlBitmapPreview->SetAttributes( aXFillAttr.GetItemSet() ); + m_aCtlXRectPreview.SetAttributes( aXFillAttr.GetItemSet() ); + m_aCtlBitmapPreview.SetAttributes( aXFillAttr.GetItemSet() ); bBitmap = rSet.Get(XATTR_FILLSTYLE).GetValue() == drawing::FillStyle_BITMAP; // show the right preview window if ( bBitmap ) { - m_pCtlBitmapPreview->Show(); - m_pCtlXRectPreview->Hide(); + m_xCtlBitmapBorder->show(); + m_xCtlXRectBorder->hide(); } else { - m_pCtlBitmapPreview->Hide(); - m_pCtlXRectPreview->Show(); + m_xCtlBitmapBorder->hide(); + m_xCtlXRectBorder->show(); } - return !m_pRbtTransOff->IsChecked(); + return !m_xRbtTransOff->get_active(); } void SvxTransparenceTabPage::InvalidatePreview (bool bEnable) @@ -541,23 +515,23 @@ void SvxTransparenceTabPage::InvalidatePreview (bool bEnable) { if ( bEnable ) { - m_pCtlBitmapPreview->Enable(); - m_pCtlBitmapPreview->SetAttributes( aXFillAttr.GetItemSet() ); + m_xCtlBitmapPreview->set_sensitive(true); + m_aCtlBitmapPreview.SetAttributes( aXFillAttr.GetItemSet() ); } else - m_pCtlBitmapPreview->Disable(); - m_pCtlBitmapPreview->Invalidate(); + m_xCtlBitmapPreview->set_sensitive(false); + m_xCtlBitmapPreview->queue_draw(); } else { if ( bEnable ) { - m_pCtlXRectPreview->Enable(); - m_pCtlXRectPreview->SetAttributes( aXFillAttr.GetItemSet() ); + m_xCtlXRectPreview->set_sensitive(true); + m_aCtlXRectPreview.SetAttributes( aXFillAttr.GetItemSet() ); } else - m_pCtlXRectPreview->Disable(); - m_pCtlXRectPreview->Invalidate(); + m_xCtlXRectPreview->set_sensitive(false); + m_xCtlXRectPreview->queue_draw(); } } |