import com.sun.star.sheet.DataPilotFieldFilter; /************************************************************************* * * The Contents of this file are made available subject to the terms of * the BSD license. * * Copyright 2000, 2010 Oracle and/or its affiliates. * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * 3. Neither the name of Sun Microsystems, Inc. nor the names of its * contributors may be used to endorse or promote products derived * from this software without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR * TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE * USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * *************************************************************************/ // Example DataPilot source component // helper class to hold the settings class ExampleSettings { public static final int nDimensionCount = 6; public static final int nValueDimension = 4; public static final int nDataDimension = 5; public static final String [] aDimensionNames = { "ones", "tens", "hundreds", "thousands", "value", "" }; public static final String getMemberName( int nMember ) { return String.valueOf( nMember ); } public int nMemberCount = 3; public java.util.List aColDimensions = new java.util.ArrayList(); public java.util.List aRowDimensions = new java.util.ArrayList(); } // XPropertySetInfo implementation for getPropertySetInfo class ExamplePropertySetInfo implements com.sun.star.beans.XPropertySetInfo { private final com.sun.star.beans.Property[] aProperties; public ExamplePropertySetInfo( com.sun.star.beans.Property[] aProps ) { aProperties = aProps; } public com.sun.star.beans.Property[] getProperties() { return aProperties; } public com.sun.star.beans.Property getPropertyByName( String aName ) throws com.sun.star.beans.UnknownPropertyException { for ( int i=0; i= 0 ) nDimensions = aSettings.aColDimensions.size(); else { nPosition = aSettings.aRowDimensions.indexOf( Integer.valueOf(nDimension)); if ( nPosition >= 0 ) nDimensions = aSettings.aRowDimensions.size(); } if ( nPosition < 0 ) return new com.sun.star.sheet.MemberResult[0]; int nMembers = aSettings.nMemberCount; int nRepeat = 1; int nFill = 1; for ( int i=0; i nPosition ) nFill *= nMembers; } int nSize = nRepeat * nMembers * nFill; com.sun.star.sheet.MemberResult[] aResults = new com.sun.star.sheet.MemberResult[nSize]; int nResultPos = 0; for (int nOuter=0; nOuter= 1 ) { String aSource = com.sun.star.uno.AnyConverter.toString(aArguments[0]); if ( aSource != null && aSource.length() > 0) { int nValue = Integer.parseInt( aSource ); if ( nValue >= 2 && nValue <= 10 ) aSettings.nMemberCount = nValue; } } } catch ( NumberFormatException e ) { System.out.println( "Error: caught exception in " + "ExampleDataPilotSource.initialize!\nException Message = " + e.getMessage()); e.printStackTrace(); } catch ( com.sun.star.lang.IllegalArgumentException e ) { System.out.println( "Error: caught exception in " + "ExampleDataPilotSource.initialize!\nException Message = " + e.getMessage()); e.printStackTrace(); } } // XDataPilotResults public com.sun.star.sheet.DataResult[][] getResults() { int[] nDigits = new int[ExampleSettings.nDimensionCount]; int nValue = 1; for (int i=0; i