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
234
235
236
237
238
239
240
241
242
|
/*************************************************************************
*
* 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: ReportWindow.hxx,v $
* $Revision: 1.6 $
*
* 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_REPORT_WINDOW_HXX
#define RPTUI_REPORT_WINDOW_HXX
#include <com/sun/star/report/XSection.hpp>
#include "ReportDefines.hxx"
#include "StartMarker.hxx"
#include <svtools/ruler.hxx>
#include <svx/svdedtv.hxx>
#include <svx/zoomitem.hxx>
#include <vector>
#include <boost/shared_ptr.hpp>
#include <MarkedSection.hxx>
#include "ViewsWindow.hxx"
class Splitter;
namespace rptui
{
class ODesignView;
class OReportSection;
class OScrollWindowHelper;
class OSectionView;
class OReportModel;
class OEndMarker;
class OReportPage;
class DlgEdFunc;
class DlgEdFactory;
class OReportWindow : public Window, public IMarkedSection
{
Ruler m_aHRuler;
ODesignView* m_pView;
OScrollWindowHelper* m_pParent;
OViewsWindow m_aViewsWindow;
::std::auto_ptr<DlgEdFactory>
m_pObjFac;
void ImplInitSettings();
sal_Int32 GetTotalHeight() const;
sal_Int32 impl_getRealPixelWidth() const;
OReportWindow(OReportWindow&);
void operator =(OReportWindow&);
protected:
virtual void DataChanged( const DataChangedEvent& rDCEvt );
public:
OReportWindow(OScrollWindowHelper* _pParent,ODesignView* _pView);
virtual ~OReportWindow();
/** late ctor
*/
void initialize();
// WINDOW overloads
virtual void Resize();
inline ODesignView* getReportView() const { return m_pView; }
inline OScrollWindowHelper* getScrollWindow() const { return m_pParent; }
void SetMode( DlgEdMode m_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();
Point getThumbPos() const;
/** 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);
/** shows the ruler
*/
void showRuler(sal_Bool _bShow);
inline sal_Int32 getRulerHeight() const { return m_aHRuler.GetSizePixel().Height(); }
/** returns the total width of the first section
*/
sal_Int32 GetTotalWidth() const;
/** 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;
void ScrollChildren(const Point& _aThumbPos);
void notifySizeChanged();
/** 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);
/** triggers the property browser with the report component or section
@param _xReportComponent
*/
void showProperties( const ::com::sun::star::uno::Reference< ::com::sun::star::report::XSection>& _xReportComponent);
/** 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;
};
//==================================================================
} //rptui
//==================================================================
#endif // RPTUI_REPORT_WINDOW_HXX
|