xref: /AOO41X/main/sc/source/ui/vba/vbapane.cxx (revision cdf0e10c4e3984b49a9502b011690b615761d4a3)
1*cdf0e10cSrcweir /*************************************************************************
2*cdf0e10cSrcweir  *
3*cdf0e10cSrcweir  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4*cdf0e10cSrcweir  *
5*cdf0e10cSrcweir  * Copyright 2000, 2010 Oracle and/or its affiliates.
6*cdf0e10cSrcweir  *
7*cdf0e10cSrcweir  * OpenOffice.org - a multi-platform office productivity suite
8*cdf0e10cSrcweir  *
9*cdf0e10cSrcweir  * This file is part of OpenOffice.org.
10*cdf0e10cSrcweir  *
11*cdf0e10cSrcweir  * OpenOffice.org is free software: you can redistribute it and/or modify
12*cdf0e10cSrcweir  * it under the terms of the GNU Lesser General Public License version 3
13*cdf0e10cSrcweir  * only, as published by the Free Software Foundation.
14*cdf0e10cSrcweir  *
15*cdf0e10cSrcweir  * OpenOffice.org is distributed in the hope that it will be useful,
16*cdf0e10cSrcweir  * but WITHOUT ANY WARRANTY; without even the implied warranty of
17*cdf0e10cSrcweir  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
18*cdf0e10cSrcweir  * GNU Lesser General Public License version 3 for more details
19*cdf0e10cSrcweir  * (a copy is included in the LICENSE file that accompanied this code).
20*cdf0e10cSrcweir  *
21*cdf0e10cSrcweir  * You should have received a copy of the GNU Lesser General Public License
22*cdf0e10cSrcweir  * version 3 along with OpenOffice.org.  If not, see
23*cdf0e10cSrcweir  * <http://www.openoffice.org/license.html>
24*cdf0e10cSrcweir  * for a copy of the LGPLv3 License.
25*cdf0e10cSrcweir  *
26*cdf0e10cSrcweir  ************************************************************************/
27*cdf0e10cSrcweir 
28*cdf0e10cSrcweir #include "vbapane.hxx"
29*cdf0e10cSrcweir #include <com/sun/star/sheet/XSpreadsheet.hpp>
30*cdf0e10cSrcweir #include <com/sun/star/sheet/XSpreadsheetDocument.hpp>
31*cdf0e10cSrcweir #include <com/sun/star/table/CellRangeAddress.hpp>
32*cdf0e10cSrcweir #include "vbarange.hxx"
33*cdf0e10cSrcweir 
34*cdf0e10cSrcweir using namespace com::sun::star;
35*cdf0e10cSrcweir using namespace ooo::vba;
36*cdf0e10cSrcweir 
37*cdf0e10cSrcweir ScVbaPane::ScVbaPane(
38*cdf0e10cSrcweir         const css::uno::Reference< ov::XHelperInterface >& xParent,
39*cdf0e10cSrcweir         const uno::Reference< uno::XComponentContext >& xContext,
40*cdf0e10cSrcweir         const uno::Reference< frame::XModel >& xModel,
41*cdf0e10cSrcweir         const uno::Reference< sheet::XViewPane > xViewPane ) throw (uno::RuntimeException) :
42*cdf0e10cSrcweir     ScVbaPane_BASE( xParent, xContext ),
43*cdf0e10cSrcweir     m_xModel( xModel, uno::UNO_SET_THROW ),
44*cdf0e10cSrcweir     m_xViewPane( xViewPane, uno::UNO_SET_THROW )
45*cdf0e10cSrcweir {
46*cdf0e10cSrcweir }
47*cdf0e10cSrcweir 
48*cdf0e10cSrcweir sal_Int32 SAL_CALL
49*cdf0e10cSrcweir ScVbaPane::getScrollColumn() throw (uno::RuntimeException)
50*cdf0e10cSrcweir {
51*cdf0e10cSrcweir     return ( m_xViewPane->getFirstVisibleColumn() + 1 );
52*cdf0e10cSrcweir }
53*cdf0e10cSrcweir 
54*cdf0e10cSrcweir void SAL_CALL
55*cdf0e10cSrcweir ScVbaPane::setScrollColumn( sal_Int32 _scrollcolumn ) throw (uno::RuntimeException)
56*cdf0e10cSrcweir {
57*cdf0e10cSrcweir     if( _scrollcolumn < 1 )
58*cdf0e10cSrcweir     {
59*cdf0e10cSrcweir         throw uno::RuntimeException( rtl::OUString::createFromAscii( "Column number should not less than 1" ),
60*cdf0e10cSrcweir                 uno::Reference< uno::XInterface >() );
61*cdf0e10cSrcweir     }
62*cdf0e10cSrcweir     m_xViewPane->setFirstVisibleColumn( _scrollcolumn - 1 );
63*cdf0e10cSrcweir }
64*cdf0e10cSrcweir 
65*cdf0e10cSrcweir sal_Int32 SAL_CALL
66*cdf0e10cSrcweir ScVbaPane::getScrollRow() throw (uno::RuntimeException)
67*cdf0e10cSrcweir {
68*cdf0e10cSrcweir     return ( m_xViewPane->getFirstVisibleRow() + 1 );
69*cdf0e10cSrcweir }
70*cdf0e10cSrcweir 
71*cdf0e10cSrcweir void SAL_CALL
72*cdf0e10cSrcweir ScVbaPane::setScrollRow( sal_Int32 _scrollrow ) throw (uno::RuntimeException)
73*cdf0e10cSrcweir {
74*cdf0e10cSrcweir     if( _scrollrow < 1 )
75*cdf0e10cSrcweir     {
76*cdf0e10cSrcweir         throw uno::RuntimeException( rtl::OUString::createFromAscii( "Row number should not less than 1" ),
77*cdf0e10cSrcweir                 uno::Reference< uno::XInterface >() );
78*cdf0e10cSrcweir     }
79*cdf0e10cSrcweir     m_xViewPane->setFirstVisibleRow( _scrollrow - 1 );
80*cdf0e10cSrcweir }
81*cdf0e10cSrcweir 
82*cdf0e10cSrcweir uno::Reference< excel::XRange > SAL_CALL
83*cdf0e10cSrcweir ScVbaPane::getVisibleRange() throw (uno::RuntimeException)
84*cdf0e10cSrcweir {
85*cdf0e10cSrcweir     // TODO: Excel includes partly visible rows/columns, Calc does not
86*cdf0e10cSrcweir     table::CellRangeAddress aRangeAddr = m_xViewPane->getVisibleRange();
87*cdf0e10cSrcweir     uno::Reference< sheet::XSpreadsheetDocument > xDoc( m_xModel, uno::UNO_QUERY_THROW );
88*cdf0e10cSrcweir     uno::Reference< container::XIndexAccess > xSheetsIA( xDoc->getSheets(), uno::UNO_QUERY_THROW );
89*cdf0e10cSrcweir     uno::Reference< sheet::XSpreadsheet > xSheet( xSheetsIA->getByIndex( aRangeAddr.Sheet ), uno::UNO_QUERY_THROW );
90*cdf0e10cSrcweir     uno::Reference< table::XCellRange > xRange( xSheet->getCellRangeByPosition( aRangeAddr.StartColumn, aRangeAddr.StartRow, aRangeAddr.EndColumn, aRangeAddr.EndRow ), uno::UNO_SET_THROW );
91*cdf0e10cSrcweir     // TODO: getParent() returns the window, Range needs the worksheet
92*cdf0e10cSrcweir 	return new ScVbaRange( getParent(), mxContext, xRange );
93*cdf0e10cSrcweir }
94*cdf0e10cSrcweir 
95*cdf0e10cSrcweir //Method
96*cdf0e10cSrcweir void SAL_CALL
97*cdf0e10cSrcweir ScVbaPane::SmallScroll( const uno::Any& Down, const uno::Any& Up, const uno::Any& ToRight, const uno::Any& ToLeft ) throw (uno::RuntimeException)
98*cdf0e10cSrcweir {
99*cdf0e10cSrcweir     rtl::OUString messageBuffer;
100*cdf0e10cSrcweir     sal_Int32 downRows = 0;
101*cdf0e10cSrcweir     sal_Int32 rightCols = 0;
102*cdf0e10cSrcweir     table::CellRangeAddress visibleRange = m_xViewPane->getVisibleRange();
103*cdf0e10cSrcweir 
104*cdf0e10cSrcweir     if( Down.hasValue() )
105*cdf0e10cSrcweir     {
106*cdf0e10cSrcweir         sal_Int32 down = 0;
107*cdf0e10cSrcweir         if( Down >>= down )
108*cdf0e10cSrcweir             downRows += down;
109*cdf0e10cSrcweir         else
110*cdf0e10cSrcweir             messageBuffer += rtl::OUString::createFromAscii( "Error getting parameter: Down\n" );
111*cdf0e10cSrcweir     }
112*cdf0e10cSrcweir     if( Up.hasValue() )
113*cdf0e10cSrcweir     {
114*cdf0e10cSrcweir         sal_Int32 up = 0;
115*cdf0e10cSrcweir         if( Up >>= up )
116*cdf0e10cSrcweir             downRows -= up;
117*cdf0e10cSrcweir         else
118*cdf0e10cSrcweir             messageBuffer += rtl::OUString::createFromAscii( "Error getting parameter: Up\n" );
119*cdf0e10cSrcweir     }
120*cdf0e10cSrcweir     if( ToRight.hasValue() )
121*cdf0e10cSrcweir     {
122*cdf0e10cSrcweir         sal_Int32 right = 0;
123*cdf0e10cSrcweir         if( ToRight >>= right )
124*cdf0e10cSrcweir             rightCols += right;
125*cdf0e10cSrcweir         else
126*cdf0e10cSrcweir             messageBuffer += rtl::OUString::createFromAscii( "Error getting parameter: ToRight\n" );
127*cdf0e10cSrcweir     }
128*cdf0e10cSrcweir     if( ToLeft.hasValue() )
129*cdf0e10cSrcweir     {
130*cdf0e10cSrcweir         sal_Int32 left = 0;
131*cdf0e10cSrcweir         if( ToLeft >>= left )
132*cdf0e10cSrcweir             rightCols -= left;
133*cdf0e10cSrcweir         else
134*cdf0e10cSrcweir             messageBuffer += rtl::OUString::createFromAscii( "Error getting parameter: ToLeft\n" );
135*cdf0e10cSrcweir     }
136*cdf0e10cSrcweir     if( messageBuffer.getLength() > 0 )
137*cdf0e10cSrcweir         throw(uno::RuntimeException( messageBuffer, uno::Reference< uno::XInterface >() ) );
138*cdf0e10cSrcweir 
139*cdf0e10cSrcweir     sal_Int32 newStartRow = visibleRange.StartRow + downRows;
140*cdf0e10cSrcweir     if( newStartRow < 0 )
141*cdf0e10cSrcweir         newStartRow = 0;
142*cdf0e10cSrcweir     sal_Int32 newStartCol = visibleRange.StartColumn + rightCols;
143*cdf0e10cSrcweir     if( newStartCol < 0 )
144*cdf0e10cSrcweir         newStartCol = 0;
145*cdf0e10cSrcweir     m_xViewPane->setFirstVisibleRow( newStartRow );
146*cdf0e10cSrcweir     m_xViewPane->setFirstVisibleColumn( newStartCol );
147*cdf0e10cSrcweir }
148*cdf0e10cSrcweir 
149*cdf0e10cSrcweir void SAL_CALL
150*cdf0e10cSrcweir ScVbaPane::LargeScroll( const uno::Any& Down, const uno::Any& Up, const uno::Any& ToRight, const uno::Any& ToLeft ) throw (uno::RuntimeException)
151*cdf0e10cSrcweir {
152*cdf0e10cSrcweir     rtl::OUString messageBuffer;
153*cdf0e10cSrcweir     table::CellRangeAddress visibleRange = m_xViewPane->getVisibleRange();
154*cdf0e10cSrcweir 
155*cdf0e10cSrcweir     sal_Int32 vertPageSize = 1 + visibleRange.EndRow - visibleRange.StartRow;
156*cdf0e10cSrcweir     sal_Int32 horizPageSize = 1 + visibleRange.EndColumn - visibleRange.StartColumn;
157*cdf0e10cSrcweir     sal_Int32 downPages = 0;
158*cdf0e10cSrcweir     sal_Int32 acrossPages = 0;
159*cdf0e10cSrcweir     if( Down.hasValue() )
160*cdf0e10cSrcweir     {
161*cdf0e10cSrcweir         sal_Int32 down = 0;
162*cdf0e10cSrcweir         if( Down >>= down )
163*cdf0e10cSrcweir             downPages += down;
164*cdf0e10cSrcweir         else
165*cdf0e10cSrcweir             messageBuffer += rtl::OUString::createFromAscii( "Error getting parameter: Down\n" );
166*cdf0e10cSrcweir     }
167*cdf0e10cSrcweir     if( Up.hasValue() )
168*cdf0e10cSrcweir     {
169*cdf0e10cSrcweir         sal_Int32 up = 0;
170*cdf0e10cSrcweir         if( Up >>= up )
171*cdf0e10cSrcweir             downPages -= up;
172*cdf0e10cSrcweir         else
173*cdf0e10cSrcweir             messageBuffer += rtl::OUString::createFromAscii( "Error getting parameter: Up\n" );
174*cdf0e10cSrcweir     }
175*cdf0e10cSrcweir     if( ToRight.hasValue() )
176*cdf0e10cSrcweir     {
177*cdf0e10cSrcweir         sal_Int32 right = 0;
178*cdf0e10cSrcweir         if( ToRight >>= right )
179*cdf0e10cSrcweir             acrossPages += right;
180*cdf0e10cSrcweir         else
181*cdf0e10cSrcweir             messageBuffer += rtl::OUString::createFromAscii( "Error getting parameter: ToRight\n" );
182*cdf0e10cSrcweir     }
183*cdf0e10cSrcweir     if( ToLeft.hasValue() )
184*cdf0e10cSrcweir     {
185*cdf0e10cSrcweir         sal_Int32 left = 0;
186*cdf0e10cSrcweir         if( ToLeft >>= left )
187*cdf0e10cSrcweir             acrossPages -= left;
188*cdf0e10cSrcweir         else
189*cdf0e10cSrcweir             messageBuffer += rtl::OUString::createFromAscii( "Error getting parameter: ToLeft\n" );
190*cdf0e10cSrcweir     }
191*cdf0e10cSrcweir     if( messageBuffer.getLength() > 0 )
192*cdf0e10cSrcweir         throw(uno::RuntimeException( messageBuffer, uno::Reference< uno::XInterface >() ) );
193*cdf0e10cSrcweir 
194*cdf0e10cSrcweir     sal_Int32 newStartRow = visibleRange.StartRow + (downPages * vertPageSize );
195*cdf0e10cSrcweir     if( newStartRow < 0 )
196*cdf0e10cSrcweir         newStartRow = 0;
197*cdf0e10cSrcweir     sal_Int32 newStartCol = visibleRange.StartColumn + (acrossPages * horizPageSize );
198*cdf0e10cSrcweir     if( newStartCol < 0 )
199*cdf0e10cSrcweir         newStartCol = 0;
200*cdf0e10cSrcweir     m_xViewPane->setFirstVisibleRow( newStartRow );
201*cdf0e10cSrcweir     m_xViewPane->setFirstVisibleColumn( newStartCol );
202*cdf0e10cSrcweir }
203*cdf0e10cSrcweir 
204*cdf0e10cSrcweir // XHelperInterface
205*cdf0e10cSrcweir 
206*cdf0e10cSrcweir VBAHELPER_IMPL_XHELPERINTERFACE( ScVbaPane, "ooo.vba.excel.Pane" )
207