1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
|
/*************************************************************************
*
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* Copyright 2008 by Sun Microsystems, Inc.
*
* OpenOffice.org - a multi-platform office productivity suite
*
* $RCSfile: ScrollHelper.hxx,v $
* $Revision: 1.7 $
*
* This file is part of OpenOffice.org.
*
* OpenOffice.org is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License version 3
* only, as published by the Free Software Foundation.
*
* OpenOffice.org is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Lesser General Public License version 3 for more details
* (a copy is included in the LICENSE file that accompanied this code).
*
* You should have received a copy of the GNU Lesser General Public License
* version 3 along with OpenOffice.org. If not, see
* <http://www.openoffice.org/license.html>
* for a copy of the LGPLv3 License.
*
************************************************************************/
#ifndef RPTUI_SCROLLHELPER_HXX
#define RPTUI_SCROLLHELPER_HXX
#include <vcl/scrbar.hxx>
#include <com/sun/star/report/XSection.hpp>
#include <comphelper/propmultiplex.hxx>
#include "ReportDefines.hxx"
#include <svtools/colorcfg.hxx>
#include <svx/svdedtv.hxx>
#include "cppuhelper/basemutex.hxx"
#include <rtl/ref.hxx>
#include <boost/shared_ptr.hpp>
#include <vcl/dockwin.hxx>
#include <MarkedSection.hxx>
#include "ReportWindow.hxx"
class SdrView;
namespace rptui
{
class ODesignView;
class OReportWindow;
class OSectionView;
class OReportSection;
class OReportModel;
/** This class defines the scrollable area of the report design. It includes
the h-ruler and the sections, and end marker. Not the start marker.
*/
typedef Window OScrollWindowHelper_BASE;
class OScrollWindowHelper : public ::cppu::BaseMutex
, public OScrollWindowHelper_BASE/*TabPage*/
, public ::comphelper::OPropertyChangeListener
, public IMarkedSection
{
private:
ScrollBar m_aHScroll;
ScrollBar m_aVScroll;
ScrollBarBox m_aCornerWin; // window in the bottom right corner
Size m_aTotalPixelSize;
ODesignView* m_pParent;
OReportWindow m_aReportWindow;
::rtl::Reference<comphelper::OPropertyChangeMultiplexer >
m_pReportDefintionMultiPlexer; // listener for property changes
DECL_LINK( ScrollHdl, ScrollBar*);
Size ResizeScrollBars();
void ImplInitSettings();
void impl_initScrollBar( ScrollBar& _rScrollBar ) const;
OScrollWindowHelper(OScrollWindowHelper&);
void operator =(OScrollWindowHelper&);
protected:
virtual void DataChanged( const DataChangedEvent& rDCEvt );
// window
virtual void Resize();
virtual long Notify( NotifyEvent& rNEvt );
// OPropertyChangeListener
virtual void _propertyChanged(const ::com::sun::star::beans::PropertyChangeEvent& _rEvent) throw( ::com::sun::star::uno::RuntimeException);
public:
OScrollWindowHelper( ODesignView* _pReportDesignView);
virtual ~OScrollWindowHelper();
/** late ctor
*/
void initialize();
inline Point getThumbPos() const { return Point(m_aHScroll.GetThumbPos(),m_aVScroll.GetThumbPos())/*m_aScrollOffset*/; }
inline const OReportWindow& getReportWindow() const { return m_aReportWindow; }
void setTotalSize(sal_Int32 _nWidth ,sal_Int32 _nHeight);
inline Size getTotalSize() const { return m_aTotalPixelSize; }
inline ScrollBar* GetHScroll() { return &m_aHScroll; }
inline ScrollBar* GetVScroll() { return &m_aVScroll; }
// forwards
void SetMode( DlgEdMode _eMode );
void SetInsertObj( USHORT eObj,const ::rtl::OUString& _sShapeType = ::rtl::OUString());
rtl::OUString GetInsertObjString() const;
void setGridSnap(BOOL bOn);
void setDragStripes(BOOL bOn);
BOOL isDragStripes() const;
/** copies the current selection in this section
*/
void Copy();
/** returns if paste is allowed
*
* \return <TRUE/> if paste is allowed
*/
BOOL IsPasteAllowed();
/** paste a new control in this section
*/
void Paste();
/** Deletes the current selection in this section
*
*/
void Delete();
/** All objects will be marked.
*/
void SelectAll(const sal_uInt16 _nObjectType);
/** returns <TRUE/> when a object is marked
*/
BOOL HasSelection();
/** removes the section at the given position.
*
* \param _nPosition Zero based.
*/
void removeSection(USHORT _nPosition);
/** adds a new section at position _nPosition.
If the section is <NULL/> nothing happens.
If the position is grater than the current elements, the section will be appended.
*/
void addSection(const ::com::sun::star::uno::Reference< ::com::sun::star::report::XSection >& _xSection
,const ::rtl::OUString& _sColorEntry
,USHORT _nPosition = USHRT_MAX);
USHORT getSectionCount() const;
/** turns the grid on or off
*
* \param _bVisible
*/
void toggleGrid(sal_Bool _bVisible);
/** unmark all objects on the views without the given one.
*
* @param _pSectionView The view where the objects should not be unmarked.
*/
void unmarkAllObjects(OSectionView* _pSectionView);
/** shows or hides the ruler.
*/
void showRuler(sal_Bool _bShow);
/** calculate the max width of the markers
*
* @param _bWithEnd if <TRUE/> the end marker will be used for calculation as well otherwise not.
* \return the max width
*/
sal_Int32 getMaxMarkerWidth(sal_Bool _bWithEnd) const;
/** checks if the keycode is known by the child windows
@param _rCode the keycode
@return <TRUE/> if the keycode is handled otherwise <FALSE/>
*/
sal_Bool handleKeyEvent(const KeyEvent& _rEvent);
/** the the section as marked or not marked
@param _pSectionView the section where to set the marked flag
@param _bMark the marked flag
*/
void setMarked(OSectionView* _pSectionView,sal_Bool _bMark);
void setMarked(const ::com::sun::star::uno::Reference< ::com::sun::star::report::XSection>& _xSection,sal_Bool _bMark);
void setMarked(const ::com::sun::star::uno::Sequence< ::com::sun::star::uno::Reference< ::com::sun::star::report::XReportComponent> >& _xShape,sal_Bool _bMark);
// IMarkedSection
::boost::shared_ptr<OSectionWindow> getMarkedSection(NearSectionAccess nsa = CURRENT) const;
::boost::shared_ptr<OSectionWindow> getSectionWindow(const ::com::sun::star::uno::Reference< ::com::sun::star::report::XSection>& _xSection) const;
virtual void markSection(const sal_uInt16 _nPos);
/** fills the positions of all collapsed sections.
*
* \param _rCollapsedPositions Out parameter which holds afterwards all positions of the collapsed sections.
*/
void fillCollapsedSections(::std::vector<sal_uInt16>& _rCollapsedPositions) const;
/** collpase all sections given by their position
*
* \param _aCollpasedSections The position of the sections which should be collapsed.
*/
void collapseSections(const com::sun::star::uno::Sequence< ::com::sun::star::beans::PropertyValue>& _aCollpasedSections);
/** align all marked objects in all sections
*
* \param eHor
* \param eVert
* \param bBoundRects
*/
void alignMarkedObjects(sal_Int32 _nControlModification, bool _bAlignAtSection, bool bBoundRects = false);
sal_uInt32 getMarkedObjectCount() const;
/** zoom the ruler and view windows
*/
void zoom(const Fraction& _aZoom);
/** fills the vector with all selected control models
/param _rSelection The vector will be filled and will not be cleared before.
*/
void fillControlModelSelection(::std::vector< ::com::sun::star::uno::Reference< ::com::sun::star::uno::XInterface > >& _rSelection) const;
/** calculates the zoom factor.
@param _eType which kind of zoom is needed
*/
sal_uInt16 getZoomFactor(SvxZoomType _eType) const;
};
}
#endif // RPTUI_SCROLLHELPER_HXX
|