1<?xml version="1.0" encoding="UTF-8"?>
2<!DOCTYPE script:module PUBLIC "-//OpenOffice.org//DTD OfficeDocument 1.0//EN" "module.dtd">
3<script:module xmlns:script="http://openoffice.org/2000/script" script:name="sc_ScDataPilotFieldObj" script:language="StarBasic">
4
5
6'*************************************************************************
7'
8'  Licensed to the Apache Software Foundation (ASF) under one
9'  or more contributor license agreements.  See the NOTICE file
10'  distributed with this work for additional information
11'  regarding copyright ownership.  The ASF licenses this file
12'  to you under the Apache License, Version 2.0 (the
13'  "License"); you may not use this file except in compliance
14'  with the License.  You may obtain a copy of the License at
15'
16'    http://www.apache.org/licenses/LICENSE-2.0
17'
18'  Unless required by applicable law or agreed to in writing,
19'  software distributed under the License is distributed on an
20'  "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
21'  KIND, either express or implied.  See the License for the
22'  specific language governing permissions and limitations
23'  under the License.
24'
25'*************************************************************************
26
27
28
29
30
31' Be sure that all variables are dimensioned:
32option explicit
33
34
35' REQUIRED VARIABLES for interface/service tests:
36
37' Requiered for  com.sun.star.container.XNamed
38 Global cNameToSet As String ' "fixed" if name is fixed
39
40
41Sub CreateObj()
42
43'*************************************************************************
44' COMPONENT:
45' sc.ScDataPilotFieldObj
46'*************************************************************************
47On Error Goto ErrHndl
48    Dim oFields As Variant
49    Dim oSheet As Object
50    Dim i,j As Integer
51    Dim oDataPilotTable, oDataPilotDescriptor As Object
52    Dim sCellRangeAddress As New com.sun.star.table.CellRangeAddress
53    Dim sCellAddress As New com.sun.star.table.CellAddress
54
55
56    oDoc = utils.createDocument("scalc", cObjectName)
57    oSheet = oDoc.Sheets.getByIndex(0)
58    Out.Log("Filling a table...")
59
60    for i = 1 to 5
61        oSheet.getCellByPosition(0, i).String = "Row" &amp; i
62        oSheet.getCellByPosition(i, 0).String = "Col" &amp; i
63    next i
64
65    for i = 1 to 5
66        for j = 1 to 5
67            oSheet.getCellByPosition(i, j).Value = 2.5 * j + i
68        next j
69    next i
70
71    sCellRangeAddress.Sheet = 0
72    sCellRangeAddress.StartColumn = 0
73    sCellRangeAddress.StartRow = 0
74    sCellRangeAddress.EndColumn = 5
75    sCellRangeAddress.EndRow = 5
76
77    sCellAddress.Sheet = 0
78    sCellAddress.Column = 7
79    sCellAddress.Row = 8
80
81    oDataPilotTable = oSheet.getDataPilotTables
82    oDataPilotDescriptor = oDataPilotTable.createDataPilotDescriptor()
83    oDataPilotDescriptor.setSourceRange(sCellRangeAddress)
84    oDataPilotTable.insertNewByName(cObjectName, sCellAddress, oDataPilotDescriptor)
85
86    oFields = oDataPilotDescriptor.getDataPilotFields()
87    oObj = oFields.getByIndex(0)
88
89    cNameToSet = cObjectName
90
91Exit Sub
92ErrHndl:
93    Test.Exception()
94End Sub
95</script:module>
96