1*cdf0e10cSrcweir<?xml version="1.0" encoding="UTF-8"?>
2*cdf0e10cSrcweir<!DOCTYPE script:module PUBLIC "-//OpenOffice.org//DTD OfficeDocument 1.0//EN" "module.dtd">
3*cdf0e10cSrcweir<script:module xmlns:script="http://openoffice.org/2000/script" script:name="sc_ScDataPilotTableObj" script:language="StarBasic">
4*cdf0e10cSrcweir
5*cdf0e10cSrcweir
6*cdf0e10cSrcweir'*************************************************************************
7*cdf0e10cSrcweir'
8*cdf0e10cSrcweir' DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
9*cdf0e10cSrcweir'
10*cdf0e10cSrcweir' Copyright 2000, 2010 Oracle and/or its affiliates.
11*cdf0e10cSrcweir'
12*cdf0e10cSrcweir' OpenOffice.org - a multi-platform office productivity suite
13*cdf0e10cSrcweir'
14*cdf0e10cSrcweir' This file is part of OpenOffice.org.
15*cdf0e10cSrcweir'
16*cdf0e10cSrcweir' OpenOffice.org is free software: you can redistribute it and/or modify
17*cdf0e10cSrcweir' it under the terms of the GNU Lesser General Public License version 3
18*cdf0e10cSrcweir' only, as published by the Free Software Foundation.
19*cdf0e10cSrcweir'
20*cdf0e10cSrcweir' OpenOffice.org is distributed in the hope that it will be useful,
21*cdf0e10cSrcweir' but WITHOUT ANY WARRANTY; without even the implied warranty of
22*cdf0e10cSrcweir' MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
23*cdf0e10cSrcweir' GNU Lesser General Public License version 3 for more details
24*cdf0e10cSrcweir' (a copy is included in the LICENSE file that accompanied this code).
25*cdf0e10cSrcweir'
26*cdf0e10cSrcweir' You should have received a copy of the GNU Lesser General Public License
27*cdf0e10cSrcweir' version 3 along with OpenOffice.org.  If not, see
28*cdf0e10cSrcweir' <http://www.openoffice.org/license.html>
29*cdf0e10cSrcweir' for a copy of the LGPLv3 License.
30*cdf0e10cSrcweir'
31*cdf0e10cSrcweir'*************************************************************************
32*cdf0e10cSrcweir'*************************************************************************
33*cdf0e10cSrcweir
34*cdf0e10cSrcweir
35*cdf0e10cSrcweir
36*cdf0e10cSrcweir' Be sure that all variables are dimensioned:
37*cdf0e10cSrcweiroption explicit
38*cdf0e10cSrcweir
39*cdf0e10cSrcweir
40*cdf0e10cSrcweir' REQUIRED VARIABLES for interface/service tests:
41*cdf0e10cSrcweir
42*cdf0e10cSrcweir' Requiered for com.sun.star.container.XNamed
43*cdf0e10cSrcweirGlobal cNameToSet As String ' "fixed" if name is fixed
44*cdf0e10cSrcweir
45*cdf0e10cSrcweir' Required for com.sun.star.sheet.XDataPilotTable
46*cdf0e10cSrcweirGlobal oOutputRange As Variant
47*cdf0e10cSrcweir
48*cdf0e10cSrcweir
49*cdf0e10cSrcweirSub CreateObj()
50*cdf0e10cSrcweir
51*cdf0e10cSrcweir'*************************************************************************
52*cdf0e10cSrcweir' COMPONENT:
53*cdf0e10cSrcweir' sc.ScDataPilotTableObj
54*cdf0e10cSrcweir'*************************************************************************
55*cdf0e10cSrcweirOn Error Goto ErrHndl
56*cdf0e10cSrcweir    Dim oSheet As Object
57*cdf0e10cSrcweir    Dim i, j As Integer
58*cdf0e10cSrcweir    Dim oDataPilotTables As Object
59*cdf0e10cSrcweir    Dim oDataPilotDescriptor As Object
60*cdf0e10cSrcweir    Dim oFilterDescriptor As Object
61*cdf0e10cSrcweir    Dim oDataPilotField As Object
62*cdf0e10cSrcweir
63*cdf0e10cSrcweir    oDoc = utils.createDocument("scalc", cObjectName)
64*cdf0e10cSrcweir    oSheet = oDoc.Sheets.getByIndex(0)
65*cdf0e10cSrcweir
66*cdf0e10cSrcweir    for i = 1 to 5
67*cdf0e10cSrcweir    	oSheet.getCellByPosition(0, i).String = "Row" &amp; i
68*cdf0e10cSrcweir    	oSheet.getCellByPosition(i, 0).String = "Col" &amp; i
69*cdf0e10cSrcweir    next i
70*cdf0e10cSrcweir
71*cdf0e10cSrcweir    for i = 1 to 5
72*cdf0e10cSrcweir        for j = 1 to 5
73*cdf0e10cSrcweir            oSheet.getCellByPosition(i, j).Value = 2.5 * j + i
74*cdf0e10cSrcweir        next j
75*cdf0e10cSrcweir    next i
76*cdf0e10cSrcweir
77*cdf0e10cSrcweir    Dim sCellRangeAddress As New com.sun.star.table.CellRangeAddress
78*cdf0e10cSrcweir    sCellRangeAddress.Sheet = 0
79*cdf0e10cSrcweir    sCellRangeAddress.StartColumn = 1
80*cdf0e10cSrcweir    sCellRangeAddress.StartRow = 0
81*cdf0e10cSrcweir    sCellRangeAddress.EndColumn = 1
82*cdf0e10cSrcweir    sCellRangeAddress.EndRow = 5
83*cdf0e10cSrcweir
84*cdf0e10cSrcweir    Dim sCellAddress As New com.sun.star.table.CellAddress
85*cdf0e10cSrcweir    sCellAddress.Sheet = 0
86*cdf0e10cSrcweir    sCellAddress.Column = 7
87*cdf0e10cSrcweir    sCellAddress.Row = 8
88*cdf0e10cSrcweir
89*cdf0e10cSrcweir    Dim FilterFields(1) As New com.sun.star.sheet.TableFilterField
90*cdf0e10cSrcweir    FilterFields(0).Connection = com.sun.star.sheet.FilterConnection.AND
91*cdf0e10cSrcweir    FilterFields(0).Field = 1
92*cdf0e10cSrcweir    FilterFields(0).isNumeric = true
93*cdf0e10cSrcweir    FilterFields(0).StringValue = "4"
94*cdf0e10cSrcweir    FilterFields(0).Operator = com.sun.star.sheet.FilterOperator.GREATER
95*cdf0e10cSrcweir
96*cdf0e10cSrcweir    FilterFields(1).Connection = com.sun.star.sheet.FilterConnection.AND
97*cdf0e10cSrcweir    FilterFields(1).Field = 1
98*cdf0e10cSrcweir    FilterFields(1).isNumeric = true
99*cdf0e10cSrcweir    FilterFields(1).StringValue = "12"
100*cdf0e10cSrcweir    FilterFields(1).Operator = com.sun.star.sheet.FilterOperator.LESS_EQUAL
101*cdf0e10cSrcweir
102*cdf0e10cSrcweir    oDataPilotTables = oSheet.getDataPilotTables
103*cdf0e10cSrcweir    oDataPilotDescriptor = oDataPilotTables.createDataPilotDescriptor()
104*cdf0e10cSrcweir    oDataPilotDescriptor.setSourceRange(sCellRangeAddress)
105*cdf0e10cSrcweir    oFilterDescriptor = oDataPilotDescriptor.getFilterDescriptor()
106*cdf0e10cSrcweir    oFilterDescriptor.setFilterFields(FilterFields())
107*cdf0e10cSrcweir
108*cdf0e10cSrcweir    oDataPilotField = oDataPilotDescriptor.getDataPilotFields().getByIndex(0)
109*cdf0e10cSrcweir    oDataPilotField.Function = com.sun.star.sheet.GeneralFunction.SUM
110*cdf0e10cSrcweir    oDataPilotField.Orientation = com.sun.star.sheet.DataPilotFieldOrientation.DATA
111*cdf0e10cSrcweir
112*cdf0e10cSrcweir    oDataPilotTables.insertNewByName(cObjectName, sCellAddress, oDataPilotDescriptor)
113*cdf0e10cSrcweir
114*cdf0e10cSrcweir    oObj = oDataPilotTables(0)
115*cdf0e10cSrcweir    oOutputRange = sCellAddress
116*cdf0e10cSrcweir
117*cdf0e10cSrcweirExit Sub
118*cdf0e10cSrcweirErrHndl:
119*cdf0e10cSrcweir    Test.Exception()
120*cdf0e10cSrcweirEnd Sub
121*cdf0e10cSrcweir
122*cdf0e10cSrcweir</script:module>
123