1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
3 * This file is part of the LibreOffice project.
5 * This Source Code Form is subject to the terms of the Mozilla Public
6 * License, v. 2.0. If a copy of the MPL was not distributed with this
7 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
9 * This file incorporates work covered by the following license notice:
11 * Licensed to the Apache Software Foundation (ASF) under one or more
12 * contributor license agreements. See the NOTICE file distributed
13 * with this work for additional information regarding copyright
14 * ownership. The ASF licenses this file to you under the Apache
15 * License, Version 2.0 (the "License"); you may not use this file
16 * except in compliance with the License. You may obtain a copy of
17 * the License at http://www.apache.org/licenses/LICENSE-2.0 .
20 #ifndef INCLUDED_SVX_SVDPAGV_HXX
21 #define INCLUDED_SVX_SVDPAGV_HXX
23 #include <com/sun/star/awt/XControlContainer.hpp>
24 #include <rtl/ustring.hxx>
25 #include <tools/color.hxx>
26 #include <svx/svdhlpln.hxx>
27 #include <svx/svdsob.hxx>
28 #include <svx/svdtypes.hxx>
29 #include <svx/svxdllapi.h>
33 #include <basegfx/range/b2irectangle.hxx>
36 namespace vcl
{ class Region
; }
50 class ViewObjectContactRedirector
;
52 class ViewObjectContactRedirector
;
53 } // end of namespace contact
54 } // end of namespace sdr
56 // typedefs for a list of SdrPageWindow
60 class SVX_DLLPUBLIC SdrPageView
65 Point aPgOrg
; // The Page's point of origin
67 tools::Rectangle aMarkBound
;
68 tools::Rectangle aMarkSnap
;
72 SdrLayerIDSet aLayerVisi
; // Set of visible Layers
73 SdrLayerIDSet aLayerLock
; // Set of non-editable Layers
74 SdrLayerIDSet aLayerPrn
; // Set of printable Layers
76 SdrObjList
* pCurrentList
; // Current List, usually the Page
77 SdrObject
* pCurrentGroup
; // Current Group; nullptr means none
79 SdrHelpLineList aHelpLines
; // Helper lines and points
81 // #103911# Use one reserved slot (bReserveBool2) for the document color
82 Color maDocumentColor
;
84 // #103834# Use one reserved slot (bReserveBool1) for the background color
85 Color maBackgroundColor
;
87 std::vector
< std::unique_ptr
<SdrPageWindow
> > maPageWindows
;
89 // #i72752# member to remember with which SdrPageWindow the BeginDrawLayer
91 SdrPageWindow
* mpPreparedPageWindow
;
93 // interface to SdrPageWindow
94 void ClearPageWindows();
96 sal_uInt32
PageWindowCount() const { return maPageWindows
.size(); }
97 SdrPageWindow
* FindPageWindow( SdrPaintWindow
& rPaintWindow
) const;
98 SdrPageWindow
* FindPageWindow( const OutputDevice
& rOutDev
) const;
99 SdrPageWindow
* GetPageWindow(sal_uInt32 nIndex
) const;
102 * Finds the page window whose PaintWindow belongs to the given output device
103 * In opposite to FindPageWindow, this method also cares possibly patched PaintWindow instances.
104 * That is, a SdrPageWindow might have an original, and a patched SdrPaintWindow instance - if
105 * this is the case, then the original SdrPaintWindow is examined before the patched one.
107 const SdrPageWindow
* FindPatchedPageWindow( const OutputDevice
& rOutDev
) const;
110 void ImpInvalidateHelpLineArea(sal_uInt16 nNum
) const;
112 void SetLayer(const OUString
& rName
, SdrLayerIDSet
& rBS
, bool bJa
);
113 bool IsLayer(const OUString
& rName
, const SdrLayerIDSet
& rBS
) const;
115 /// Let's see if the current Group (pCurrentGroup) is still inserted
116 void CheckCurrentGroup();
121 SdrPageView(SdrPage
* pPage1
, SdrView
& rNewView
);
124 SdrPageView
& operator=( SdrPageView
const & ) = delete; // MSVC2017 workaround
125 SdrPageView( SdrPageView
const & ) = delete; // MSVC2017 workaround
128 /// Is called by PaintView, when modal changes have finished
129 void ModelHasChanged();
134 void AddPaintWindowToPageView(SdrPaintWindow
& rPaintWindow
);
135 void RemovePaintWindowFromPageView(SdrPaintWindow
& rPaintWindow
);
137 SdrView
& GetView() { return mrView
; }
138 const SdrView
& GetView() const { return mrView
; }
141 * Looks up the control container belonging to given output device
143 * If the given output device belongs to one of the SdrPageViewWinRecs associated with this
144 * SdrPageView instance, the XControlContainer for this output device is returned, <NULL/>
147 css::uno::Reference
< css::awt::XControlContainer
>
148 GetControlContainer( const OutputDevice
& _rDevice
) const;
150 /// Sets all elements in the view which support a design and an alive mode into the given mode
151 void SetDesignMode( bool _bDesignMode
) const;
153 bool IsVisible() const { return mbVisible
; }
155 /// Invalidates the Page's whole area
156 void InvalidateAllWin();
158 /// PrePaint call forwarded from app windows
161 /// @param rReg refers to the OutDev and not to the Page
162 void CompleteRedraw( SdrPaintWindow
& rPaintWindow
, const vcl::Region
& rReg
, sdr::contact::ViewObjectContactRedirector
* pRedirector
);
164 /// Write access to mpPreparedPageWindow
165 void setPreparedPageWindow(SdrPageWindow
* pKnownTarget
);
167 void DrawLayer(SdrLayerID nID
, OutputDevice
* pGivenTarget
, sdr::contact::ViewObjectContactRedirector
* pRedirector
= nullptr,
168 const tools::Rectangle
& rRect
= tools::Rectangle(),
169 basegfx::B2IRectangle
const* pPageFrame
= nullptr);
170 void DrawPageViewGrid(OutputDevice
& rOut
, const tools::Rectangle
& rRect
, Color aColor
= COL_BLACK
);
172 tools::Rectangle
GetPageRect() const;
173 SdrPage
* GetPage() const { return mpPage
; }
175 /// Return current List
176 SdrObjList
* GetObjList() const { return pCurrentList
; }
178 /// Return current Group
179 SdrObject
* GetCurrentGroup() const { return pCurrentGroup
; }
181 /// Set current Group and List
182 void SetCurrentGroupAndList(SdrObject
* pNewGroup
, SdrObjList
* pNewList
);
184 bool HasMarkedObjPageView() const { return mbHasMarked
; }
185 void SetHasMarkedObj(bool bOn
) { mbHasMarked
= bOn
; }
187 const tools::Rectangle
& MarkBound() const { return aMarkBound
; }
188 const tools::Rectangle
& MarkSnap() const { return aMarkSnap
; }
189 tools::Rectangle
& MarkBound() { return aMarkBound
; }
190 tools::Rectangle
& MarkSnap() { return aMarkSnap
; }
192 void SetLayerVisible(const OUString
& rName
, bool bShow
) {
193 SetLayer(rName
, aLayerVisi
, bShow
);
197 bool IsLayerVisible(const OUString
& rName
) const { return IsLayer(rName
, aLayerVisi
); }
199 void SetLayerLocked(const OUString
& rName
, bool bLock
) { SetLayer(rName
, aLayerLock
, bLock
); if(bLock
) AdjHdl(); }
200 bool IsLayerLocked(const OUString
& rName
) const { return IsLayer(rName
,aLayerLock
); }
202 void SetLayerPrintable(const OUString
& rName
, bool bPrn
) { SetLayer(rName
, aLayerPrn
, bPrn
); }
203 bool IsLayerPrintable(const OUString
& rName
) const { return IsLayer(rName
, aLayerPrn
); }
205 /// PV represents a RefPage or a SubList of a RefObj, or the Model is ReadOnly
206 bool IsReadOnly() const;
208 /// The Origin always refers to the upper left corner of the Page
209 const Point
& GetPageOrigin() const { return aPgOrg
; }
210 void SetPageOrigin(const Point
& rOrg
);
212 void LogicToPagePos(Point
& rPnt
) const { rPnt
-=aPgOrg
; }
213 void LogicToPagePos(tools::Rectangle
& rRect
) const { rRect
.Move(-aPgOrg
.X(),-aPgOrg
.Y()); }
214 void PagePosToLogic(Point
& rPnt
) const { rPnt
+=aPgOrg
; }
216 void SetVisibleLayers(const SdrLayerIDSet
& rSet
) { aLayerVisi
=rSet
; }
217 const SdrLayerIDSet
& GetVisibleLayers() const { return aLayerVisi
; }
218 void SetPrintableLayers(const SdrLayerIDSet
& rSet
) { aLayerPrn
=rSet
; }
219 const SdrLayerIDSet
& GetPrintableLayers() const { return aLayerPrn
; }
220 void SetLockedLayers(const SdrLayerIDSet
& rSet
) { aLayerLock
=rSet
; }
221 const SdrLayerIDSet
& GetLockedLayers() const { return aLayerLock
; }
223 const SdrHelpLineList
& GetHelpLines() const { return aHelpLines
; }
224 void SetHelpLines(const SdrHelpLineList
& rHLL
);
225 //void SetHelpLinePos(sal_uInt16 nNum, const Point& rNewPos);
226 void SetHelpLine(sal_uInt16 nNum
, const SdrHelpLine
& rNewHelpLine
);
227 void DeleteHelpLine(sal_uInt16 nNum
);
228 void InsertHelpLine(const SdrHelpLine
& rHL
);
230 /// At least one member must be visible for the Group object and
231 /// it must not be locked
233 /// true, if the object's layer is visible and not locked
234 bool IsObjMarkable(SdrObject
const * pObj
) const;
236 /// Entering (editing) an object group
237 /// After that, we have direct access to all member objects of the group.
238 /// All other objects are not editable in the meantime (until the next
240 bool EnterGroup(SdrObject
* pObj
);
242 /// Leave an object group we entered previously
243 void LeaveOneGroup();
245 /// Leave all object groups we entered previously
246 void LeaveAllGroup();
248 /// Determine, how deep we descended (0 = Root(Page))
249 sal_uInt16
GetEnteredLevel() const;
251 // #103834# Set background color for svx at SdrPageViews
252 void SetApplicationBackgroundColor(Color aBackgroundColor
);
254 const Color
& GetApplicationBackgroundColor() const { return maBackgroundColor
;}
256 // #103911# Set/Get document color for svx at SdrPageViews
257 void SetApplicationDocumentColor(Color aDocumentColor
);
258 const Color
& GetApplicationDocumentColor() const { return maDocumentColor
;}
262 #endif // INCLUDED_SVX_SVDPAGV_HXX
264 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */