diff options
-rw-r--r-- | chart2/uiconfig/accelerator/en-US/default.xml | 1 | ||||
-rw-r--r-- | compilerplugins/clang/singlevalfields.results | 3 | ||||
-rw-r--r-- | compilerplugins/clang/unusedenumconstants.writeonly.results | 2 | ||||
-rw-r--r-- | compilerplugins/clang/unusedfields.writeonly.results | 2 | ||||
-rw-r--r-- | include/svx/svdpntv.hxx | 14 | ||||
-rw-r--r-- | include/svx/svxids.hrc | 2 | ||||
-rw-r--r-- | officecfg/registry/data/org/openoffice/Office/Accelerators.xcu | 18 | ||||
-rw-r--r-- | officecfg/registry/data/org/openoffice/Office/UI/GenericCommands.xcu | 5 | ||||
-rw-r--r-- | sd/sdi/_drvwsh.sdi | 5 | ||||
-rw-r--r-- | sd/source/ui/view/drviewse.cxx | 9 | ||||
-rw-r--r-- | solenv/clang-format/blacklist | 2 | ||||
-rw-r--r-- | svx/Library_svxcore.mk | 1 | ||||
-rw-r--r-- | svx/inc/pch/precompiled_svx.hxx | 5 | ||||
-rw-r--r-- | svx/inc/pch/precompiled_svxcore.hxx | 3 | ||||
-rw-r--r-- | svx/inc/svdibrow.hxx | 119 | ||||
-rw-r--r-- | svx/sdi/svx.sdi | 19 | ||||
-rw-r--r-- | svx/source/svdraw/svdedxv.cxx | 39 | ||||
-rw-r--r-- | svx/source/svdraw/svdibrow.cxx | 1233 | ||||
-rw-r--r-- | svx/source/svdraw/svdmrkv.cxx | 7 | ||||
-rw-r--r-- | svx/source/svdraw/svdpntv.cxx | 57 | ||||
-rw-r--r-- | svx/source/svdraw/svdview.cxx | 10 |
21 files changed, 6 insertions, 1550 deletions
diff --git a/chart2/uiconfig/accelerator/en-US/default.xml b/chart2/uiconfig/accelerator/en-US/default.xml index 4738a7fedd40..3965f4b8f34a 100644 --- a/chart2/uiconfig/accelerator/en-US/default.xml +++ b/chart2/uiconfig/accelerator/en-US/default.xml @@ -42,6 +42,5 @@ <accel:item accel:code="KEY_INSERT" accel:shift="true" xlink:href=".uno:Paste"/> <accel:item accel:code="KEY_PASTE" xlink:href=".uno:Paste"/> <accel:item accel:code="KEY_DELETE" xlink:href=".uno:Delete"/> - <accel:item accel:code="KEY_9" accel:shift="true" accel:mod1="true" accel:mod2="true" xlink:href=".uno:ShowItemBrowser"/> <accel:item accel:code="KEY_F4" xlink:href=".uno:TransformDialog"/> </accel:acceleratorlist> diff --git a/compilerplugins/clang/singlevalfields.results b/compilerplugins/clang/singlevalfields.results index b4c26ff6d892..b91b0ec48b61 100644 --- a/compilerplugins/clang/singlevalfields.results +++ b/compilerplugins/clang/singlevalfields.results @@ -700,9 +700,6 @@ svl/source/crypto/cryptosign.cxx:153 svx/inc/sdr/overlay/overlaymanagerbuffered.hxx:44 sdr::overlay::OverlayManagerBuffered maBufferIdle sdr overlay OverlayManagerBuffered Idle -svx/inc/svdibrow.hxx:96 - SdrItemBrowser aIdle - svx svdraw SdrItemBrowser svx/source/dialog/contimp.hxx:70 SvxSuperContourDlg aUpdateIdle SvxSuperContourDlg UpdateIdle diff --git a/compilerplugins/clang/unusedenumconstants.writeonly.results b/compilerplugins/clang/unusedenumconstants.writeonly.results index ea5bca51c086..ff3da7eee610 100644 --- a/compilerplugins/clang/unusedenumconstants.writeonly.results +++ b/compilerplugins/clang/unusedenumconstants.writeonly.results @@ -9564,8 +9564,6 @@ svx/source/stbctrls/modctrl.cxx:48 enum SvxModifyControl::ImplData::ModificationState MODIFICATION_STATE_FEEDBACK svx/source/stbctrls/modctrl.cxx:49 enum SvxModifyControl::ImplData::ModificationState MODIFICATION_STATE_SIZE -svx/source/svdraw/svdibrow.cxx:78 - enum ItemType DONTKNOW svx/source/svdraw/svdocapt.cxx:67 enum EscDir UNT svx/source/table/tablehandles.hxx:30 diff --git a/compilerplugins/clang/unusedfields.writeonly.results b/compilerplugins/clang/unusedfields.writeonly.results index ba5c6c1049a6..feafdf7bbe6c 100644 --- a/compilerplugins/clang/unusedfields.writeonly.results +++ b/compilerplugins/clang/unusedfields.writeonly.results @@ -772,8 +772,6 @@ svx/source/sidebar/line/LinePropertyPanel.hxx:104 svx::sidebar::LinePropertyPanel maEdgeStyle sfx2::sidebar::ControllerItem svx/source/sidebar/line/LinePropertyPanel.hxx:105 svx::sidebar::LinePropertyPanel maCapStyle sfx2::sidebar::ControllerItem -svx/source/svdraw/svdibrow.cxx:98 - ImpItemListRow pType const std::type_info * svx/source/svdraw/svdpdf.hxx:196 ImpSdrPdfImport mdPageWidthPts double svx/source/tbxctrls/tbcontrl.cxx:199 diff --git a/include/svx/svdpntv.hxx b/include/svx/svdpntv.hxx index c1614cf8e738..903475cc343b 100644 --- a/include/svx/svdpntv.hxx +++ b/include/svx/svdpntv.hxx @@ -53,10 +53,6 @@ class SdrModel; class SdrObject; enum class GraphicManagerDrawFlags; -#ifdef DBG_UTIL -class SdrItemBrowser; -#endif - namespace sdr { namespace contact { class ViewObjectContactRedirector; }} @@ -134,9 +130,6 @@ private: std::unique_ptr<SdrPageView> mpPageView; protected: SdrModel* mpModel; -#ifdef DBG_UTIL - VclPtr<SdrItemBrowser> mpItemBrowser; -#endif VclPtr<OutputDevice> mpActualOutDev; // Only for comparison VclPtr<OutputDevice> mpDragWin; SfxStyleSheet* mpDefaultStyleSheet; @@ -496,13 +489,6 @@ public: /// 3. SdrAnimationMode::Disable: don't start and don't show any replacement void SetAnimationMode( const SdrAnimationMode eMode ); - /// The Browser is destroyed for bShow=false -#ifdef DBG_UTIL - void ShowItemBrowser(bool bShow); - bool IsItemBrowserVisible() const { return mpItemBrowser!=nullptr && GetItemBrowser()->IsVisible(); } - vcl::Window* GetItemBrowser() const; -#endif - /// Must be called by the App when scrolling etc. in order for /// an active FormControl to be moved too void VisAreaChanged(const OutputDevice* pOut); diff --git a/include/svx/svxids.hrc b/include/svx/svxids.hrc index 2842dcf5a77f..8d4b16389b5d 100644 --- a/include/svx/svxids.hrc +++ b/include/svx/svxids.hrc @@ -790,7 +790,7 @@ class SvxSetItem; #define SID_ATTR_TRANSFORM_HORI_POSITION ( SID_SVX_START + 999 ) #define SID_ATTR_TRANSFORM_VERT_POSITION ( SID_SVX_START + 1000 ) -#define SID_SHOW_ITEMBROWSER ( SID_SVX_START + 1001 ) +// Available for use 1001 #define SID_ALIGN_ANY_LEFT ( SID_SVX_START + 1002 ) #define SID_ALIGN_ANY_HCENTER ( SID_SVX_START + 1003 ) #define SID_ALIGN_ANY_RIGHT ( SID_SVX_START + 1004 ) diff --git a/officecfg/registry/data/org/openoffice/Office/Accelerators.xcu b/officecfg/registry/data/org/openoffice/Office/Accelerators.xcu index 3139f766b20b..b763a1b08402 100644 --- a/officecfg/registry/data/org/openoffice/Office/Accelerators.xcu +++ b/officecfg/registry/data/org/openoffice/Office/Accelerators.xcu @@ -1392,12 +1392,6 @@ Ctrl+Shift+e aka E_SHIFT_MOD1 under GTK/IBUS is for some emoji thing </node> </node> <node oor:name="com.sun.star.chart2.ChartDocument" oor:op="replace"> - <node oor:name="9_SHIFT_MOD1_MOD2" oor:op="replace"> - <prop oor:name="Command"> - <value xml:lang="x-no-translate">I10N SHORTCUTS - NO TRANSLATE</value> - <value xml:lang="en-US">.uno:ShowItemBrowser</value> - </prop> - </node> <node oor:name="C_MOD1" oor:op="replace"> <prop oor:name="Command"> <value xml:lang="x-no-translate">I10N SHORTCUTS - NO TRANSLATE</value> @@ -1540,12 +1534,6 @@ Ctrl+Shift+e aka E_SHIFT_MOD1 under GTK/IBUS is for some emoji thing <value xml:lang="de">.uno:Grow</value> </prop> </node> - <node oor:name="9_SHIFT_MOD1_MOD2" oor:op="replace"> - <prop oor:name="Command"> - <value xml:lang="x-no-translate">I10N SHORTCUTS - NO TRANSLATE</value> - <value xml:lang="en-US">.uno:ShowItemBrowser</value> - </prop> - </node> <node oor:name="ADD_MOD1" oor:op="replace"> <prop oor:name="Command"> <value xml:lang="x-no-translate">I10N SHORTCUTS - NO TRANSLATE</value> @@ -2827,12 +2815,6 @@ Ctrl+Shift+e aka E_SHIFT_MOD1 under GTK/IBUS is for some emoji thing <value xml:lang="de">.uno:Grow</value> </prop> </node> - <node oor:name="9_SHIFT_MOD1_MOD2" oor:op="replace"> - <prop oor:name="Command"> - <value xml:lang="x-no-translate">I10N SHORTCUTS - NO TRANSLATE</value> - <value xml:lang="en-US">.uno:ShowItemBrowser</value> - </prop> - </node> <node oor:name="ADD_MOD1" oor:op="replace"> <prop oor:name="Command"> <value xml:lang="x-no-translate">I10N SHORTCUTS - NO TRANSLATE</value> diff --git a/officecfg/registry/data/org/openoffice/Office/UI/GenericCommands.xcu b/officecfg/registry/data/org/openoffice/Office/UI/GenericCommands.xcu index 08ff909b5db5..c09dda21d69a 100644 --- a/officecfg/registry/data/org/openoffice/Office/UI/GenericCommands.xcu +++ b/officecfg/registry/data/org/openoffice/Office/UI/GenericCommands.xcu @@ -5765,11 +5765,6 @@ <value xml:lang="en-US">Current Date</value> </prop> </node> - <node oor:name=".uno:ShowItemBrowser" oor:op="replace"> - <prop oor:name="Label" oor:type="xs:string"> - <value xml:lang="en-US">Item Browser On/Off</value> - </prop> - </node> <node oor:name=".uno:DateField" oor:op="replace"> <prop oor:name="Label" oor:type="xs:string"> <value xml:lang="en-US">Date Field</value> diff --git a/sd/sdi/_drvwsh.sdi b/sd/sdi/_drvwsh.sdi index dd64ae35cd4e..5d99ed09b16b 100644 --- a/sd/sdi/_drvwsh.sdi +++ b/sd/sdi/_drvwsh.sdi @@ -2091,11 +2091,6 @@ interface DrawView ExecMethod = FuTemporary ; StateMethod = GetMenuState ; ] - SID_SHOW_ITEMBROWSER // ole : no, status : play rec - [ - ExecMethod = FuSupport ; - StateMethod = GetMenuState ; - ] SID_AUTOSPELL_CHECK // ole : no, status : play rec [ ExecMethod = FuSupport ; diff --git a/sd/source/ui/view/drviewse.cxx b/sd/source/ui/view/drviewse.cxx index 45d5e1bc2a43..97592f5c6a69 100644 --- a/sd/source/ui/view/drviewse.cxx +++ b/sd/source/ui/view/drviewse.cxx @@ -1339,15 +1339,6 @@ void DrawViewShell::FuSupport(SfxRequest& rReq) } break; -#ifdef DBG_UTIL - case SID_SHOW_ITEMBROWSER: - { - mpDrawView->ShowItemBrowser( !mpDrawView->IsItemBrowserVisible() ); - rReq.Done (); - } - break; -#endif - case SID_AUTOSPELL_CHECK: { bool bOnlineSpell = !GetDoc()->GetOnlineSpell(); diff --git a/solenv/clang-format/blacklist b/solenv/clang-format/blacklist index 4b4124a74ae5..e3e20aac6a2d 100644 --- a/solenv/clang-format/blacklist +++ b/solenv/clang-format/blacklist @@ -13856,7 +13856,6 @@ svx/inc/sdr/properties/pageproperties.hxx svx/inc/sdr/properties/rectangleproperties.hxx svx/inc/sdr/properties/textproperties.hxx svx/inc/strings.hxx -svx/inc/svdibrow.hxx svx/inc/sxallitm.hxx svx/inc/sxcikitm.hxx svx/inc/sxlayitm.hxx @@ -14367,7 +14366,6 @@ svx/source/svdraw/svdglev.cxx svx/source/svdraw/svdglue.cxx svx/source/svdraw/svdhdl.cxx svx/source/svdraw/svdhlpln.cxx -svx/source/svdraw/svdibrow.cxx svx/source/svdraw/svditer.cxx svx/source/svdraw/svdlayer.cxx svx/source/svdraw/svdmark.cxx diff --git a/svx/Library_svxcore.mk b/svx/Library_svxcore.mk index fe2a7469bfe5..71e670d20570 100644 --- a/svx/Library_svxcore.mk +++ b/svx/Library_svxcore.mk @@ -301,7 +301,6 @@ $(eval $(call gb_Library_add_exception_objects,svxcore,\ svx/source/svdraw/svdglue \ svx/source/svdraw/svdhdl \ svx/source/svdraw/svdhlpln \ - svx/source/svdraw/svdibrow \ svx/source/svdraw/svditer \ svx/source/svdraw/svdlayer \ svx/source/svdraw/svdmark \ diff --git a/svx/inc/pch/precompiled_svx.hxx b/svx/inc/pch/precompiled_svx.hxx index 77bbf9031b2a..a1025a3dde90 100644 --- a/svx/inc/pch/precompiled_svx.hxx +++ b/svx/inc/pch/precompiled_svx.hxx @@ -13,7 +13,7 @@ manual changes will be rewritten by the next run of update_pch.sh (which presumably also fixes all possible problems, so it's usually better to use it). - Generated on 2019-12-03 09:22:33 using: + Generated on 2019-12-03 09:41:31 using: ./bin/update_pch svx svx --cutoff=3 --exclude:system --exclude:module --include:local If after updating build fails, use the following command to locate conflicting headers: @@ -61,8 +61,11 @@ #include <rtl/instance.hxx> #include <rtl/math.hxx> #include <rtl/ref.hxx> +#include <rtl/strbuf.h> #include <rtl/string.h> #include <rtl/string.hxx> +#include <rtl/stringconcat.hxx> +#include <rtl/stringutils.hxx> #include <rtl/tencinfo.h> #include <rtl/textenc.h> #include <rtl/uri.hxx> diff --git a/svx/inc/pch/precompiled_svxcore.hxx b/svx/inc/pch/precompiled_svxcore.hxx index 882b3267089d..35f4ea416ed7 100644 --- a/svx/inc/pch/precompiled_svxcore.hxx +++ b/svx/inc/pch/precompiled_svxcore.hxx @@ -13,7 +13,7 @@ manual changes will be rewritten by the next run of update_pch.sh (which presumably also fixes all possible problems, so it's usually better to use it). - Generated on 2019-12-03 09:23:12 using: + Generated on 2019-12-03 09:41:26 using: ./bin/update_pch svx svxcore --cutoff=7 --exclude:system --include:module --exclude:local If after updating build fails, use the following command to locate conflicting headers: @@ -62,7 +62,6 @@ #include <osl/interlck.h> #include <osl/mutex.hxx> #include <osl/process.h> -#include <osl/thread.h> #include <osl/time.h> #include <rtl/alloc.h> #include <rtl/character.hxx> diff --git a/svx/inc/svdibrow.hxx b/svx/inc/svdibrow.hxx deleted file mode 100644 index defb0e260df1..000000000000 --- a/svx/inc/svdibrow.hxx +++ /dev/null @@ -1,119 +0,0 @@ -/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ -/* - * This file is part of the LibreOffice project. - * - * This Source Code Form is subject to the terms of the Mozilla Public - * License, v. 2.0. If a copy of the MPL was not distributed with this - * file, You can obtain one at http://mozilla.org/MPL/2.0/. - * - * This file incorporates work covered by the following license notice: - * - * Licensed to the Apache Software Foundation (ASF) under one or more - * contributor license agreements. See the NOTICE file distributed - * with this work for additional information regarding copyright - * ownership. The ASF licenses this file to you under the Apache - * License, Version 2.0 (the "License"); you may not use this file - * except in compliance with the License. You may obtain a copy of - * the License at http://www.apache.org/licenses/LICENSE-2.0 . - */ - -#ifndef INCLUDED_SVX_INC_SVDIBROW_HXX -#define INCLUDED_SVX_INC_SVDIBROW_HXX - -#include <svtools/brwbox.hxx> -#include <vcl/edit.hxx> -#include <vcl/floatwin.hxx> -#include <vcl/idle.hxx> -#include <memory> - -class SfxItemSet; -class ImpItemListRow; -class BrowserMouseEvent; - -class SdrItemBrowserControl final : public BrowseBox -{ -friend class ImpItemEdit; - std::vector<std::unique_ptr<ImpItemListRow>> aList; - long nCurrentPaintRow; - VclPtr<Edit> pEditControl; - OUString aWNameMemorized; - Link<SdrItemBrowserControl&,void> aEntryChangedHdl; - Link<SdrItemBrowserControl&,void> aSetDirtyHdl; - std::unique_ptr<ImpItemListRow> pCurrentChangeEntry; - long nLastWhichOfs; - sal_uInt16 nLastWhich; - bool bWhichesButNames; - bool bDontHideIneffectiveItems; - bool bDontSortItems; - - void ImpCtor(); - void ImpSetEntry(const ImpItemListRow& rEntry, std::size_t nEntryNum); - void ImpSaveWhich(); - void ImpRestoreWhich(); - std::size_t GetCurrentPos() const; - bool BeginChangeEntry(std::size_t nPos); - - virtual long GetRowCount() const override; - virtual bool SeekRow(long nRow) override; - virtual void PaintField(vcl::RenderContext& rDev, const tools::Rectangle& rRect, sal_uInt16 nColumnId) const override; - virtual void DoubleClick(const BrowserMouseEvent&) override; - virtual void KeyInput(const KeyEvent& rEvt) override; - virtual void Select() override; - void SetDirty(); // is called for example in mode switches - virtual tools::Rectangle GetFieldCharacterBounds(sal_Int32 _nRow,sal_Int32 _nColumnPos,sal_Int32 nIndex) override; - virtual sal_Int32 GetFieldIndexAtPoint(sal_Int32 _nRow,sal_Int32 _nColumnPos,const Point& _rPoint) override; - -public: - SdrItemBrowserControl(vcl::Window* pParent); - virtual ~SdrItemBrowserControl() override; - virtual void dispose() override; - void Clear(); - void SetAttributes(const SfxItemSet* pAttr, const SfxItemSet* p2ndSet); - sal_uInt16 GetCurrentWhich() const; - void EndChangeEntry(); - void BreakChangeEntry(); - - /** GetCellText returns the text at the given position - @param _nRow - the number of the row - @param _nColId - the ID of the column - @return - the text out of the cell - */ - virtual OUString GetCellText(long _nRow, sal_uInt16 _nColId) const override; - - const ImpItemListRow* GetCurrentChangeEntry() const { return pCurrentChangeEntry.get(); } - OUString GetNewEntryValue() const { return pEditControl->GetText(); } - void SetEntryChangedHdl(const Link<SdrItemBrowserControl&,void>& rLink) { aEntryChangedHdl=rLink; } - void SetSetDirtyHdl(const Link<SdrItemBrowserControl&,void>& rLink) { aSetDirtyHdl=rLink; } -}; - -class SdrView; - -class SdrItemBrowser: public FloatingWindow { - VclPtr<SdrItemBrowserControl> aBrowse; - Idle aIdle; - SdrView* pView; - bool bDirty; - static vcl::Window* ImpGetViewWin(SdrView const & rView); - DECL_LINK(IdleHdl, Timer *, void); - DECL_LINK(ChangedHdl, SdrItemBrowserControl&, void); - DECL_LINK(SetDirtyHdl, SdrItemBrowserControl&, void); -public: - SdrItemBrowser(SdrView& rView); - virtual ~SdrItemBrowser() override; - void ForceParent(); - void SetDirty(); - void Undirty(); - virtual void dispose() override; - virtual void Resize() override; - virtual void GetFocus() override; - void SetAttributes(const SfxItemSet* pAttr, const SfxItemSet* p2ndSet) { aBrowse->SetAttributes(pAttr,p2ndSet); } - SdrItemBrowserControl *GetBrowserControl() { return aBrowse.get(); } -}; - -#endif // INCLUDED_SVX_INC_SVDIBROW_HXX - - -/* vim:set shiftwidth=4 softtabstop=4 expandtab: */ diff --git a/svx/sdi/svx.sdi b/svx/sdi/svx.sdi index d191813d3ca6..795d4df6f944 100644 --- a/svx/sdi/svx.sdi +++ b/svx/sdi/svx.sdi @@ -7744,25 +7744,6 @@ SfxBoolItem ShowFmExplorer SID_FM_SHOW_FMEXPLORER -SfxBoolItem ShowItemBrowser SID_SHOW_ITEMBROWSER - -[ - AutoUpdate = TRUE, - FastCall = FALSE, - ReadOnlyDoc = TRUE, - Toggle = FALSE, - Container = FALSE, - RecordAbsolute = FALSE, - RecordPerSet; - - - AccelConfig = TRUE, - MenuConfig = FALSE, - ToolBoxConfig = TRUE, - GroupId = SfxGroupId::View; -] - - SfxBoolItem ShowPropBrowser SID_SHOW_PROPERTYBROWSER [ diff --git a/svx/source/svdraw/svdedxv.cxx b/svx/source/svdraw/svdedxv.cxx index f6861bdadee6..2deae4c913cb 100644 --- a/svx/source/svdraw/svdedxv.cxx +++ b/svx/source/svdraw/svdedxv.cxx @@ -45,9 +45,6 @@ #include <vcl/cursor.hxx> #include <vcl/hatch.hxx> #include <vcl/weld.hxx> -#ifdef DBG_UTIL -#include <svdibrow.hxx> -#endif #include <comphelper/lok.hxx> #include <drawinglayer/processor2d/baseprocessor2d.hxx> #include <drawinglayer/processor2d/processor2dtools.hxx> @@ -1325,10 +1322,6 @@ bool SdrObjEditView::SdrBeginTextEdit(SdrObject* pObj_, SdrPageView* pPV, vcl::W LINK(this, SdrObjEditView, ImpAfterCutOrPasteChainingEventHdl)); } -#ifdef DBG_UTIL - if (mpItemBrowser != nullptr) - mpItemBrowser->SetDirty(); -#endif pTextEditOutliner->ClearModifyFlag(); if (pTextObj->IsFitToSize()) @@ -1641,13 +1634,6 @@ SdrEndTextEditKind SdrObjEditView::SdrEndTextEdit(bool bDontDeleteReally) { GetMarkedObjectListWriteAccess().SetNameDirty(); } -#ifdef DBG_UTIL - if (mpItemBrowser) - { - GetMarkedObjectListWriteAccess().SetNameDirty(); - mpItemBrowser->SetDirty(); - } -#endif } if (pTEObj && !pTEObj->getSdrModelFromSdrObject().isLocked() && pTEObj->GetBroadcaster()) @@ -1826,10 +1812,6 @@ bool SdrObjEditView::KeyInput(const KeyEvent& rKEvt, vcl::Window* pWin) if (pWin != nullptr && pWin != pTextEditWin) SetTextEditWin(pWin); -#ifdef DBG_UTIL - if (mpItemBrowser != nullptr) - mpItemBrowser->SetDirty(); -#endif ImpMakeTextCursorAreaVisible(); return true; } @@ -1873,10 +1855,6 @@ bool SdrObjEditView::MouseButtonDown(const MouseEvent& rMEvt, OutputDevice* pWin if (pWin != nullptr && pWin != pTextEditWin && pWin->GetOutDevType() == OUTDEV_WINDOW) SetTextEditWin(static_cast<vcl::Window*>(pWin)); -#ifdef DBG_UTIL - if (mpItemBrowser != nullptr) - mpItemBrowser->SetDirty(); -#endif ImpMakeTextCursorAreaVisible(); return true; } @@ -1915,10 +1893,6 @@ bool SdrObjEditView::MouseButtonUp(const MouseEvent& rMEvt, OutputDevice* pWin) rMEvt.GetModifier()); if (pTextEditOutlinerView->MouseButtonUp(aMEvt)) { -#ifdef DBG_UTIL - if (mpItemBrowser != nullptr) - mpItemBrowser->SetDirty(); -#endif ImpMakeTextCursorAreaVisible(); return true; } @@ -1962,10 +1936,6 @@ bool SdrObjEditView::MouseMove(const MouseEvent& rMEvt, OutputDevice* pWin) rMEvt.GetModifier()); if (pTextEditOutlinerView->MouseMove(aMEvt) && bSelMode) { -#ifdef DBG_UTIL - if (mpItemBrowser != nullptr) - mpItemBrowser->SetDirty(); -#endif ImpMakeTextCursorAreaVisible(); return true; } @@ -2011,10 +1981,6 @@ bool SdrObjEditView::Command(const CommandEvent& rCEvt, vcl::Window* pWin) pTextEditOutlinerView->Command(aCEvt); if (pWin != nullptr && pWin != pTextEditWin) SetTextEditWin(pWin); -#ifdef DBG_UTIL - if (mpItemBrowser != nullptr) - mpItemBrowser->SetDirty(); -#endif ImpMakeTextCursorAreaVisible(); return true; } @@ -2287,11 +2253,6 @@ bool SdrObjEditView::SetAttributes(const SfxItemSet& rSet, bool bReplaceAll) if (mpModel && pTEOutliner && pTEOutliner->IsModified()) mpModel->SetChanged(); -#ifdef DBG_UTIL - if (mpItemBrowser != nullptr) - mpItemBrowser->SetDirty(); -#endif - ImpMakeTextCursorAreaVisible(); } bRet = true; diff --git a/svx/source/svdraw/svdibrow.cxx b/svx/source/svdraw/svdibrow.cxx deleted file mode 100644 index a08d358530a5..000000000000 --- a/svx/source/svdraw/svdibrow.cxx +++ /dev/null @@ -1,1233 +0,0 @@ -/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ -/* - * This file is part of the LibreOffice project. - * - * This Source Code Form is subject to the terms of the Mozilla Public - * License, v. 2.0. If a copy of the MPL was not distributed with this - * file, You can obtain one at http://mozilla.org/MPL/2.0/. - * - * This file incorporates work covered by the following license notice: - * - * Licensed to the Apache Software Foundation (ASF) under one or more - * contributor license agreements. See the NOTICE file distributed - * with this work for additional information regarding copyright - * ownership. The ASF licenses this file to you under the Apache - * License, Version 2.0 (the "License"); you may not use this file - * except in compliance with the License. You may obtain a copy of - * the License at http://www.apache.org/licenses/LICENSE-2.0 . - */ - -#include <stdlib.h> -#include <limits> - -#include <editeng/fontitem.hxx> -#include <svdibrow.hxx> -#include <editeng/charscaleitem.hxx> -#include <editeng/colritem.hxx> -#include <editeng/editdata.hxx> -#include <editeng/eeitem.hxx> -#include <editeng/fhgtitem.hxx> -#include <editeng/flditem.hxx> -#include <svl/flagitem.hxx> -#include <svl/ptitem.hxx> -#include <svl/rectitem.hxx> -#include <svl/rngitem.hxx> -#include <svl/whiter.hxx> -#include <sal/log.hxx> - -#include <svx/sdrpaintwindow.hxx> -#include <svx/sdooitm.hxx> -#include <svx/sdtaaitm.hxx> -#include <svx/sdtacitm.hxx> -#include <svx/sdtaiitm.hxx> -#include <svx/sdtayitm.hxx> -#include <svx/sdtfsitm.hxx> -#include <svx/xcolit.hxx> -#include <svx/svdpool.hxx> -#include <svx/svdview.hxx> -#include <svx/sxcaitm.hxx> -#include <svx/sxcecitm.hxx> -#include <sxcikitm.hxx> -#include <svx/sxcllitm.hxx> -#include <svx/sxekitm.hxx> -#include <svx/sxelditm.hxx> -#include <svx/sxfiitm.hxx> -#include <svx/xenum.hxx> -#include <svx/xfillit0.hxx> -#include <svx/xflbmtit.hxx> -#include <svx/xflbstit.hxx> -#include <svx/xflbtoxy.hxx> -#include <svx/xftshit.hxx> -#include <svx/xlineit0.hxx> -#include <svx/xlnedwit.hxx> -#include <svx/xlnstwit.hxx> -#include <svx/xtextit0.hxx> -#include <unotools/intlwrapper.hxx> - -using namespace com::sun::star; - -#define ITEMBROWSER_WHICHCOL_ID 1 -#define ITEMBROWSER_STATECOL_ID 2 -#define ITEMBROWSER_TYPECOL_ID 3 -#define ITEMBROWSER_NAMECOL_ID 4 -#define ITEMBROWSER_VALUECOL_ID 5 - -#define ITEM_NOT_FOUND std::numeric_limits<std::size_t>::max() - -namespace { - -enum class ItemType { - DONTKNOW, BYTE, INT16, UINT16, INT32, UINT32, - ENUM, BOOL, FLAG, STRING, POINT, RECT, RANGE, - FRACTION, - XCOLOR, - COLOR, - FONT, FONTHEIGHT, FONTWIDTH, FIELD -}; - -} - -class ImpItemListRow -{ -public: - OUString aName; - OUString aValue; - SfxItemState eState; - sal_uInt16 nWhichId; - - const std::type_info* pType; - ItemType eItemType; - - sal_Int32 nVal; - sal_Int32 nMin; - sal_Int32 nMax; - - bool bComment; - bool bIsNum; - bool bCanNum; - -public: - ImpItemListRow() - : eState(SfxItemState::UNKNOWN), - nWhichId(0), - pType(nullptr), - eItemType(ItemType::DONTKNOW), - nVal(0), - nMin(0), - nMax(0), - bComment(false), - bIsNum(false), - bCanNum(false) - {} - - OUString GetItemTypeStr() const; - bool operator==(const ImpItemListRow& rEntry) const; - bool operator!=(const ImpItemListRow& rEntry) const { return !operator==(rEntry); } -}; - -OUString ImpItemListRow::GetItemTypeStr() const -{ - switch(eItemType) - { - case ItemType::BYTE : return "Byte"; break; - case ItemType::INT16 : return "Int16"; break; - case ItemType::UINT16 : return "UInt16"; break; - case ItemType::INT32 : return "Int32"; break; - case ItemType::UINT32 : return "UInt32"; break; - case ItemType::ENUM : return "Enum"; break; - case ItemType::BOOL : return "Bool"; break; - case ItemType::FLAG : return "Flag"; break; - case ItemType::STRING : return "String"; break; - case ItemType::POINT : return "Point"; break; - case ItemType::RECT : return "Rectangle";break; - case ItemType::RANGE : return "Range"; break; - case ItemType::FRACTION : return "Fraction"; break; - case ItemType::XCOLOR : return "XColor"; break; - case ItemType::COLOR : return "Color"; break; - case ItemType::FONT : return "Font"; break; - case ItemType::FONTHEIGHT: return "FontHeight";break; - case ItemType::FONTWIDTH : return "FontWidth"; break; - case ItemType::FIELD : return "Field"; break; - default: break; - } - - return OUString(); -} - -bool ImpItemListRow::operator==(const ImpItemListRow& rEntry) const -{ - return (aName == rEntry.aName - && aValue == rEntry.aValue - && eState==rEntry.eState - && nWhichId==rEntry.nWhichId - && bComment==rEntry.bComment - && bIsNum==rEntry.bIsNum - && bCanNum==rEntry.bCanNum - && pType==rEntry.pType - && eItemType==rEntry.eItemType - && nVal==rEntry.nVal - && nMin==rEntry.nMin - && nMax==rEntry.nMax); -} - - -class ImpItemEdit: public Edit -{ - VclPtr<SdrItemBrowserControl> pBrowse; - -public: - ImpItemEdit(vcl::Window* pParent, SdrItemBrowserControl* pBrowse_, WinBits nBits) - : Edit(pParent, nBits), - pBrowse(pBrowse_) - {} - virtual ~ImpItemEdit() override { disposeOnce(); } - virtual void dispose() override { pBrowse.clear(); Edit::dispose(); } - virtual void KeyInput(const KeyEvent& rEvt) override; -}; - -void ImpItemEdit::KeyInput(const KeyEvent& rKEvt) -{ - SdrItemBrowserControl* pBrowseTemp = pBrowse; - - sal_uInt16 nKeyCode(rKEvt.GetKeyCode().GetCode() + rKEvt.GetKeyCode().GetModifier()); - - if(nKeyCode == KEY_RETURN) - { - pBrowseTemp->EndChangeEntry(); - pBrowseTemp->GrabFocus(); - } - else if(nKeyCode == KEY_ESCAPE) - { - pBrowseTemp->BreakChangeEntry(); - pBrowseTemp->GrabFocus(); - } - else if(nKeyCode == KEY_UP || nKeyCode == KEY_DOWN) - { - pBrowseTemp->EndChangeEntry(); - pBrowseTemp->GrabFocus(); - pBrowseTemp->KeyInput(rKEvt); - } - else - Edit::KeyInput(rKEvt); -} - -// - SdrItemBrowserControl - - -#define MYBROWSEMODE (BrowserMode::THUMBDRAGGING|BrowserMode::KEEPHIGHLIGHT|BrowserMode::NO_HSCROLL|BrowserMode::HIDECURSOR) - -SdrItemBrowserControl::SdrItemBrowserControl(vcl::Window* pParent): - BrowseBox(pParent, WB_3DLOOK | WB_BORDER | WB_TABSTOP, MYBROWSEMODE) -{ - ImpCtor(); -} - -SdrItemBrowserControl::~SdrItemBrowserControl() -{ - disposeOnce(); -} - -void SdrItemBrowserControl::dispose() -{ - pEditControl.disposeAndClear(); - - pCurrentChangeEntry.reset(); - - Clear(); - BrowseBox::dispose(); -} - -void SdrItemBrowserControl::ImpCtor() -{ - pEditControl = nullptr; - pCurrentChangeEntry = nullptr; - nLastWhichOfs = 0; - nLastWhich = 0; - bWhichesButNames = false; - bDontHideIneffectiveItems = false; - bDontSortItems = false; - - InsertDataColumn( - ITEMBROWSER_WHICHCOL_ID, - "Which", - GetTextWidth(" Which ") + 2); - InsertDataColumn( - ITEMBROWSER_STATECOL_ID, - "State", - std::max(GetTextWidth(" State ") + 2 , - GetTextWidth("DontCare") + 2)); - InsertDataColumn( - ITEMBROWSER_TYPECOL_ID , - "Type", - GetTextWidth(" Type_ ") + 2); - InsertDataColumn( - ITEMBROWSER_NAMECOL_ID , - "Name", - 150); - InsertDataColumn( - ITEMBROWSER_VALUECOL_ID, - "Value", - GetTextWidth("12345678901234567890")); - SetDataRowHeight( - GetTextHeight()); - - long nWdt=GetColumnWidth(ITEMBROWSER_WHICHCOL_ID)+ - GetColumnWidth(ITEMBROWSER_STATECOL_ID)+ - GetColumnWidth(ITEMBROWSER_TYPECOL_ID )+ - GetColumnWidth(ITEMBROWSER_NAMECOL_ID )+ - GetColumnWidth(ITEMBROWSER_VALUECOL_ID); - - long nHgt=GetTitleHeight()+16*GetDataRowHeight(); - - SetOutputSizePixel(Size(nWdt,nHgt)); -} - -void SdrItemBrowserControl::Clear() -{ - aList.clear(); - BrowseBox::Clear(); -} - -long SdrItemBrowserControl::GetRowCount() const -{ - return aList.size(); -} - -bool SdrItemBrowserControl::SeekRow(long nRow) -{ - nCurrentPaintRow = nRow; - return true; -} - -OUString SdrItemBrowserControl::GetCellText(long _nRow, sal_uInt16 _nColId) const -{ - OUString sRet; - if ( _nRow >= 0 && _nRow < static_cast<sal_Int32>(aList.size()) ) - { - auto& pEntry = aList[_nRow]; - if ( pEntry->bComment ) - { - if (_nColId == ITEMBROWSER_NAMECOL_ID) - sRet = pEntry->aName; - } - else - { - sRet = "???"; - switch (_nColId) - { - case ITEMBROWSER_WHICHCOL_ID: - sRet = OUString::number( pEntry->nWhichId ); break; - case ITEMBROWSER_STATECOL_ID: - { - switch (pEntry->eState) - { - case SfxItemState::UNKNOWN : sRet = "Unknown"; break; - case SfxItemState::DISABLED: sRet = "Disabled"; break; - case SfxItemState::DONTCARE: sRet = "DontCare"; break; - case SfxItemState::SET : sRet = "Set"; break; - case SfxItemState::DEFAULT : sRet = "Default"; break; - case SfxItemState::READONLY: sRet = "ReadOnly"; break; - } // switch - } break; - case ITEMBROWSER_TYPECOL_ID: sRet = pEntry->GetItemTypeStr(); break; - case ITEMBROWSER_NAMECOL_ID: sRet = pEntry->aName; break; - case ITEMBROWSER_VALUECOL_ID: sRet = pEntry->aValue; break; - } // switch - } - } - return sRet; -} - -void SdrItemBrowserControl::PaintField(vcl::RenderContext& rDev, const tools::Rectangle& rRect, sal_uInt16 nColumnId) const -{ - if (nCurrentPaintRow<0 || static_cast<std::size_t>(nCurrentPaintRow)>=aList.size()) { - return; - } - tools::Rectangle aR(rRect); - aR.AdjustBottom( 1 ); - auto& pEntry=aList[nCurrentPaintRow]; - if (pEntry->bComment) - { - if (nColumnId==ITEMBROWSER_NAMECOL_ID) - { - rDev.SetLineColor(); - rDev.SetFillColor( COL_LIGHTGRAY ); - aR.SetLeft(0 ); - aR.SetRight(rDev.GetOutputSize().Width() ); - rDev.DrawRect(aR); - rDev.DrawText(rRect.TopLeft(),pEntry->aName); - } - } else { - rDev.SetClipRegion(vcl::Region(aR)); - rDev.DrawText(aR.TopLeft(),GetCellText(nCurrentPaintRow,nColumnId)); - rDev.SetClipRegion(); - } -} - -std::size_t SdrItemBrowserControl::GetCurrentPos() const -{ - std::size_t nRet=ITEM_NOT_FOUND; - if (GetSelectRowCount()==1) { - long nPos=static_cast<BrowseBox*>(const_cast<SdrItemBrowserControl *>(this))->FirstSelectedRow(); - if (nPos>=0 && static_cast<std::size_t>(nPos)<aList.size()) { - nRet = static_cast<std::size_t>(nPos); - } - } - return nRet; -} - -sal_uInt16 SdrItemBrowserControl::GetCurrentWhich() const -{ - sal_uInt16 nRet=0; - const std::size_t nPos=GetCurrentPos(); - if (nPos!=ITEM_NOT_FOUND) { - nRet=aList[nPos]->nWhichId; - } - return nRet; -} - -void SdrItemBrowserControl::DoubleClick(const BrowserMouseEvent&) -{ - const std::size_t nPos=GetCurrentPos(); - if (nPos!=ITEM_NOT_FOUND) { - BeginChangeEntry(nPos); - } -} - -void SdrItemBrowserControl::KeyInput(const KeyEvent& rKEvt) -{ - sal_uInt16 nKeyCode=rKEvt.GetKeyCode().GetCode()+rKEvt.GetKeyCode().GetModifier(); - bool bEvaluated = false; - const std::size_t nPos=GetCurrentPos(); - if (nPos!=ITEM_NOT_FOUND) { - if (nKeyCode==KEY_RETURN) { - if (BeginChangeEntry(nPos)) bEvaluated = true; - } else if (nKeyCode==KEY_ESCAPE) { - - } else if (rKEvt.GetKeyCode().GetModifier()==KEY_SHIFT+KEY_MOD1+KEY_MOD2) { // Ctrl - if (nKeyCode==KEY_SHIFT+KEY_MOD1+KEY_MOD2+KEY_W) { - bWhichesButNames=!bWhichesButNames; - SetDirty(); - } - if (nKeyCode==KEY_SHIFT+KEY_MOD1+KEY_MOD2+KEY_I) { - bDontHideIneffectiveItems=!bDontHideIneffectiveItems; - SetDirty(); - } - if (nKeyCode==KEY_SHIFT+KEY_MOD1+KEY_MOD2+KEY_S) { - bDontSortItems=!bDontSortItems; - SetDirty(); - } - } - } - if (!bEvaluated) BrowseBox::KeyInput(rKEvt); -} - -void SdrItemBrowserControl::SetDirty() -{ - aSetDirtyHdl.Call(*this); -} - -tools::Rectangle SdrItemBrowserControl::GetFieldCharacterBounds(sal_Int32 /*_nRow*/,sal_Int32 /*_nColumnPos*/,sal_Int32 /*nIndex*/) -{ - // no accessibility implementation required - return tools::Rectangle(); -} - -sal_Int32 SdrItemBrowserControl::GetFieldIndexAtPoint(sal_Int32 /*_nRow*/,sal_Int32 /*_nColumnPos*/,const Point& /*_rPoint*/) -{ - // no accessibility implementation required - return -1; -} - -void SdrItemBrowserControl::Select() -{ - EndChangeEntry(); - BrowseBox::Select(); - ImpSaveWhich(); -} - -void SdrItemBrowserControl::ImpSaveWhich() -{ - sal_uInt16 nWh=GetCurrentWhich(); - if (nWh!=0) { - nLastWhich=nWh; - nLastWhichOfs=GetCurrentPos()-GetTopRow(); - } -} - -void SdrItemBrowserControl::ImpRestoreWhich() -{ - if (nLastWhich!=0) { - bool bFnd = false; - const std::size_t nCount=aList.size(); - std::size_t nNum; - for (nNum=0; nNum<nCount && !bFnd; nNum++) { - auto& pEntry=aList[nNum]; - if (!pEntry->bComment) { - sal_uInt16 nWh=pEntry->nWhichId; - if (nWh==nLastWhich) bFnd = true; - } - } - if (bFnd) { - long nPos=nNum-1; - long nWhichOfs=nPos-GetTopRow(); - if (nWhichOfs!=nLastWhichOfs) { - ScrollRows(nWhichOfs-nLastWhichOfs); - } - GoToRow(nPos); - } - } -} - -bool SdrItemBrowserControl::BeginChangeEntry(std::size_t nPos) -{ - BreakChangeEntry(); - bool bRet = false; - auto& pEntry=aList[nPos]; - if (!pEntry->bComment) { - SetMode(MYBROWSEMODE & BrowserMode(~BrowserMode::KEEPHIGHLIGHT)); - pEditControl=VclPtr<ImpItemEdit>::Create(&GetDataWindow(),this,0); - tools::Rectangle aRect(GetFieldRectPixel(nPos, ITEMBROWSER_VALUECOL_ID, false)); - aRect.AdjustLeft(2 ); // little offset for the Edit, so it's exact to the pixel - aRect.AdjustRight( -1 ); - pEditControl->SetPosSizePixel(aRect.TopLeft(),aRect.GetSize()); - pEditControl->SetText(pEntry->aValue); - pEditControl->SetBackground( Wallpaper(COL_LIGHTGRAY)); - vcl::Font aFont(pEditControl->GetFont()); - aFont.SetFillColor(COL_LIGHTGRAY); - pEditControl->SetFont(aFont); - pEditControl->Show(); - pEditControl->GrabFocus(); - pEditControl->SetSelection(Selection(SELECTION_MIN,SELECTION_MAX)); - vcl::Window* pParent=GetParent(); - aWNameMemorized=pParent->GetText(); - OUString aNewName = aWNameMemorized + " " + - pEntry->GetItemTypeStr(); - if (pEntry->bCanNum) { - aNewName += ": " + OUString::number(pEntry->nMin) + - ".." + OUString::number(pEntry->nMax); - } - aNewName += " - Type 'del' to reset to default."; - pParent->SetText(aNewName); - pCurrentChangeEntry.reset(new ImpItemListRow(*pEntry)); - bRet = true; - } - return bRet; -} - -void SdrItemBrowserControl::EndChangeEntry() -{ - if (!pEditControl) - return; - - aEntryChangedHdl.Call(*this); - BreakChangeEntry(); -} - -void SdrItemBrowserControl::BreakChangeEntry() -{ - if (pEditControl!=nullptr) { - pEditControl.disposeAndClear(); - pCurrentChangeEntry.reset(); - vcl::Window* pParent=GetParent(); - pParent->SetText(aWNameMemorized); - SetMode(MYBROWSEMODE); - } -} - -void SdrItemBrowserControl::ImpSetEntry(const ImpItemListRow& rEntry, std::size_t nEntryNum) -{ - SAL_WARN_IF(nEntryNum > aList.size(), "svx", "trying to set item " << nEntryNum << "in a vector of size " << aList.size()); - if (nEntryNum >= aList.size()) { - nEntryNum = aList.size(); - aList.emplace_back(new ImpItemListRow(rEntry)); - RowInserted(nEntryNum); - } else { - auto& pCurrentEntry=aList[nEntryNum]; - if (*pCurrentEntry!=rEntry) { - bool bStateDiff=rEntry.eState!=pCurrentEntry->eState; - bool bValueDiff=rEntry.aValue != pCurrentEntry->aValue; - bool bAllDiff = true; - if (bStateDiff || bValueDiff) { - // check whether only state and/or value have changed - ImpItemListRow aTest(rEntry); - aTest.eState=pCurrentEntry->eState; - aTest.aValue=pCurrentEntry->aValue; - if (aTest==*pCurrentEntry) bAllDiff = false; - } - *pCurrentEntry=rEntry; - if (bAllDiff) { - RowModified(nEntryNum); - } else { - if (bStateDiff) RowModified(nEntryNum,ITEMBROWSER_STATECOL_ID); - if (bValueDiff) RowModified(nEntryNum,ITEMBROWSER_VALUECOL_ID); - } - } - } -} - -static bool ImpGetItem(const SfxItemSet& rSet, sal_uInt16 nWhich, const SfxPoolItem*& rpItem) -{ - SfxItemState eState=rSet.GetItemState(nWhich,true,&rpItem); - if (eState==SfxItemState::DEFAULT) { - rpItem=&rSet.Get(nWhich); - } - return (eState==SfxItemState::DEFAULT || eState==SfxItemState::SET) && rpItem!=nullptr; -} - -static bool IsItemIneffective(sal_uInt16 nWhich, const SfxItemSet* pSet, sal_uInt16& rIndent) -{ - rIndent=0; - if (pSet==nullptr) return false; - const SfxPoolItem* pItem=nullptr; - switch (nWhich) { - case XATTR_LINEDASH : - case XATTR_LINEWIDTH : - case XATTR_LINECOLOR : - case XATTR_LINESTART : - case XATTR_LINEEND : - case XATTR_LINESTARTWIDTH : - case XATTR_LINEENDWIDTH : - case XATTR_LINESTARTCENTER : - case XATTR_LINEENDCENTER : - case XATTR_LINETRANSPARENCE : { - rIndent=1; - if (ImpGetItem(*pSet,XATTR_LINESTYLE,pItem)) { - drawing::LineStyle eLineStyle=static_cast<const XLineStyleItem*>(pItem)->GetValue(); - if (eLineStyle==drawing::LineStyle_NONE) return true; - if (eLineStyle!=drawing::LineStyle_DASH && nWhich==XATTR_LINEDASH) return true; - } - if (nWhich==XATTR_LINESTART || nWhich==XATTR_LINESTARTCENTER) { - rIndent=2; - if (ImpGetItem(*pSet,XATTR_LINESTARTWIDTH,pItem)) { - sal_Int32 nWdt=static_cast<const XLineStartWidthItem*>(pItem)->GetValue(); - if (nWdt==0) return true; - } - } - if (nWhich==XATTR_LINEEND || nWhich==XATTR_LINEENDCENTER) { - rIndent=2; - if (ImpGetItem(*pSet,XATTR_LINEENDWIDTH,pItem)) { - sal_Int32 nWdt=static_cast<const XLineEndWidthItem*>(pItem)->GetValue(); - if (nWdt==0) return true; - } - } - } break; - case XATTR_FILLCOLOR : /* only for Style=Color */ - case XATTR_FILLGRADIENT : /* only for Style=Gradient */ - case XATTR_FILLHATCH : /* only for Style=Hatch */ - case XATTR_FILLTRANSPARENCE : /* only for Style=Color */ - case XATTR_GRADIENTSTEPCOUNT : /* only for Style=Gradient */ - case XATTR_FILLBACKGROUND : /* only for Style=Hatch */ - { - rIndent=1; - if (ImpGetItem(*pSet,XATTR_FILLSTYLE,pItem)) { - drawing::FillStyle eFillStyle=static_cast<const XFillStyleItem*>(pItem)->GetValue(); - if (eFillStyle==drawing::FillStyle_NONE) return true; - // transparency currently only for SolidFill - if (eFillStyle!=drawing::FillStyle_SOLID && (nWhich==XATTR_FILLCOLOR || nWhich==XATTR_FILLTRANSPARENCE)) return true; - if (eFillStyle!=drawing::FillStyle_GRADIENT && (nWhich==XATTR_FILLGRADIENT || nWhich==XATTR_GRADIENTSTEPCOUNT)) return true; - if (eFillStyle!=drawing::FillStyle_HATCH && (nWhich==XATTR_FILLHATCH || nWhich==XATTR_FILLBACKGROUND)) return true; - } - } break; - case XATTR_FILLBITMAP : - case XATTR_FILLBMP_TILE : - case XATTR_FILLBMP_POS : /* currently only if TILE=sal_True */ - case XATTR_FILLBMP_SIZEX : /* only if not Stretch */ - case XATTR_FILLBMP_SIZEY : /* only if not Stretch */ - case XATTR_FILLBMP_SIZELOG : /* only if SIZELOG=sal_False to reset to sal_True (old) -> but is still in use */ - case XATTR_FILLBMP_TILEOFFSETX : /* only if TILE=sal_True */ - case XATTR_FILLBMP_TILEOFFSETY : /* only if TILE=sal_True */ - case XATTR_FILLBMP_STRETCH : /* only if TILE=sal_False */ - case XATTR_FILLBMP_POSOFFSETX : /* only if TILE=sal_True*/ - case XATTR_FILLBMP_POSOFFSETY : { /* only if TILE=sal_True*/ - rIndent=1; - if (ImpGetItem(*pSet,XATTR_FILLSTYLE,pItem)) { - drawing::FillStyle eFillStyle=static_cast<const XFillStyleItem*>(pItem)->GetValue(); - if (eFillStyle!=drawing::FillStyle_BITMAP) return true; - } - if (nWhich==XATTR_FILLBITMAP || nWhich==XATTR_FILLBMP_TILE) { - return false; // always selectable - } - bool bTileTRUE = false; - bool bTileFALSE = false; - bool bStretchTRUE = false; - if (ImpGetItem(*pSet,XATTR_FILLBMP_TILE,pItem)) { - bTileTRUE=static_cast<const XFillBmpTileItem*>(pItem)->GetValue(); - bTileFALSE=!bTileTRUE; - } - if (ImpGetItem(*pSet,XATTR_FILLBMP_STRETCH,pItem)) { - bStretchTRUE=static_cast<const XFillBmpStretchItem*>(pItem)->GetValue(); - } - // Stretch not selectable if Tile=TRUE - if (nWhich==XATTR_FILLBMP_STRETCH) return bTileTRUE; - // and 7+1 items (sub-attributes) remain - rIndent=2; - // Pos (enum) not selectable if Tile=FALSE - if (nWhich==XATTR_FILLBMP_POS) return bTileFALSE; - // SizeXY not selectable if Stretch=TRUE - if (nWhich==XATTR_FILLBMP_SIZEX || nWhich==XATTR_FILLBMP_SIZEY) { - return bTileFALSE && bStretchTRUE; - } - // 2 items specially for Tile - if (nWhich==XATTR_FILLBMP_POSOFFSETX || nWhich==XATTR_FILLBMP_POSOFFSETY) { - return bTileFALSE; - } - // another 2 items specially for Tile -- however, these exclude each other - if (nWhich==XATTR_FILLBMP_TILEOFFSETX || nWhich==XATTR_FILLBMP_TILEOFFSETY) { - if (bTileFALSE) return true; - sal_uInt16 nX=0,nY=0; - bool bX = false,bY = false; - if (ImpGetItem(*pSet,XATTR_FILLBMP_TILEOFFSETX,pItem)) { - nX=static_cast<const XFillBmpTileOffsetXItem*>(pItem)->GetValue(); - bX = true; - } - if (ImpGetItem(*pSet,XATTR_FILLBMP_TILEOFFSETY,pItem)) { - nY=static_cast<const XFillBmpTileOffsetYItem*>(pItem)->GetValue(); - bY = true; - } - if (nWhich==XATTR_FILLBMP_TILEOFFSETX) { - if (nX!=0 || !bX) return false; - if (nY!=0) return true; - } else { - if (nY!=0 || !bY) return false; - if (nX!=0) return true; - } - } - // SizeLog not selectable if Stretch=TRUE and/or - // if SizeLog=sal_False. - // -> apparently still in use - // (sal_True is the static PoolDefault) - if (nWhich==XATTR_FILLBMP_SIZELOG) { - if (bTileFALSE && bStretchTRUE) return true; - } - } break; - - case XATTR_FORMTXTADJUST : - case XATTR_FORMTXTDISTANCE : - case XATTR_FORMTXTSTART : - case XATTR_FORMTXTMIRROR : - case XATTR_FORMTXTOUTLINE : - case XATTR_FORMTXTSHADOW : - case XATTR_FORMTXTSHDWCOLOR : - case XATTR_FORMTXTSHDWXVAL : - case XATTR_FORMTXTSHDWYVAL : - case XATTR_FORMTXTHIDEFORM : - case XATTR_FORMTXTSHDWTRANSP: { - rIndent=1; - if (ImpGetItem(*pSet,XATTR_FORMTXTSTYLE,pItem)) { - XFormTextStyle eStyle=static_cast<const XFormTextStyleItem*>(pItem)->GetValue(); - if (eStyle==XFormTextStyle::NONE) return true; - } - if ((nWhich>=XATTR_FORMTXTSHDWCOLOR && nWhich<=XATTR_FORMTXTSHDWYVAL) || nWhich>=XATTR_FORMTXTSHDWTRANSP) { - rIndent=2; - if (ImpGetItem(*pSet,XATTR_FORMTXTSHADOW,pItem)) { - XFormTextShadow eShadow=static_cast<const XFormTextShadowItem*>(pItem)->GetValue(); - if (eShadow==XFormTextShadow::NONE) return true; - } - } - } break; - - case SDRATTR_SHADOWCOLOR : - case SDRATTR_SHADOWXDIST : - case SDRATTR_SHADOWYDIST : - case SDRATTR_SHADOWTRANSPARENCE: - case SDRATTR_SHADOW3D : - case SDRATTR_SHADOWPERSP : { - rIndent=1; - if (ImpGetItem(*pSet,SDRATTR_SHADOW,pItem)) { - bool bShadow=static_cast<const SdrOnOffItem*>(pItem)->GetValue(); - if (!bShadow) return true; - } - } break; - - case SDRATTR_CAPTIONANGLE: { - rIndent=1; - if (ImpGetItem(*pSet,SDRATTR_CAPTIONFIXEDANGLE,pItem)) { - bool bFixed=static_cast<const SdrOnOffItem*>(pItem)->GetValue(); - if (!bFixed) return true; - } - } break; - case SDRATTR_CAPTIONESCREL: - case SDRATTR_CAPTIONESCABS: { - rIndent=1; - if (ImpGetItem(*pSet,SDRATTR_CAPTIONESCISREL,pItem)) { - bool bRel=static_cast<const SdrCaptionEscIsRelItem*>(pItem)->GetValue(); - if (bRel && nWhich==SDRATTR_CAPTIONESCABS) return true; - if (!bRel && nWhich==SDRATTR_CAPTIONESCREL) return true; - } - } break; - case SDRATTR_CAPTIONLINELEN: { - rIndent=1; - if (ImpGetItem(*pSet,SDRATTR_CAPTIONFITLINELEN,pItem)) { - bool bFit=static_cast<const SdrCaptionFitLineLenItem*>(pItem)->GetValue(); - if (bFit) return true; - } - } break; - - case SDRATTR_TEXT_MINFRAMEHEIGHT: - case SDRATTR_TEXT_MAXFRAMEHEIGHT: { - rIndent=1; - if (ImpGetItem(*pSet,SDRATTR_TEXT_AUTOGROWHEIGHT,pItem)) { - bool bAutoGrow=static_cast<const SdrOnOffItem*>(pItem)->GetValue(); - if (!bAutoGrow) return true; - } - } break; - case SDRATTR_TEXT_MINFRAMEWIDTH: - case SDRATTR_TEXT_MAXFRAMEWIDTH: { - rIndent=1; - if (ImpGetItem(*pSet,SDRATTR_TEXT_AUTOGROWWIDTH,pItem)) { - bool bAutoGrow=static_cast<const SdrOnOffItem*>(pItem)->GetValue(); - if (!bAutoGrow) return true; - } - } break; - case SDRATTR_TEXT_VERTADJUST: - case SDRATTR_TEXT_HORZADJUST: { - if (ImpGetItem(*pSet,SDRATTR_TEXT_FITTOSIZE,pItem)) { - drawing::TextFitToSizeType const eFit = - static_cast<const SdrTextFitToSizeTypeItem*>(pItem)->GetValue(); - if (eFit != drawing::TextFitToSizeType_NONE) { return true; } - } - } break; - - case SDRATTR_TEXT_ANIDIRECTION : - case SDRATTR_TEXT_ANISTARTINSIDE: - case SDRATTR_TEXT_ANISTOPINSIDE : - case SDRATTR_TEXT_ANICOUNT : - case SDRATTR_TEXT_ANIDELAY : - case SDRATTR_TEXT_ANIAMOUNT : { - rIndent=1; - if (ImpGetItem(*pSet,SDRATTR_TEXT_ANIKIND,pItem)) { - SdrTextAniKind eAniKind=static_cast<const SdrTextAniKindItem*>(pItem)->GetValue(); - if (eAniKind==SdrTextAniKind::NONE) return true; - if (eAniKind==SdrTextAniKind::Blink && (nWhich==SDRATTR_TEXT_ANIDIRECTION || nWhich==SDRATTR_TEXT_ANIAMOUNT)) return true; - if (eAniKind==SdrTextAniKind::Slide && (nWhich==SDRATTR_TEXT_ANISTARTINSIDE || nWhich==SDRATTR_TEXT_ANISTOPINSIDE)) return true; - } - } break; - - case SDRATTR_EDGELINEDELTACOUNT: return true; - case SDRATTR_EDGELINE1DELTA: - case SDRATTR_EDGELINE2DELTA: - case SDRATTR_EDGELINE3DELTA: { - if (ImpGetItem(*pSet,SDRATTR_EDGEKIND,pItem)) { - SdrEdgeKind eKind=static_cast<const SdrEdgeKindItem*>(pItem)->GetValue(); - if (eKind==SdrEdgeKind::ThreeLines) { - return nWhich>SDRATTR_EDGELINE2DELTA; - } - if (eKind!=SdrEdgeKind::OrthoLines && eKind!=SdrEdgeKind::Bezier) return true; - } - if (ImpGetItem(*pSet,SDRATTR_EDGELINEDELTACOUNT,pItem)) { - sal_uInt16 nCount=static_cast<const SdrEdgeLineDeltaCountItem*>(pItem)->GetValue(); - if (nCount==0) return true; - if (nCount==1 && nWhich>SDRATTR_EDGELINE1DELTA) return true; - if (nCount==2 && nWhich>SDRATTR_EDGELINE2DELTA) return true; - } - } break; - - case SDRATTR_CIRCSTARTANGLE: - case SDRATTR_CIRCENDANGLE : { - rIndent=1; - if (ImpGetItem(*pSet,SDRATTR_CIRCKIND,pItem)) { - SdrCircKind eKind=static_cast<const SdrCircKindItem*>(pItem)->GetValue(); - if (eKind==SdrCircKind::Full) return true; - } - } break; - } // switch - return false; -} - -static sal_uInt16 ImpSortWhich(sal_uInt16 nWhich) -{ - switch (nWhich) { - // Line - case XATTR_LINESTART : nWhich=XATTR_LINETRANSPARENCE ; break; - case XATTR_LINEEND : nWhich=XATTR_LINESTARTWIDTH ; break; - case XATTR_LINESTARTWIDTH : nWhich=XATTR_LINESTART ; break; - case XATTR_LINEENDWIDTH : nWhich=XATTR_LINESTARTCENTER ; break; - case XATTR_LINESTARTCENTER : nWhich=XATTR_LINEENDWIDTH ; break; - case XATTR_LINEENDCENTER : nWhich=XATTR_LINEEND ; break; - case XATTR_LINETRANSPARENCE : nWhich=XATTR_LINEENDCENTER ; break; - - // Fill - case XATTR_FILLBMP_POS : nWhich=XATTR_FILLBMP_STRETCH ; break; - case XATTR_FILLBMP_SIZEX : nWhich=XATTR_FILLBMP_POS ; break; - case XATTR_FILLBMP_SIZEY : nWhich=XATTR_FILLBMP_SIZEX ; break; - case XATTR_FILLBMP_SIZELOG : nWhich=XATTR_FILLBMP_SIZEY ; break; - case XATTR_FILLBMP_TILEOFFSETX : nWhich=XATTR_FILLBMP_SIZELOG ; break; - case XATTR_FILLBMP_TILEOFFSETY : nWhich=XATTR_FILLBMP_TILEOFFSETX ; break; - case XATTR_FILLBMP_STRETCH : nWhich=XATTR_FILLBMP_TILEOFFSETY ; break; - - // Fontwork - case XATTR_FORMTXTSHADOW : nWhich=XATTR_FORMTXTSHDWXVAL ; break; - case XATTR_FORMTXTSHDWCOLOR : nWhich=XATTR_FORMTXTHIDEFORM ; break; - case XATTR_FORMTXTSHDWXVAL : nWhich=XATTR_FORMTXTSHADOW ; break; - case XATTR_FORMTXTSHDWYVAL : nWhich=XATTR_FORMTXTSHDWCOLOR ; break; - case XATTR_FORMTXTHIDEFORM : nWhich=XATTR_FORMTXTSHDWYVAL ; break; - - // Misc - case SDRATTR_TEXT_MINFRAMEHEIGHT: nWhich=SDRATTR_TEXT_FITTOSIZE ; break; - case SDRATTR_TEXT_AUTOGROWHEIGHT: nWhich=SDRATTR_TEXT_LEFTDIST ; break; - case SDRATTR_TEXT_FITTOSIZE : nWhich=SDRATTR_TEXT_RIGHTDIST ; break; - case SDRATTR_TEXT_LEFTDIST : nWhich=SDRATTR_TEXT_UPPERDIST ; break; - case SDRATTR_TEXT_RIGHTDIST : nWhich=SDRATTR_TEXT_LOWERDIST ; break; - case SDRATTR_TEXT_UPPERDIST : nWhich=SDRATTR_TEXT_AUTOGROWWIDTH ; break; - case SDRATTR_TEXT_LOWERDIST : nWhich=SDRATTR_TEXT_MINFRAMEWIDTH ; break; - case SDRATTR_TEXT_VERTADJUST : nWhich=SDRATTR_TEXT_MAXFRAMEWIDTH ; break; - case SDRATTR_TEXT_MAXFRAMEHEIGHT: nWhich=SDRATTR_TEXT_AUTOGROWHEIGHT; break; - case SDRATTR_TEXT_MINFRAMEWIDTH : nWhich=SDRATTR_TEXT_MINFRAMEHEIGHT; break; - case SDRATTR_TEXT_MAXFRAMEWIDTH : nWhich=SDRATTR_TEXT_MAXFRAMEHEIGHT; break; - case SDRATTR_TEXT_AUTOGROWWIDTH : nWhich=SDRATTR_TEXT_HORZADJUST ; break; - case SDRATTR_TEXT_HORZADJUST : nWhich=SDRATTR_TEXT_VERTADJUST ; break; - } // switch - return nWhich; -} - -#define INSERTCOMMENT(nStartId,nEndId,aStr) \ - { if (nWhich0<nStartId && nWhich>=nStartId && nWhich<=nEndId) aCommentStr=aStr; } - -void SdrItemBrowserControl::SetAttributes(const SfxItemSet* pSet, const SfxItemSet* p2ndSet) -{ - SetMode(MYBROWSEMODE & BrowserMode(~BrowserMode::KEEPHIGHLIGHT)); - if (pSet!=nullptr) { - IntlWrapper aIntlWrapper(SvtSysLocale().GetUILanguageTag()); - sal_uInt16 nEntryNum=0; - SfxWhichIter aIter(*pSet); - const SfxItemPool* pPool=pSet->GetPool(); - sal_uInt16 nWhich0=0; - sal_uInt16 nWhich=aIter.FirstWhich(); - while (nWhich!=0) { - // Now sort this a little bit differently. - // Only works as long as there are no InvalidItems, i. e. no gaps - // at this position in the Set. - if (!bDontSortItems) nWhich=ImpSortWhich(nWhich); - SfxItemState eState=pSet->GetItemState(nWhich); - if (p2ndSet!=nullptr) { - SfxItemState e2ndState=p2ndSet->GetItemState(nWhich); - if (eState==SfxItemState::DEFAULT) eState=SfxItemState::DISABLED; - else if (e2ndState==SfxItemState::DEFAULT) eState=SfxItemState::DEFAULT; - } - if (eState!=SfxItemState::DISABLED) { - const SfxPoolItem& rItem=pSet->Get(nWhich); - sal_uInt16 nIndent=0; - if (!rItem.IsVoidItem() && dynamic_cast<const SfxSetItem *>(&rItem) == nullptr - && (!IsItemIneffective(nWhich,pSet,nIndent) || bDontHideIneffectiveItems)) { - OUString aCommentStr; - - INSERTCOMMENT(XATTR_LINE_FIRST,XATTR_LINE_LAST,"L I N E"); - INSERTCOMMENT(XATTR_FILL_FIRST,XATTR_FILL_LAST,"F I L L"); - INSERTCOMMENT(XATTR_TEXT_FIRST,XATTR_TEXT_LAST,"F O N T W O R K"); - INSERTCOMMENT(SDRATTR_SHADOW_FIRST,SDRATTR_SHADOW_LAST,"S H A D O W"); - INSERTCOMMENT(SDRATTR_CAPTION_FIRST,SDRATTR_CAPTION_LAST,"C A P T I O N"); - INSERTCOMMENT(SDRATTR_MISC_FIRST,SDRATTR_MISC_LAST,"M I S C E L L A N E O U S"); - INSERTCOMMENT(SDRATTR_EDGE_FIRST,SDRATTR_EDGE_LAST,"C O N N E C T O R"); - INSERTCOMMENT(SDRATTR_MEASURE_FIRST,SDRATTR_MEASURE_LAST,"D I M E N S I O N"); - INSERTCOMMENT(SDRATTR_CIRC_FIRST,SDRATTR_CIRC_LAST,"C I R C U L A R"); - INSERTCOMMENT(SDRATTR_NOTPERSIST_FIRST,SDRATTR_NOTPERSIST_LAST,"N O T P E R S I S T"); - INSERTCOMMENT(SDRATTR_MOVEX,SDRATTR_VERTSHEARONE,"Transformation of all object individually"); - INSERTCOMMENT(SDRATTR_RESIZEXALL,SDRATTR_VERTSHEARALL,"Transformation of all objects together"); - INSERTCOMMENT(SDRATTR_TRANSFORMREF1X,SDRATTR_TRANSFORMREF2Y,"V I E W R E F E R E N C E P O I N T S"); - INSERTCOMMENT(SDRATTR_GRAF_FIRST,SDRATTR_GRAF_LAST,"G R A P H I C"); - INSERTCOMMENT(EE_ITEMS_START,EE_ITEMS_END,"E D I T E N G I N E"); - INSERTCOMMENT(EE_ITEMS_END+1,EE_ITEMS_END+1,"... by Joe Merten, JME Engineering Berlin ..."); - - if (!aCommentStr.isEmpty()) - { - ImpItemListRow aEntry; - aEntry.bComment = true; - aEntry.aName=aCommentStr; - ImpSetEntry(aEntry,nEntryNum); - nEntryNum++; - } - nWhich0=nWhich; - ImpItemListRow aEntry; - aEntry.aName = SdrItemPool::GetItemName(nWhich); - nIndent*=2; - - while(nIndent > 0) - { - aEntry.aName = " " + aEntry.aName; - nIndent--; - } - - aEntry.eState=eState; - aEntry.nWhichId=nWhich; - if (!IsInvalidItem(&rItem)) { - aEntry.pType=&typeid(rItem); - aEntry.nMax=0x7FFFFFFF; - aEntry.nMin=-aEntry.nMax; - aEntry.nVal=-4711; - if (dynamic_cast<const SfxByteItem *>(&rItem) != nullptr) aEntry.eItemType=ItemType::BYTE; - else if (dynamic_cast<const SfxInt16Item *>(&rItem) != nullptr) aEntry.eItemType=ItemType::INT16; - else if (dynamic_cast<const SfxUInt16Item *>(&rItem) != nullptr) aEntry.eItemType=ItemType::UINT16; - else if (dynamic_cast<const SfxInt32Item *>(&rItem) != nullptr) aEntry.eItemType=ItemType::INT32; - else if (dynamic_cast<const SfxUInt32Item *>(&rItem) != nullptr) aEntry.eItemType=ItemType::UINT32; - else if (dynamic_cast<const SfxEnumItemInterface *>(&rItem) != nullptr) aEntry.eItemType=ItemType::ENUM; - else if (dynamic_cast<const SfxBoolItem *>(&rItem) != nullptr) aEntry.eItemType=ItemType::BOOL; - else if (dynamic_cast<const SfxFlagItem *>(&rItem) != nullptr) aEntry.eItemType=ItemType::FLAG; - else if (dynamic_cast<const XColorItem *>(&rItem) != nullptr) aEntry.eItemType=ItemType::XCOLOR; - else if (dynamic_cast<const SfxStringItem *>(&rItem) != nullptr) aEntry.eItemType=ItemType::STRING; - else if (dynamic_cast<const SfxPointItem *>(&rItem) != nullptr) aEntry.eItemType=ItemType::POINT; - else if (dynamic_cast<const SfxRectangleItem *>(&rItem) != nullptr) aEntry.eItemType=ItemType::RECT; - else if (dynamic_cast<const SfxRangeItem *>(&rItem) != nullptr) aEntry.eItemType=ItemType::RANGE; - else if (dynamic_cast<const SdrFractionItem *>(&rItem) != nullptr) aEntry.eItemType=ItemType::FRACTION; - else if (dynamic_cast<const SvxColorItem *>(&rItem) != nullptr) aEntry.eItemType=ItemType::COLOR; - else if (dynamic_cast<const SvxFontItem *>(&rItem) != nullptr) aEntry.eItemType=ItemType::FONT; - else if (dynamic_cast<const SvxFontHeightItem *>(&rItem) != nullptr)aEntry.eItemType=ItemType::FONTHEIGHT; - else if (dynamic_cast<const SvxCharScaleWidthItem *>(&rItem) != nullptr) aEntry.eItemType=ItemType::FONTWIDTH; - else if (dynamic_cast<const SvxFieldItem *>(&rItem) != nullptr) aEntry.eItemType=ItemType::FIELD; - switch (aEntry.eItemType) { - case ItemType::BYTE : aEntry.bIsNum = true; aEntry.nVal=static_cast<const SfxByteItem &>(rItem).GetValue(); aEntry.nMin=0; aEntry.nMax=255; break; - case ItemType::INT16 : aEntry.bIsNum = true; aEntry.nVal=static_cast<const SfxInt16Item &>(rItem).GetValue(); aEntry.nMin=-32767; aEntry.nMax=32767; break; - case ItemType::UINT16 : aEntry.bIsNum = true; aEntry.nVal=static_cast<const SfxUInt16Item&>(rItem).GetValue(); aEntry.nMin=0; aEntry.nMax=65535; break; - case ItemType::INT32 : aEntry.bIsNum = true; aEntry.nVal=static_cast<const SfxInt32Item &>(rItem).GetValue(); break; - case ItemType::UINT32 : aEntry.bIsNum = true; aEntry.nVal=static_cast<const SfxUInt32Item&>(rItem).GetValue(); aEntry.nMin=0; /*aEntry.nMax=0xFF...*/;break; - case ItemType::ENUM : aEntry.bCanNum = true; aEntry.nVal=static_cast<const SfxEnumItemInterface&>(rItem).GetEnumValue(); aEntry.nMin=0; aEntry.nMax=static_cast<const SfxEnumItemInterface&>(rItem).GetValueCount()-1; break; - case ItemType::BOOL : aEntry.bCanNum = true; aEntry.nVal=sal_Int32(static_cast<const SfxBoolItem &>(rItem).GetValue()); aEntry.nMin=0; aEntry.nMax=1; break; - case ItemType::FLAG : aEntry.bCanNum = true; aEntry.nVal=static_cast<const SfxFlagItem &>(rItem).GetValue(); aEntry.nMin=0; aEntry.nMax=0xFFFF; break; - case ItemType::FONTHEIGHT: aEntry.bCanNum = true; aEntry.nVal=static_cast<const SvxFontHeightItem&>(rItem).GetHeight(); aEntry.nMin=0; break; - case ItemType::FONTWIDTH : aEntry.bCanNum = true; aEntry.nVal=static_cast<const SvxCharScaleWidthItem&>(rItem).GetValue(); aEntry.nMin=0; aEntry.nMax=0xFFFF;break; - default: break; - } // switch - if (aEntry.bIsNum) aEntry.bCanNum = true; - - rItem.GetPresentation(SfxItemPresentation::Nameless, - pPool->GetMetric(nWhich), - MapUnit::MapMM, aEntry.aValue, aIntlWrapper); - if (aEntry.bCanNum) - { - aEntry.aValue = OUString::number(aEntry.nVal) + ": " + aEntry.aValue; - } - } - else - { - aEntry.aValue = "InvalidItem"; - } - ImpSetEntry(aEntry,nEntryNum); - nEntryNum++; - } - } - nWhich=aIter.NextWhich(); - } // while - - if (aList.size()>nEntryNum) { // maybe still too many entries - size_t const nTooMuch = aList.size() - nEntryNum; - aList.erase(aList.begin() + nEntryNum, aList.end()); - RowRemoved(nEntryNum,nTooMuch); - } - } else { - Clear(); // if pSet==NULL - } - ImpRestoreWhich(); - SetMode(MYBROWSEMODE); -} - -SdrItemBrowser::SdrItemBrowser(SdrView& rView): - FloatingWindow(ImpGetViewWin(rView), WB_STDDOCKWIN|WB_3DLOOK|WB_CLOSEABLE|WB_SIZEMOVE), - aBrowse(VclPtr<SdrItemBrowserControl>::Create(this)), - aIdle("svx svdraw SdrItemBrowser"), - pView(&rView), - bDirty(false) -{ - SetOutputSizePixel(aBrowse->GetSizePixel()); - SetText("Joe's ItemBrowser"); - aBrowse->Show(); - aIdle.SetInvokeHandler(LINK(this,SdrItemBrowser,IdleHdl)); - GetBrowserControl()->SetEntryChangedHdl(LINK(this,SdrItemBrowser,ChangedHdl)); - GetBrowserControl()->SetSetDirtyHdl(LINK(this,SdrItemBrowser,SetDirtyHdl)); - SetDirty(); -} - -SdrItemBrowser::~SdrItemBrowser() -{ - disposeOnce(); -} - -void SdrItemBrowser::dispose() -{ - aBrowse.disposeAndClear(); - FloatingWindow::dispose(); -} - -void SdrItemBrowser::Resize() -{ - aBrowse->SetSizePixel(GetOutputSizePixel()); -} - -void SdrItemBrowser::GetFocus() -{ - aBrowse->GrabFocus(); -} - -vcl::Window* SdrItemBrowser::ImpGetViewWin(SdrView const & rView) -{ - const sal_uInt32 nWinCount(rView.PaintWindowCount()); - - for(sal_uInt32 a(0); a < nWinCount; a++) - { - SdrPaintWindow* pCandidate = rView.GetPaintWindow(a); - - if(OUTDEV_WINDOW == pCandidate->GetOutputDevice().GetOutDevType()) - { - return static_cast<vcl::Window*>(&pCandidate->GetOutputDevice()); - } - } - - return nullptr; -} - -void SdrItemBrowser::ForceParent() -{ - vcl::Window* pWin=ImpGetViewWin(*pView); - if (pWin!=nullptr) SetParent(pWin); -} - -void SdrItemBrowser::SetDirty() -{ - if (!bDirty) { - bDirty = true; - aIdle.SetPriority(TaskPriority::HIGH_IDLE); - aIdle.Start(); - } -} - -void SdrItemBrowser::Undirty() -{ - aIdle.Stop(); - bDirty = false; - - SfxItemSet aSet(pView->GetModel()->GetItemPool()); - pView->GetAttributes(aSet); - - if(pView->AreObjectsMarked()) - { - SfxItemSet a2ndSet(pView->GetModel()->GetItemPool()); - pView->GetAttributes(a2ndSet, true); - - SetAttributes(&aSet,&a2ndSet); - } - else - { - SetAttributes(&aSet, nullptr); - } -} - -IMPL_LINK_NOARG(SdrItemBrowser, IdleHdl, Timer *, void) -{ - Undirty(); -} - -IMPL_LINK(SdrItemBrowser, ChangedHdl, SdrItemBrowserControl&, rBrowse, void) -{ - const ImpItemListRow* pEntry = rBrowse.GetCurrentChangeEntry(); - if (pEntry!=nullptr) - { - SfxItemSet aSet(pView->GetModel()->GetItemPool()); - pView->GetAttributes(aSet); - - SfxItemSet aNewSet(*aSet.GetPool(),{{pEntry->nWhichId,pEntry->nWhichId}}); - OUString aNewText(rBrowse.GetNewEntryValue()); - bool bDel( aNewText == "del" - || aNewText == "Del" - || aNewText == "DEL" - || aNewText == "default" - || aNewText == "Default" - || aNewText == "DEFAULT" ); - - if (!bDel) { - std::unique_ptr<SfxPoolItem> pNewItem(aSet.Get(pEntry->nWhichId).Clone()); - sal_Int32 nLongVal = aNewText.toInt32(); - if (pEntry->bCanNum) { - if (nLongVal>pEntry->nMax) nLongVal=pEntry->nMax; - if (nLongVal<pEntry->nMin) nLongVal=pEntry->nMin; - } - bool bPairX = true; - bool bPairY = false; - sal_uInt16 nSepLen=1; - long nLongX = aNewText.toInt32(); - long nLongY=0; - sal_Int32 nPos = aNewText.indexOf('/'); - if (nPos==-1) nPos=aNewText.indexOf(':'); - if (nPos==-1) nPos=aNewText.indexOf(' '); - if (nPos==-1) { nPos=aNewText.indexOf(".."); if (nPos!=-1) nSepLen=2; } - if (nPos!=01) - { - bPairX=nPos>0; - OUString s(aNewText.copy(nPos+nSepLen)); - bPairY = !aNewText.isEmpty(); - nLongY = s.toInt32(); - } - switch (pEntry->eItemType) { - case ItemType::BYTE : static_cast<SfxByteItem *>(pNewItem.get())->SetValue(static_cast<sal_uInt8>(nLongVal)); break; - case ItemType::INT16 : static_cast<SfxInt16Item *>(pNewItem.get())->SetValue(static_cast<sal_Int16>(nLongVal)); break; - case ItemType::UINT16: static_cast<SfxUInt16Item*>(pNewItem.get())->SetValue(static_cast<sal_uInt16>(nLongVal)); break; - case ItemType::INT32: { - if(dynamic_cast<const SdrAngleItem *>(pNewItem.get())) - { - aNewText = aNewText.replace(',', '.'); - double nVal = aNewText.toFloat(); - nLongVal = static_cast<sal_Int32>(nVal * 100.0 + 0.5); - } - static_cast<SfxInt32Item *>(pNewItem.get())->SetValue(nLongVal); - } break; - case ItemType::UINT32: static_cast<SfxUInt32Item*>(pNewItem.get())->SetValue(aNewText.toInt32()); break; - case ItemType::ENUM : static_cast<SfxEnumItemInterface*>(pNewItem.get())->SetEnumValue(static_cast<sal_uInt16>(nLongVal)); break; - case ItemType::BOOL: { - aNewText = aNewText.toAsciiUpperCase(); - if (aNewText == "TRUE") nLongVal=1; - if (aNewText == "JA") nLongVal=1; - if (aNewText == "AN") nLongVal=1; - if (aNewText == "EIN") nLongVal=1; - if (aNewText == "ON") nLongVal=1; - if (aNewText == "YES") nLongVal=1; - static_cast<SfxBoolItem*>(pNewItem.get())->SetValue(nLongVal == 1); - } break; - case ItemType::FLAG : static_cast<SfxFlagItem *>(pNewItem.get())->SetValue(static_cast<sal_uInt16>(nLongVal)); break; - case ItemType::STRING: static_cast<SfxStringItem*>(pNewItem.get())->SetValue(aNewText); break; - case ItemType::POINT : static_cast<SfxPointItem*>(pNewItem.get())->SetValue(Point(nLongX,nLongY)); break; - case ItemType::RECT : break; - case ItemType::RANGE : { - static_cast<SfxRangeItem*>(pNewItem.get())->From()=static_cast<sal_uInt16>(nLongX); - static_cast<SfxRangeItem*>(pNewItem.get())->From()=static_cast<sal_uInt16>(nLongY); - } break; - case ItemType::FRACTION: { - if (!bPairX) nLongX=1; - if (!bPairY) nLongY=1; - static_cast<SdrFractionItem*>(pNewItem.get())->SetValue(Fraction(nLongX,nLongY)); - } break; - case ItemType::XCOLOR: break; - case ItemType::COLOR: break; - case ItemType::FONT: { - static_cast<SvxFontItem*>(pNewItem.get())->SetFamily( FAMILY_DONTKNOW ); - static_cast<SvxFontItem*>(pNewItem.get())->SetFamilyName(aNewText); - static_cast<SvxFontItem*>(pNewItem.get())->SetStyleName(OUString()); - } break; - case ItemType::FONTHEIGHT: { - sal_uInt32 nHgt=0; - sal_uInt16 nProp=100; - if (aNewText.indexOf('%') != -1) { - nProp=static_cast<sal_uInt16>(nLongVal); - } else { - nHgt=static_cast<sal_uInt32>(nLongVal); - } - static_cast<SvxFontHeightItem*>(pNewItem.get())->SetHeight(nHgt,nProp); - } break; - case ItemType::FONTWIDTH: { - sal_uInt16 nProp=100; - if (aNewText.indexOf('%') != -1) { - nProp=static_cast<sal_uInt16>(nLongVal); - } - static_cast<SvxCharScaleWidthItem*>(pNewItem.get())->SetValue(nProp); - } break; - case ItemType::FIELD: break; - default: break; - } // switch - aNewSet.Put(*pNewItem); - } - pView->SetAttributes(aNewSet,bDel); - } -} - -IMPL_LINK_NOARG(SdrItemBrowser, SetDirtyHdl, SdrItemBrowserControl&, void) -{ - SetDirty(); -} - -/* vim:set shiftwidth=4 softtabstop=4 expandtab: */ diff --git a/svx/source/svdraw/svdmrkv.cxx b/svx/source/svdraw/svdmrkv.cxx index 6e357739727b..0be2473a44ca 100644 --- a/svx/source/svdraw/svdmrkv.cxx +++ b/svx/source/svdraw/svdmrkv.cxx @@ -27,10 +27,6 @@ #include <svx/svdotable.hxx> #include "svddrgm1.hxx" -#ifdef DBG_UTIL -#include <svdibrow.hxx> -#endif - #include <osl/thread.h> #include <svx/svdoole2.hxx> #include <svx/xgrad.hxx> @@ -2445,9 +2441,6 @@ void SdrMarkView::MarkListHasChanged() mbMarkedObjRectDirty=true; mbMarkedPointsRectsDirty=true; -#ifdef DBG_UTIL - if (mpItemBrowser!=nullptr) mpItemBrowser->SetDirty(); -#endif bool bOneEdgeMarked=false; if (GetMarkedObjectCount()==1) { const SdrObject* pObj=GetMarkedObjectByIndex(0); diff --git a/svx/source/svdraw/svdpntv.cxx b/svx/source/svdraw/svdpntv.cxx index ec2a3b1917c5..16123f23c22b 100644 --- a/svx/source/svdraw/svdpntv.cxx +++ b/svx/source/svdraw/svdpntv.cxx @@ -36,7 +36,6 @@ #include <svx/svdglue.hxx> #include <svx/svdobj.hxx> #include <svx/svdograf.hxx> -#include <svdibrow.hxx> #include <svx/svditer.hxx> #include <svx/svdouno.hxx> #include <svx/sdr/overlay/overlayobjectlist.hxx> @@ -134,9 +133,6 @@ BitmapEx convertMetafileToBitmapEx( void SdrPaintView::ImpClearVars() { -#ifdef DBG_UTIL - mpItemBrowser=nullptr; -#endif mbPageVisible=true; mbPageShadowVisible=true; mbPageBorderVisible=true; @@ -207,10 +203,6 @@ SdrPaintView::~SdrPaintView() maColorConfig.RemoveListener(this); ClearPageView(); -#ifdef DBG_UTIL - mpItemBrowser.disposeAndClear(); -#endif - // delete existing SdrPaintWindows maPaintWindows.clear(); } @@ -289,13 +281,6 @@ void SdrPaintView::ModelHasChanged() { mpPageView->ModelHasChanged(); } - -#ifdef DBG_UTIL - if(mpItemBrowser) - { - mpItemBrowser->SetDirty(); - } -#endif } @@ -421,11 +406,6 @@ void SdrPaintView::AddWindowToPaintView(OutputDevice* pNewWin, vcl::Window *pWin { mpPageView->AddPaintWindowToPageView(*pNewPaintWindow); } - -#ifdef DBG_UTIL - if (mpItemBrowser!=nullptr) - mpItemBrowser->ForceParent(); -#endif } void SdrPaintView::DeleteWindowFromPaintView(OutputDevice* pOldWin) @@ -442,11 +422,6 @@ void SdrPaintView::DeleteWindowFromPaintView(OutputDevice* pOldWin) DeletePaintWindow(*pCandidate); } - -#ifdef DBG_UTIL - if (mpItemBrowser!=nullptr) - mpItemBrowser->ForceParent(); -#endif } void SdrPaintView::SetLayerVisible(const OUString& rName, bool bShow) @@ -989,9 +964,6 @@ void SdrPaintView::SetDefaultAttr(const SfxItemSet& rAttr, bool bReplaceAll) if (bReplaceAll) maDefaultAttr.Set(rAttr); else maDefaultAttr.Put(rAttr,false); // if FALSE, regard InvalidItems as "holes," not as Default SetNotPersistDefaultAttr(rAttr); -#ifdef DBG_UTIL - if (mpItemBrowser!=nullptr) mpItemBrowser->SetDirty(); -#endif } void SdrPaintView::SetDefaultStyleSheet(SfxStyleSheet* pStyleSheet, bool bDontRemoveHardAttr) @@ -1012,9 +984,6 @@ void SdrPaintView::SetDefaultStyleSheet(SfxStyleSheet* pStyleSheet, bool bDontRe nWhich=aIter.NextWhich(); } } -#ifdef DBG_UTIL - if (mpItemBrowser!=nullptr) mpItemBrowser->SetDirty(); -#endif } void SdrPaintView::GetAttributes(SfxItemSet& rTargetSet, bool bOnlyHardAttr) const @@ -1047,25 +1016,6 @@ void SdrPaintView::SetStyleSheet(SfxStyleSheet* pStyleSheet, bool bDontRemoveHar SetDefaultStyleSheet(pStyleSheet,bDontRemoveHardAttr); } - -#ifdef DBG_UTIL -void SdrPaintView::ShowItemBrowser(bool bShow) -{ - if (bShow) { - if (mpItemBrowser==nullptr) { - mpItemBrowser=VclPtr<SdrItemBrowser>::Create(*static_cast<SdrView*>(this)); - } - mpItemBrowser->Show(); - mpItemBrowser->GrabFocus(); - } else { - if (mpItemBrowser!=nullptr) { - mpItemBrowser->Hide(); - mpItemBrowser.disposeAndClear(); - } - } -} -#endif - void SdrPaintView::MakeVisible(const tools::Rectangle& rRect, vcl::Window& rWin) { // TODO: handle when the text cursor goes out of the chart area @@ -1131,13 +1081,6 @@ void SdrPaintView::SetAnimationEnabled( bool bEnable ) SetAnimationMode( bEnable ? SdrAnimationMode::Animate : SdrAnimationMode::Disable ); } -#if defined DBG_UTIL -vcl::Window* SdrPaintView::GetItemBrowser() const -{ - return mpItemBrowser; -} -#endif - void SdrPaintView::SetAnimationPause( bool bSet ) { if(mbAnimationPause != bSet) diff --git a/svx/source/svdraw/svdview.cxx b/svx/source/svdraw/svdview.cxx index 76222cd30158..b7a74e21b4fd 100644 --- a/svx/source/svdraw/svdview.cxx +++ b/svx/source/svdraw/svdview.cxx @@ -31,10 +31,6 @@ #include <svx/svdomedia.hxx> #include <svx/svdetc.hxx> -#ifdef DBG_UTIL -#include <svdibrow.hxx> -#endif - #include <svx/svdoutl.hxx> #include <svx/svdview.hxx> #include <editeng/editview.hxx> @@ -1349,9 +1345,6 @@ void SdrView::MarkAll() { if (IsTextEdit()) { GetTextEditOutlinerView()->SetSelection(ESelection(0,0,EE_PARA_ALL,EE_TEXTPOS_ALL)); -#ifdef DBG_UTIL - if (mpItemBrowser!=nullptr) mpItemBrowser->SetDirty(); -#endif } else if (IsGluePointEditMode()) MarkAllGluePoints(); else if (HasMarkablePoints()) MarkAllPoints(); else MarkAllObj(); @@ -1364,9 +1357,6 @@ void SdrView::UnmarkAll() eSel.nStartPara=eSel.nEndPara; eSel.nStartPos=eSel.nEndPos; GetTextEditOutlinerView()->SetSelection(eSel); -#ifdef DBG_UTIL - if (mpItemBrowser!=nullptr) mpItemBrowser->SetDirty(); -#endif } else if (HasMarkedGluePoints()) UnmarkAllGluePoints(); else if (HasMarkedPoints()) UnmarkAllPoints(); // Marked, not Markable! else UnmarkAllObj(); |