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
|
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE script:module PUBLIC "-//OpenOffice.org//DTD OfficeDocument 1.0//EN" "module.dtd">
<script:module xmlns:script="http://openoffice.org/2000/script" script:name="sc_ScDataPilotFieldObj" script:language="StarBasic">
'*************************************************************************
'
' DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
'
' Copyright 2000, 2010 Oracle and/or its affiliates.
'
' OpenOffice.org - a multi-platform office productivity suite
'
' 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.
'
'*************************************************************************
'*************************************************************************
' Be sure that all variables are dimensioned:
option explicit
' REQUIRED VARIABLES for interface/service tests:
' Requiered for com.sun.star.container.XNamed
Global cNameToSet As String ' "fixed" if name is fixed
Sub CreateObj()
'*************************************************************************
' COMPONENT:
' sc.ScDataPilotFieldObj
'*************************************************************************
On Error Goto ErrHndl
Dim oFields As Variant
Dim oSheet As Object
Dim i,j As Integer
Dim oDataPilotTable, oDataPilotDescriptor As Object
Dim sCellRangeAddress As New com.sun.star.table.CellRangeAddress
Dim sCellAddress As New com.sun.star.table.CellAddress
oDoc = utils.createDocument("scalc", cObjectName)
oSheet = oDoc.Sheets.getByIndex(0)
Out.Log("Filling a table...")
for i = 1 to 5
oSheet.getCellByPosition(0, i).String = "Row" & i
oSheet.getCellByPosition(i, 0).String = "Col" & i
next i
for i = 1 to 5
for j = 1 to 5
oSheet.getCellByPosition(i, j).Value = 2.5 * j + i
next j
next i
sCellRangeAddress.Sheet = 0
sCellRangeAddress.StartColumn = 0
sCellRangeAddress.StartRow = 0
sCellRangeAddress.EndColumn = 5
sCellRangeAddress.EndRow = 5
sCellAddress.Sheet = 0
sCellAddress.Column = 7
sCellAddress.Row = 8
oDataPilotTable = oSheet.getDataPilotTables
oDataPilotDescriptor = oDataPilotTable.createDataPilotDescriptor()
oDataPilotDescriptor.setSourceRange(sCellRangeAddress)
oDataPilotTable.insertNewByName(cObjectName, sCellAddress, oDataPilotDescriptor)
oFields = oDataPilotDescriptor.getDataPilotFields()
oObj = oFields.getByIndex(0)
cNameToSet = cObjectName
Exit Sub
ErrHndl:
Test.Exception()
End Sub
</script:module>
|