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
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
|
/*************************************************************************
*
* 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: pivot.hxx,v $
* $Revision: 1.8 $
*
* 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.
*
************************************************************************/
/*
WICHTIG:
Folgende Reihenfolge beim Aufbau der Pivot-Tabelle unbedingt einzuhalten:
pPivot->SetColFields(aColArr, aColCount)
pPivot->SetRowFields(aRowArr, aRowCount)
pPivot->SetDataFields(aDataArr, aDataCount)
if (pPivot->CreateData())
{
pPivotDrawData();
pPivotReleaseData();
}
ausserdem ist sicherzustellen, dass entweder das ColArr oder das RowArr
einen PivotDataField Eintrag enthalten
*/
#ifndef SC_PIVOT_HXX
#define SC_PIVOT_HXX
#include "global.hxx"
#include "address.hxx"
#include <vector>
class SubTotal;
#include "collect.hxx"
#define PIVOT_DATA_FIELD (MAXCOLCOUNT)
#define PIVOT_FUNC_REF (MAXCOLCOUNT)
#include <com/sun/star/uno/Sequence.hxx>
#include <com/sun/star/sheet/DataPilotFieldReference.hpp>
#include <com/sun/star/sheet/DataPilotFieldSortInfo.hpp>
#include <com/sun/star/sheet/DataPilotFieldLayoutInfo.hpp>
#include <com/sun/star/sheet/DataPilotFieldAutoShowInfo.hpp>
#define PIVOT_STYLE_INNER 0
#define PIVOT_STYLE_RESULT 1
#define PIVOT_STYLE_CATEGORY 2
#define PIVOT_STYLE_TITLE 3
#define PIVOT_STYLE_FIELDNAME 4
#define PIVOT_STYLE_TOP 5
class SvStream;
class ScDocument;
class ScUserListData;
class ScMultipleReadHeader;
class ScMultipleWriteHeader;
class ScProgress;
struct LabelData;
// -----------------------------------------------------------------------
struct PivotField
{
SCsCOL nCol;
USHORT nFuncMask;
USHORT nFuncCount;
::com::sun::star::sheet::DataPilotFieldReference maFieldRef;
explicit PivotField( SCsCOL nNewCol = 0, USHORT nNewFuncMask = PIVOT_FUNC_NONE );
bool operator==( const PivotField& r ) const;
};
// -----------------------------------------------------------------------
// implementation still in global2.cxx
struct ScPivotParam
{
SCCOL nCol; // Cursor Position /
SCROW nRow; // bzw. Anfang des Zielbereiches
SCTAB nTab;
LabelData** ppLabelArr;
SCSIZE nLabels;
PivotField aPageArr[PIVOT_MAXPAGEFIELD];
PivotField aColArr[PIVOT_MAXFIELD];
PivotField aRowArr[PIVOT_MAXFIELD];
PivotField aDataArr[PIVOT_MAXFIELD];
SCSIZE nPageCount;
SCSIZE nColCount;
SCSIZE nRowCount;
SCSIZE nDataCount;
BOOL bIgnoreEmptyRows;
BOOL bDetectCategories;
BOOL bMakeTotalCol;
BOOL bMakeTotalRow;
ScPivotParam();
ScPivotParam( const ScPivotParam& r );
~ScPivotParam();
ScPivotParam& operator= ( const ScPivotParam& r );
BOOL operator== ( const ScPivotParam& r ) const;
void Clear ();
void ClearLabelData ();
void ClearPivotArrays();
void SetLabelData ( LabelData** ppLabArr,
SCSIZE nLab );
void SetPivotArrays ( const PivotField* pPageArr,
const PivotField* pColArr,
const PivotField* pRowArr,
const PivotField* pDataArr,
SCSIZE nPageCnt,
SCSIZE nColCnt,
SCSIZE nRowCnt,
SCSIZE nDataCnt );
};
// -----------------------------------------------------------------------
struct PivotColRef
{
SCSIZE nDataIndex;
SCSIZE nRecCount;
USHORT nFuncMask;
SCSIZE nIndex;
PivotColRef()
{
nDataIndex = nRecCount = nIndex = 0;
nFuncMask = PIVOT_FUNC_NONE;
}
};
typedef PivotField PivotFieldArr[PIVOT_MAXFIELD];
typedef PivotField PivotPageFieldArr[PIVOT_MAXPAGEFIELD];
class PivotStrCollection : public StrCollection
{
ScUserListData* pUserData;
public:
PivotStrCollection(USHORT nLim = 4, USHORT nDel = 4, BOOL bDup = FALSE) :
StrCollection ( nLim, nDel, bDup ),
pUserData (NULL) { }
PivotStrCollection(const PivotStrCollection& rPivotStrCollection) :
StrCollection ( rPivotStrCollection ),
pUserData ( rPivotStrCollection.pUserData) {}
virtual DataObject* Clone() const;
virtual short Compare(DataObject* pKey1, DataObject* pKey2) const;
TypedStrData* operator[]( const USHORT nIndex) const
{ return (TypedStrData*)At(nIndex); }
void SetUserData(ScUserListData* pData)
{ pUserData = pData; }
const String& GetString(USHORT nIndex)
{ return ((TypedStrData*)At(nIndex))->GetString(); }
USHORT GetIndex(TypedStrData* pData) const;
};
class ScPivot : public DataObject
{
ScDocument* pDoc;
ScQueryParam aQuery;
BOOL bHasHeader;
BOOL bIgnoreEmpty; // Flags aus Dialog
BOOL bDetectCat;
BOOL bMakeTotalCol;
BOOL bMakeTotalRow;
String aName;
String aTag;
SCSIZE nColNameCount;
String* pColNames; // Array
SCCOL nSrcCol1;
SCROW nSrcRow1;
SCCOL nSrcCol2;
SCROW nSrcRow2;
SCTAB nSrcTab;
SCCOL nDestCol1;
SCROW nDestRow1;
SCCOL nDestCol2;
SCROW nDestRow2;
SCTAB nDestTab;
SCCOL nDataStartCol;
SCROW nDataStartRow;
SCSIZE nColCount;
SCSIZE nRowCount;
SCSIZE nDataCount;
PivotFieldArr aColArr;
PivotFieldArr aRowArr;
PivotFieldArr aDataArr;
PivotStrCollection* pColList[PIVOT_MAXFIELD]; // pro Zeile alle Eintraege
PivotStrCollection* pRowList[PIVOT_MAXFIELD];
PivotStrCollection* pDataList; // Shortcut auf Col/RowList mit Daten
SubTotal** ppDataArr;
SCSIZE nDataColCount;
SCSIZE nDataRowCount;
SCSIZE nRowIndex;
SCSIZE nColIndex;
SCSIZE nDataIndex;
SCSIZE nRecCount;
PivotColRef* pColRef;
BOOL bValidArea;
BOOL bDataAtCol;
public:
ScPivot(ScDocument* pDocument);
ScPivot(const ScPivot& rPivot);
~ScPivot();
virtual DataObject* Clone() const;
ScPivot* CreateNew() const;
BOOL Load(SvStream& rStream, ScMultipleReadHeader& rHdr );
BOOL Store(SvStream& rStream, ScMultipleWriteHeader& rHdr ) const;
void SetQuery(const ScQueryParam& rQuery);
void GetQuery(ScQueryParam& rQuery) const;
void SetHeader(BOOL bHeader);
BOOL GetHeader() const;
void SetIgnoreEmpty(BOOL bIgnore);
BOOL GetIgnoreEmpty() const;
void SetDetectCat(BOOL bDetect);
BOOL GetDetectCat() const;
void SetMakeTotalCol(BOOL bSet);
BOOL GetMakeTotalCol() const;
void SetMakeTotalRow(BOOL bSet);
BOOL GetMakeTotalRow() const;
void SetName(const String& rNew);
const String& GetName() const;
void SetTag(const String& rNew);
const String& GetTag() const;
void SetSrcArea(SCCOL nCol1, SCROW nRow1, SCCOL nCol2, SCROW nRow2, SCTAB nTab);
void GetSrcArea(SCCOL& rCol1, SCROW& rRow1, SCCOL& rCol2, SCROW& rRow2, SCTAB& rTab) const;
ScRange GetSrcArea() const;
void SetDestPos(SCCOL nCol, SCROW nRow, SCTAB nTab);
void GetDestArea(SCCOL& rCol1, SCROW& rRow1, SCCOL& rCol2, SCROW& rRow2, SCTAB& rTab) const;
ScRange GetDestArea() const;
void SetColFields(const PivotField* pFieldArr, SCSIZE nCount);
void GetColFields(PivotField* pFieldArr, SCSIZE& rCount) const;
SCSIZE GetColFieldCount() const { return nColCount; }
void SetRowFields(const PivotField* pFieldArr, SCSIZE nCount);
void GetRowFields(PivotField* pFieldArr, SCSIZE& rCount) const;
SCSIZE GetRowFieldCount() const { return nRowCount; }
void SetDataFields(const PivotField* pFieldArr, SCSIZE nCount);
void GetDataFields(PivotField* pFieldArr, SCSIZE& rCount) const;
void GetParam( ScPivotParam& rParam, ScQueryParam& rQuery, ScArea& rSrcArea ) const;
void SetParam( const ScPivotParam& rParam, const ScQueryParam& rQuery,
const ScArea& rSrcArea );
BOOL CreateData(BOOL bKeepDest = FALSE);
void DrawData();
void ReleaseData();
BOOL IsPivotAtCursor(SCCOL nCol, SCROW nRow, SCTAB nTab) const;
BOOL IsFilterAtCursor(SCCOL nCol, SCROW nRow, SCTAB nTab) const;
BOOL GetColFieldAtCursor(SCCOL nCol, SCROW nRow, SCTAB nTab, SCCOL& rField) const;
BOOL GetRowFieldAtCursor(SCCOL nCol, SCROW nRow, SCTAB nTab, SCCOL& rField) const;
// Referenz-Anpassung:
void MoveSrcArea( SCCOL nNewCol, SCROW nNewRow, SCTAB nNewTab );
void MoveDestArea( SCCOL nNewCol, SCROW nNewRow, SCTAB nNewTab );
void ExtendSrcArea( SCCOL nNewEndCol, SCROW nNewEndRow );
private:
BOOL CreateFields();
void CreateFieldData();
void CalcArea();
void SetDataLine(SCCOL nCol, SCROW nRow, SCTAB nTab, SCSIZE nRIndex);
void SetFuncLine(SCCOL nCol, SCROW nRow, SCTAB nTab, USHORT nFunc, SCSIZE nIndex, SCSIZE nStartRIndex, SCSIZE nEndRIndex);
void ColToTable(SCSIZE nField, SCROW& nRow, ScProgress& rProgress);
void RowToTable(SCSIZE nField, SCCOL& nCol);
void SetFrame(SCCOL nCol1, SCROW nRow1, SCCOL nCol2, SCROW nRow2, USHORT nWidth = 20);
void SetFrameHor(SCCOL nCol1, SCROW nRow1, SCCOL nCol2, SCROW nRow2);
void SetFrameVer(SCCOL nCol1, SCROW nRow1, SCCOL nCol2, SCROW nRow2);
void SetFontBold(SCCOL nCol1, SCROW nRow1, SCCOL nCol2, SCROW nRow2);
void SetJustifyLeft(SCCOL nCol1, SCROW nRow1, SCCOL nCol2, SCROW nRow2);
void SetJustifyRight(SCCOL nCol1, SCROW nRow1, SCCOL nCol2, SCROW nRow2);
void SetStyle(SCCOL nCol1, SCROW nRow1, SCCOL nCol2, SCROW nRow2, USHORT nId);
void SetButton(SCCOL nCol1, SCROW nRow1, SCCOL nCol2, SCROW nRow2);
void SetValue(SCCOL nCol, SCROW nRow, const SubTotal& rTotal, USHORT nFunc);
SCROW GetCategoryRow( SCCOL nCol, SCROW nRow );
};
//------------------------------------------------------------------------
class ScPivotCollection : public Collection
{
private:
ScDocument* pDoc;
public:
ScPivotCollection(USHORT nLim = 4, USHORT nDel = 4, ScDocument* pDocument = NULL) :
Collection ( nLim, nDel),
pDoc ( pDocument ) {}
ScPivotCollection(const ScPivotCollection& rScPivotCollection) :
Collection ( rScPivotCollection ),
pDoc ( rScPivotCollection.pDoc ) {}
virtual DataObject* Clone() const;
ScPivot* operator[]( const USHORT nIndex) const {return (ScPivot*)At(nIndex);}
ScPivot* GetPivotAtCursor(SCCOL nCol, SCROW nRow, SCTAB nTab) const;
BOOL Load( SvStream& rStream );
BOOL Store( SvStream& rStream ) const;
void UpdateReference(UpdateRefMode eUpdateRefMode,
SCCOL nCol1, SCROW nRow1, SCTAB nTab1,
SCCOL nCol2, SCROW nRow2, SCTAB nTab2,
SCsCOL nDx, SCsROW nDy, SCsTAB nDz );
void UpdateGrow( const ScRange& rArea, SCCOL nGrowX, SCROW nGrowY );
BOOL operator==(const ScPivotCollection& rCmp) const;
String CreateNewName( USHORT nMin = 1 ) const;
};
//------------------------------------------------------------------------
struct LabelData
{
String maName; /// Visible name of the dimension.
SCsCOL mnCol;
USHORT mnFuncMask; /// Page/Column/Row subtotal function.
sal_Int32 mnUsedHier; /// Used hierarchy.
bool mbShowAll; /// true = Show all (also empty) results.
bool mbIsValue; /// true = Sum or count in data field.
::com::sun::star::uno::Sequence< ::rtl::OUString > maHiers; /// Hierarchies.
::com::sun::star::uno::Sequence< ::rtl::OUString > maMembers; /// Members.
::com::sun::star::uno::Sequence< sal_Bool > maVisible; /// Visibility of members.
::com::sun::star::uno::Sequence< sal_Bool > maShowDet; /// Show details of members.
::com::sun::star::sheet::DataPilotFieldSortInfo maSortInfo; /// Sorting info.
::com::sun::star::sheet::DataPilotFieldLayoutInfo maLayoutInfo; /// Layout info.
::com::sun::star::sheet::DataPilotFieldAutoShowInfo maShowInfo; /// AutoShow info.
explicit LabelData( const String& rName, short nCol, bool bIsValue );
};
// ============================================================================
struct ScDPFuncData
{
short mnCol;
USHORT mnFuncMask;
::com::sun::star::sheet::DataPilotFieldReference maFieldRef;
explicit ScDPFuncData( short nNewCol, USHORT nNewFuncMask );
explicit ScDPFuncData( short nNewCol, USHORT nNewFuncMask,
const ::com::sun::star::sheet::DataPilotFieldReference& rFieldRef );
};
// ============================================================================
typedef LabelData ScDPLabelData;
typedef std::vector< ScDPLabelData > ScDPLabelDataVec;
typedef std::vector< String > ScDPNameVec;
// ============================================================================
#endif
|