xref: /aoo41x/main/sc/source/ui/vba/vbapane.cxx (revision b3f79822)
1*b3f79822SAndrew Rist /**************************************************************
2cdf0e10cSrcweir  *
3*b3f79822SAndrew Rist  * Licensed to the Apache Software Foundation (ASF) under one
4*b3f79822SAndrew Rist  * or more contributor license agreements.  See the NOTICE file
5*b3f79822SAndrew Rist  * distributed with this work for additional information
6*b3f79822SAndrew Rist  * regarding copyright ownership.  The ASF licenses this file
7*b3f79822SAndrew Rist  * to you under the Apache License, Version 2.0 (the
8*b3f79822SAndrew Rist  * "License"); you may not use this file except in compliance
9*b3f79822SAndrew Rist  * with the License.  You may obtain a copy of the License at
10*b3f79822SAndrew Rist  *
11*b3f79822SAndrew Rist  *   http://www.apache.org/licenses/LICENSE-2.0
12*b3f79822SAndrew Rist  *
13*b3f79822SAndrew Rist  * Unless required by applicable law or agreed to in writing,
14*b3f79822SAndrew Rist  * software distributed under the License is distributed on an
15*b3f79822SAndrew Rist  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16*b3f79822SAndrew Rist  * KIND, either express or implied.  See the License for the
17*b3f79822SAndrew Rist  * specific language governing permissions and limitations
18*b3f79822SAndrew Rist  * under the License.
19*b3f79822SAndrew Rist  *
20*b3f79822SAndrew Rist  *************************************************************/
21*b3f79822SAndrew Rist 
22*b3f79822SAndrew Rist 
23cdf0e10cSrcweir 
24cdf0e10cSrcweir #include "vbapane.hxx"
25cdf0e10cSrcweir #include <com/sun/star/sheet/XSpreadsheet.hpp>
26cdf0e10cSrcweir #include <com/sun/star/sheet/XSpreadsheetDocument.hpp>
27cdf0e10cSrcweir #include <com/sun/star/table/CellRangeAddress.hpp>
28cdf0e10cSrcweir #include "vbarange.hxx"
29cdf0e10cSrcweir 
30cdf0e10cSrcweir using namespace com::sun::star;
31cdf0e10cSrcweir using namespace ooo::vba;
32cdf0e10cSrcweir 
ScVbaPane(const css::uno::Reference<ov::XHelperInterface> & xParent,const uno::Reference<uno::XComponentContext> & xContext,const uno::Reference<frame::XModel> & xModel,const uno::Reference<sheet::XViewPane> xViewPane)33cdf0e10cSrcweir ScVbaPane::ScVbaPane(
34cdf0e10cSrcweir         const css::uno::Reference< ov::XHelperInterface >& xParent,
35cdf0e10cSrcweir         const uno::Reference< uno::XComponentContext >& xContext,
36cdf0e10cSrcweir         const uno::Reference< frame::XModel >& xModel,
37cdf0e10cSrcweir         const uno::Reference< sheet::XViewPane > xViewPane ) throw (uno::RuntimeException) :
38cdf0e10cSrcweir     ScVbaPane_BASE( xParent, xContext ),
39cdf0e10cSrcweir     m_xModel( xModel, uno::UNO_SET_THROW ),
40cdf0e10cSrcweir     m_xViewPane( xViewPane, uno::UNO_SET_THROW )
41cdf0e10cSrcweir {
42cdf0e10cSrcweir }
43cdf0e10cSrcweir 
44cdf0e10cSrcweir sal_Int32 SAL_CALL
getScrollColumn()45cdf0e10cSrcweir ScVbaPane::getScrollColumn() throw (uno::RuntimeException)
46cdf0e10cSrcweir {
47cdf0e10cSrcweir     return ( m_xViewPane->getFirstVisibleColumn() + 1 );
48cdf0e10cSrcweir }
49cdf0e10cSrcweir 
50cdf0e10cSrcweir void SAL_CALL
setScrollColumn(sal_Int32 _scrollcolumn)51cdf0e10cSrcweir ScVbaPane::setScrollColumn( sal_Int32 _scrollcolumn ) throw (uno::RuntimeException)
52cdf0e10cSrcweir {
53cdf0e10cSrcweir     if( _scrollcolumn < 1 )
54cdf0e10cSrcweir     {
55cdf0e10cSrcweir         throw uno::RuntimeException( rtl::OUString::createFromAscii( "Column number should not less than 1" ),
56cdf0e10cSrcweir                 uno::Reference< uno::XInterface >() );
57cdf0e10cSrcweir     }
58cdf0e10cSrcweir     m_xViewPane->setFirstVisibleColumn( _scrollcolumn - 1 );
59cdf0e10cSrcweir }
60cdf0e10cSrcweir 
61cdf0e10cSrcweir sal_Int32 SAL_CALL
getScrollRow()62cdf0e10cSrcweir ScVbaPane::getScrollRow() throw (uno::RuntimeException)
63cdf0e10cSrcweir {
64cdf0e10cSrcweir     return ( m_xViewPane->getFirstVisibleRow() + 1 );
65cdf0e10cSrcweir }
66cdf0e10cSrcweir 
67cdf0e10cSrcweir void SAL_CALL
setScrollRow(sal_Int32 _scrollrow)68cdf0e10cSrcweir ScVbaPane::setScrollRow( sal_Int32 _scrollrow ) throw (uno::RuntimeException)
69cdf0e10cSrcweir {
70cdf0e10cSrcweir     if( _scrollrow < 1 )
71cdf0e10cSrcweir     {
72cdf0e10cSrcweir         throw uno::RuntimeException( rtl::OUString::createFromAscii( "Row number should not less than 1" ),
73cdf0e10cSrcweir                 uno::Reference< uno::XInterface >() );
74cdf0e10cSrcweir     }
75cdf0e10cSrcweir     m_xViewPane->setFirstVisibleRow( _scrollrow - 1 );
76cdf0e10cSrcweir }
77cdf0e10cSrcweir 
78cdf0e10cSrcweir uno::Reference< excel::XRange > SAL_CALL
getVisibleRange()79cdf0e10cSrcweir ScVbaPane::getVisibleRange() throw (uno::RuntimeException)
80cdf0e10cSrcweir {
81cdf0e10cSrcweir     // TODO: Excel includes partly visible rows/columns, Calc does not
82cdf0e10cSrcweir     table::CellRangeAddress aRangeAddr = m_xViewPane->getVisibleRange();
83cdf0e10cSrcweir     uno::Reference< sheet::XSpreadsheetDocument > xDoc( m_xModel, uno::UNO_QUERY_THROW );
84cdf0e10cSrcweir     uno::Reference< container::XIndexAccess > xSheetsIA( xDoc->getSheets(), uno::UNO_QUERY_THROW );
85cdf0e10cSrcweir     uno::Reference< sheet::XSpreadsheet > xSheet( xSheetsIA->getByIndex( aRangeAddr.Sheet ), uno::UNO_QUERY_THROW );
86cdf0e10cSrcweir     uno::Reference< table::XCellRange > xRange( xSheet->getCellRangeByPosition( aRangeAddr.StartColumn, aRangeAddr.StartRow, aRangeAddr.EndColumn, aRangeAddr.EndRow ), uno::UNO_SET_THROW );
87cdf0e10cSrcweir     // TODO: getParent() returns the window, Range needs the worksheet
88cdf0e10cSrcweir 	return new ScVbaRange( getParent(), mxContext, xRange );
89cdf0e10cSrcweir }
90cdf0e10cSrcweir 
91cdf0e10cSrcweir //Method
92cdf0e10cSrcweir void SAL_CALL
SmallScroll(const uno::Any & Down,const uno::Any & Up,const uno::Any & ToRight,const uno::Any & ToLeft)93cdf0e10cSrcweir ScVbaPane::SmallScroll( const uno::Any& Down, const uno::Any& Up, const uno::Any& ToRight, const uno::Any& ToLeft ) throw (uno::RuntimeException)
94cdf0e10cSrcweir {
95cdf0e10cSrcweir     rtl::OUString messageBuffer;
96cdf0e10cSrcweir     sal_Int32 downRows = 0;
97cdf0e10cSrcweir     sal_Int32 rightCols = 0;
98cdf0e10cSrcweir     table::CellRangeAddress visibleRange = m_xViewPane->getVisibleRange();
99cdf0e10cSrcweir 
100cdf0e10cSrcweir     if( Down.hasValue() )
101cdf0e10cSrcweir     {
102cdf0e10cSrcweir         sal_Int32 down = 0;
103cdf0e10cSrcweir         if( Down >>= down )
104cdf0e10cSrcweir             downRows += down;
105cdf0e10cSrcweir         else
106cdf0e10cSrcweir             messageBuffer += rtl::OUString::createFromAscii( "Error getting parameter: Down\n" );
107cdf0e10cSrcweir     }
108cdf0e10cSrcweir     if( Up.hasValue() )
109cdf0e10cSrcweir     {
110cdf0e10cSrcweir         sal_Int32 up = 0;
111cdf0e10cSrcweir         if( Up >>= up )
112cdf0e10cSrcweir             downRows -= up;
113cdf0e10cSrcweir         else
114cdf0e10cSrcweir             messageBuffer += rtl::OUString::createFromAscii( "Error getting parameter: Up\n" );
115cdf0e10cSrcweir     }
116cdf0e10cSrcweir     if( ToRight.hasValue() )
117cdf0e10cSrcweir     {
118cdf0e10cSrcweir         sal_Int32 right = 0;
119cdf0e10cSrcweir         if( ToRight >>= right )
120cdf0e10cSrcweir             rightCols += right;
121cdf0e10cSrcweir         else
122cdf0e10cSrcweir             messageBuffer += rtl::OUString::createFromAscii( "Error getting parameter: ToRight\n" );
123cdf0e10cSrcweir     }
124cdf0e10cSrcweir     if( ToLeft.hasValue() )
125cdf0e10cSrcweir     {
126cdf0e10cSrcweir         sal_Int32 left = 0;
127cdf0e10cSrcweir         if( ToLeft >>= left )
128cdf0e10cSrcweir             rightCols -= left;
129cdf0e10cSrcweir         else
130cdf0e10cSrcweir             messageBuffer += rtl::OUString::createFromAscii( "Error getting parameter: ToLeft\n" );
131cdf0e10cSrcweir     }
132cdf0e10cSrcweir     if( messageBuffer.getLength() > 0 )
133cdf0e10cSrcweir         throw(uno::RuntimeException( messageBuffer, uno::Reference< uno::XInterface >() ) );
134cdf0e10cSrcweir 
135cdf0e10cSrcweir     sal_Int32 newStartRow = visibleRange.StartRow + downRows;
136cdf0e10cSrcweir     if( newStartRow < 0 )
137cdf0e10cSrcweir         newStartRow = 0;
138cdf0e10cSrcweir     sal_Int32 newStartCol = visibleRange.StartColumn + rightCols;
139cdf0e10cSrcweir     if( newStartCol < 0 )
140cdf0e10cSrcweir         newStartCol = 0;
141cdf0e10cSrcweir     m_xViewPane->setFirstVisibleRow( newStartRow );
142cdf0e10cSrcweir     m_xViewPane->setFirstVisibleColumn( newStartCol );
143cdf0e10cSrcweir }
144cdf0e10cSrcweir 
145cdf0e10cSrcweir void SAL_CALL
LargeScroll(const uno::Any & Down,const uno::Any & Up,const uno::Any & ToRight,const uno::Any & ToLeft)146cdf0e10cSrcweir ScVbaPane::LargeScroll( const uno::Any& Down, const uno::Any& Up, const uno::Any& ToRight, const uno::Any& ToLeft ) throw (uno::RuntimeException)
147cdf0e10cSrcweir {
148cdf0e10cSrcweir     rtl::OUString messageBuffer;
149cdf0e10cSrcweir     table::CellRangeAddress visibleRange = m_xViewPane->getVisibleRange();
150cdf0e10cSrcweir 
151cdf0e10cSrcweir     sal_Int32 vertPageSize = 1 + visibleRange.EndRow - visibleRange.StartRow;
152cdf0e10cSrcweir     sal_Int32 horizPageSize = 1 + visibleRange.EndColumn - visibleRange.StartColumn;
153cdf0e10cSrcweir     sal_Int32 downPages = 0;
154cdf0e10cSrcweir     sal_Int32 acrossPages = 0;
155cdf0e10cSrcweir     if( Down.hasValue() )
156cdf0e10cSrcweir     {
157cdf0e10cSrcweir         sal_Int32 down = 0;
158cdf0e10cSrcweir         if( Down >>= down )
159cdf0e10cSrcweir             downPages += down;
160cdf0e10cSrcweir         else
161cdf0e10cSrcweir             messageBuffer += rtl::OUString::createFromAscii( "Error getting parameter: Down\n" );
162cdf0e10cSrcweir     }
163cdf0e10cSrcweir     if( Up.hasValue() )
164cdf0e10cSrcweir     {
165cdf0e10cSrcweir         sal_Int32 up = 0;
166cdf0e10cSrcweir         if( Up >>= up )
167cdf0e10cSrcweir             downPages -= up;
168cdf0e10cSrcweir         else
169cdf0e10cSrcweir             messageBuffer += rtl::OUString::createFromAscii( "Error getting parameter: Up\n" );
170cdf0e10cSrcweir     }
171cdf0e10cSrcweir     if( ToRight.hasValue() )
172cdf0e10cSrcweir     {
173cdf0e10cSrcweir         sal_Int32 right = 0;
174cdf0e10cSrcweir         if( ToRight >>= right )
175cdf0e10cSrcweir             acrossPages += right;
176cdf0e10cSrcweir         else
177cdf0e10cSrcweir             messageBuffer += rtl::OUString::createFromAscii( "Error getting parameter: ToRight\n" );
178cdf0e10cSrcweir     }
179cdf0e10cSrcweir     if( ToLeft.hasValue() )
180cdf0e10cSrcweir     {
181cdf0e10cSrcweir         sal_Int32 left = 0;
182cdf0e10cSrcweir         if( ToLeft >>= left )
183cdf0e10cSrcweir             acrossPages -= left;
184cdf0e10cSrcweir         else
185cdf0e10cSrcweir             messageBuffer += rtl::OUString::createFromAscii( "Error getting parameter: ToLeft\n" );
186cdf0e10cSrcweir     }
187cdf0e10cSrcweir     if( messageBuffer.getLength() > 0 )
188cdf0e10cSrcweir         throw(uno::RuntimeException( messageBuffer, uno::Reference< uno::XInterface >() ) );
189cdf0e10cSrcweir 
190cdf0e10cSrcweir     sal_Int32 newStartRow = visibleRange.StartRow + (downPages * vertPageSize );
191cdf0e10cSrcweir     if( newStartRow < 0 )
192cdf0e10cSrcweir         newStartRow = 0;
193cdf0e10cSrcweir     sal_Int32 newStartCol = visibleRange.StartColumn + (acrossPages * horizPageSize );
194cdf0e10cSrcweir     if( newStartCol < 0 )
195cdf0e10cSrcweir         newStartCol = 0;
196cdf0e10cSrcweir     m_xViewPane->setFirstVisibleRow( newStartRow );
197cdf0e10cSrcweir     m_xViewPane->setFirstVisibleColumn( newStartCol );
198cdf0e10cSrcweir }
199cdf0e10cSrcweir 
200cdf0e10cSrcweir // XHelperInterface
201cdf0e10cSrcweir 
202cdf0e10cSrcweir VBAHELPER_IMPL_XHELPERINTERFACE( ScVbaPane, "ooo.vba.excel.Pane" )
203