xref: /AOO41X/main/sc/source/ui/vba/vbaoleobject.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 <com/sun/star/awt/XControlModel.hpp>
29*cdf0e10cSrcweir #include <com/sun/star/awt/XWindow2.hpp>
30*cdf0e10cSrcweir #include <com/sun/star/view/XControlAccess.hpp>
31*cdf0e10cSrcweir #include <com/sun/star/container/XChild.hpp>
32*cdf0e10cSrcweir #include <com/sun/star/drawing/XShape.hpp>
33*cdf0e10cSrcweir #include <ooo/vba/XControlProvider.hpp>
34*cdf0e10cSrcweir 
35*cdf0e10cSrcweir #include "vbaoleobject.hxx"
36*cdf0e10cSrcweir 
37*cdf0e10cSrcweir using namespace com::sun::star;
38*cdf0e10cSrcweir using namespace ooo::vba;
39*cdf0e10cSrcweir 
40*cdf0e10cSrcweir 
41*cdf0e10cSrcweir sal_Int32 pt2mm( double pt ) //1/100mm
42*cdf0e10cSrcweir {
43*cdf0e10cSrcweir     return static_cast<sal_Int32>(pt * 0.352778);
44*cdf0e10cSrcweir }
45*cdf0e10cSrcweir 
46*cdf0e10cSrcweir double mm2pt( sal_Int32 mm )
47*cdf0e10cSrcweir {
48*cdf0e10cSrcweir     return mm * 2.8345;
49*cdf0e10cSrcweir }
50*cdf0e10cSrcweir 
51*cdf0e10cSrcweir 
52*cdf0e10cSrcweir ScVbaOLEObject::ScVbaOLEObject( const uno::Reference< XHelperInterface >& xParent, const uno::Reference< uno::XComponentContext >& xContext,
53*cdf0e10cSrcweir             css::uno::Reference< css::drawing::XControlShape > xControlShape )
54*cdf0e10cSrcweir : OLEObjectImpl_BASE( xParent, xContext ), m_xControlShape( xControlShape )
55*cdf0e10cSrcweir {
56*cdf0e10cSrcweir     //init m_xWindowPeer
57*cdf0e10cSrcweir     uno::Reference< awt::XControlModel > xControlModel( xControlShape->getControl(), css::uno::UNO_QUERY_THROW );
58*cdf0e10cSrcweir     uno::Reference< container::XChild > xChild( xControlModel, uno::UNO_QUERY_THROW );
59*cdf0e10cSrcweir     xChild.set( xChild->getParent(), uno::UNO_QUERY_THROW );
60*cdf0e10cSrcweir     xChild.set( xChild->getParent(), uno::UNO_QUERY_THROW );
61*cdf0e10cSrcweir     css::uno::Reference< css::frame::XModel > xModel( xChild->getParent(), uno::UNO_QUERY_THROW );
62*cdf0e10cSrcweir     uno::Reference<lang::XMultiComponentFactory > xServiceManager( mxContext->getServiceManager(), uno::UNO_QUERY_THROW );
63*cdf0e10cSrcweir     uno::Reference< XControlProvider > xControlProvider( xServiceManager->createInstanceWithContext( rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( "ooo.vba.ControlProvider" ) ), mxContext ), uno::UNO_QUERY_THROW );
64*cdf0e10cSrcweir     m_xControl.set( xControlProvider->createControl(  xControlShape, xModel ) );
65*cdf0e10cSrcweir }
66*cdf0e10cSrcweir 
67*cdf0e10cSrcweir uno::Reference< uno::XInterface > SAL_CALL
68*cdf0e10cSrcweir ScVbaOLEObject::getObject() throw (uno::RuntimeException)
69*cdf0e10cSrcweir {
70*cdf0e10cSrcweir     return uno::Reference< uno::XInterface >( m_xControlShape, uno::UNO_QUERY_THROW );
71*cdf0e10cSrcweir }
72*cdf0e10cSrcweir 
73*cdf0e10cSrcweir sal_Bool SAL_CALL
74*cdf0e10cSrcweir ScVbaOLEObject::getEnabled() throw (uno::RuntimeException)
75*cdf0e10cSrcweir {
76*cdf0e10cSrcweir     return m_xControl->getEnabled();
77*cdf0e10cSrcweir }
78*cdf0e10cSrcweir 
79*cdf0e10cSrcweir void SAL_CALL
80*cdf0e10cSrcweir ScVbaOLEObject::setEnabled( sal_Bool _enabled ) throw (uno::RuntimeException)
81*cdf0e10cSrcweir {
82*cdf0e10cSrcweir     m_xControl->setEnabled( _enabled );
83*cdf0e10cSrcweir }
84*cdf0e10cSrcweir 
85*cdf0e10cSrcweir sal_Bool SAL_CALL
86*cdf0e10cSrcweir ScVbaOLEObject::getVisible() throw (uno::RuntimeException)
87*cdf0e10cSrcweir {
88*cdf0e10cSrcweir     OSL_TRACE("OleObject %s returning visible %s", rtl::OUStringToOString( m_xControl->getName(), RTL_TEXTENCODING_UTF8 ).getStr(), m_xControl->getVisible() ? "true" : "false" );
89*cdf0e10cSrcweir     return m_xControl->getVisible();
90*cdf0e10cSrcweir }
91*cdf0e10cSrcweir 
92*cdf0e10cSrcweir void SAL_CALL
93*cdf0e10cSrcweir ScVbaOLEObject::setVisible( sal_Bool _visible ) throw (uno::RuntimeException)
94*cdf0e10cSrcweir {
95*cdf0e10cSrcweir     OSL_TRACE("OleObject %s set visible %s", rtl::OUStringToOString( m_xControl->getName(), RTL_TEXTENCODING_UTF8 ).getStr(), _visible ? "true" : "false" );
96*cdf0e10cSrcweir     m_xControl->setVisible( _visible );
97*cdf0e10cSrcweir }
98*cdf0e10cSrcweir 
99*cdf0e10cSrcweir double SAL_CALL
100*cdf0e10cSrcweir ScVbaOLEObject::getLeft() throw (uno::RuntimeException)
101*cdf0e10cSrcweir {
102*cdf0e10cSrcweir     return m_xControl->getLeft();
103*cdf0e10cSrcweir }
104*cdf0e10cSrcweir 
105*cdf0e10cSrcweir void SAL_CALL
106*cdf0e10cSrcweir ScVbaOLEObject::setLeft( double _left ) throw (uno::RuntimeException)
107*cdf0e10cSrcweir {
108*cdf0e10cSrcweir     m_xControl->setLeft( _left );
109*cdf0e10cSrcweir 
110*cdf0e10cSrcweir }
111*cdf0e10cSrcweir 
112*cdf0e10cSrcweir double SAL_CALL
113*cdf0e10cSrcweir ScVbaOLEObject::getTop() throw (uno::RuntimeException)
114*cdf0e10cSrcweir {
115*cdf0e10cSrcweir     return m_xControl->getTop();
116*cdf0e10cSrcweir }
117*cdf0e10cSrcweir 
118*cdf0e10cSrcweir void SAL_CALL
119*cdf0e10cSrcweir ScVbaOLEObject::setTop( double _top ) throw (uno::RuntimeException)
120*cdf0e10cSrcweir {
121*cdf0e10cSrcweir     m_xControl->setTop( _top );
122*cdf0e10cSrcweir }
123*cdf0e10cSrcweir 
124*cdf0e10cSrcweir double SAL_CALL
125*cdf0e10cSrcweir ScVbaOLEObject::getHeight() throw (uno::RuntimeException)
126*cdf0e10cSrcweir {
127*cdf0e10cSrcweir     return m_xControl->getHeight();
128*cdf0e10cSrcweir }
129*cdf0e10cSrcweir 
130*cdf0e10cSrcweir void SAL_CALL
131*cdf0e10cSrcweir ScVbaOLEObject::setHeight( double _height ) throw (uno::RuntimeException)
132*cdf0e10cSrcweir {
133*cdf0e10cSrcweir     m_xControl->setHeight( _height );
134*cdf0e10cSrcweir }
135*cdf0e10cSrcweir 
136*cdf0e10cSrcweir double SAL_CALL
137*cdf0e10cSrcweir ScVbaOLEObject::getWidth() throw (uno::RuntimeException)
138*cdf0e10cSrcweir {
139*cdf0e10cSrcweir     return m_xControl->getWidth();
140*cdf0e10cSrcweir }
141*cdf0e10cSrcweir 
142*cdf0e10cSrcweir void SAL_CALL
143*cdf0e10cSrcweir ScVbaOLEObject::setWidth( double _width ) throw (uno::RuntimeException)
144*cdf0e10cSrcweir {
145*cdf0e10cSrcweir     m_xControl->setWidth( _width );
146*cdf0e10cSrcweir }
147*cdf0e10cSrcweir rtl::OUString&
148*cdf0e10cSrcweir ScVbaOLEObject::getServiceImplName()
149*cdf0e10cSrcweir {
150*cdf0e10cSrcweir 	static rtl::OUString sImplName( RTL_CONSTASCII_USTRINGPARAM("ScVbaOLEObject") );
151*cdf0e10cSrcweir 	return sImplName;
152*cdf0e10cSrcweir }
153*cdf0e10cSrcweir 
154*cdf0e10cSrcweir uno::Sequence< rtl::OUString >
155*cdf0e10cSrcweir ScVbaOLEObject::getServiceNames()
156*cdf0e10cSrcweir {
157*cdf0e10cSrcweir 	static uno::Sequence< rtl::OUString > aServiceNames;
158*cdf0e10cSrcweir 	if ( aServiceNames.getLength() == 0 )
159*cdf0e10cSrcweir 	{
160*cdf0e10cSrcweir 		aServiceNames.realloc( 1 );
161*cdf0e10cSrcweir 		aServiceNames[ 0 ] = rtl::OUString( RTL_CONSTASCII_USTRINGPARAM("ooo.vba.excel.OLEObject" ) );
162*cdf0e10cSrcweir 	}
163*cdf0e10cSrcweir 	return aServiceNames;
164*cdf0e10cSrcweir }
165