diff --git a/sc/source/ui/vba/vbaoleobject.cxx b/sc/source/ui/vba/vbaoleobject.cxx new file mode 100644 index 000000000000..6d067da2a8a0 --- /dev/null +++ b/sc/source/ui/vba/vbaoleobject.cxx @@ -0,0 +1,192 @@ +/************************************************************************* + * + * OpenOffice.org - a multi-platform office productivity suite + * + * $RCSfile: vbaoleobject.cxx,v $ + * + * $Revision: 1.2 $ + * + * last change: $Author: vg $ $Date: 2007-12-07 10:56:27 $ + * + * The Contents of this file are made available subject to + * the terms of GNU Lesser General Public License Version 2.1. + * + * + * GNU Lesser General Public License Version 2.1 + * ============================================= + * Copyright 2005 by Sun Microsystems, Inc. + * 901 San Antonio Road, Palo Alto, CA 94303, USA + * + * This library is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License version 2.1, as published by the Free Software Foundation. + * + * This library is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public + * License along with this library; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, + * MA 02111-1307 USA + * + ************************************************************************/ + +#include +#include +#include +#include +#include + +#include "vbaoleobject.hxx" + +using namespace com::sun::star; +using namespace org::openoffice; + + +sal_Int32 pt2mm( double pt ) //1/100mm +{ + return static_cast(pt * 0.352778); +} + +double mm2pt( sal_Int32 mm ) +{ + return mm * 2.8345; +} + + +ScVbaOLEObject::ScVbaOLEObject( const uno::Reference< vba::XHelperInterface >& xParent, const uno::Reference< uno::XComponentContext >& xContext, + css::uno::Reference< css::drawing::XControlShape > xControlShape ) +: OLEObjectImpl_BASE( xParent, xContext ), m_xControlShape( xControlShape ) +{ + //init m_xWindowPeer + uno::Reference< awt::XControlModel > xControlModel( xControlShape->getControl(), css::uno::UNO_QUERY_THROW ); + uno::Reference< container::XChild > xChild( xControlModel, uno::UNO_QUERY_THROW ); + xChild.set( xChild->getParent(), uno::UNO_QUERY_THROW ); + xChild.set( xChild->getParent(), uno::UNO_QUERY_THROW ); + css::uno::Reference< css::frame::XModel > xModel( xChild->getParent(), uno::UNO_QUERY_THROW ); + css::uno::Reference< css::view::XControlAccess > xControlAccess( xModel->getCurrentController(), css::uno::UNO_QUERY_THROW ); + m_xWindowPeer = xControlAccess->getControl( xControlModel )->getPeer(); +} + +uno::Reference< uno::XInterface > SAL_CALL +ScVbaOLEObject::getObject() throw (uno::RuntimeException) +{ + return uno::Reference< uno::XInterface >( m_xControlShape, uno::UNO_QUERY_THROW ); +} + +sal_Bool SAL_CALL +ScVbaOLEObject::getEnabled() throw (uno::RuntimeException) +{ + uno::Reference< css::awt::XWindow2 > xWindow2( m_xWindowPeer, css::uno::UNO_QUERY_THROW ); + return xWindow2->isEnabled(); +} + +void SAL_CALL +ScVbaOLEObject::setEnabled( sal_Bool _enabled ) throw (uno::RuntimeException) +{ + uno::Reference< css::awt::XWindow2 > xWindow2( m_xWindowPeer, css::uno::UNO_QUERY_THROW ); + xWindow2->setEnable( _enabled ); +} + +sal_Bool SAL_CALL +ScVbaOLEObject::getVisible() throw (uno::RuntimeException) +{ + uno::Reference< css::awt::XWindow2 > xWindow2( m_xWindowPeer, css::uno::UNO_QUERY_THROW ); + return xWindow2->isVisible(); +} + +void SAL_CALL +ScVbaOLEObject::setVisible( sal_Bool _visible ) throw (uno::RuntimeException) +{ + uno::Reference< css::awt::XWindow2 > xWindow2( m_xWindowPeer, css::uno::UNO_QUERY_THROW ); + xWindow2->setVisible( _visible ); +} + +double SAL_CALL +ScVbaOLEObject::getLeft() throw (uno::RuntimeException) +{ + uno::Reference< drawing::XShape > xShape( m_xControlShape, uno::UNO_QUERY_THROW ); + return mm2pt( xShape->getPosition().X / 100 ); +} + +void SAL_CALL +ScVbaOLEObject::setLeft( double _left ) throw (uno::RuntimeException) +{ + awt::Point oldPosition; + uno::Reference< drawing::XShape > xShape( m_xControlShape, uno::UNO_QUERY_THROW ); + oldPosition = xShape->getPosition(); + oldPosition.X = pt2mm( _left ) * 100; + xShape->setPosition( oldPosition ); + +} + +double SAL_CALL +ScVbaOLEObject::getTop() throw (uno::RuntimeException) +{ + uno::Reference< drawing::XShape > xShape( m_xControlShape, uno::UNO_QUERY_THROW ); + return mm2pt( xShape->getPosition().Y / 100 ); +} + +void SAL_CALL +ScVbaOLEObject::setTop( double _top ) throw (uno::RuntimeException) +{ + awt::Point oldPosition; + uno::Reference< drawing::XShape > xShape( m_xControlShape, uno::UNO_QUERY_THROW ); + oldPosition = xShape->getPosition(); + oldPosition.Y = pt2mm( _top ) * 100;; + xShape->setPosition( oldPosition ); +} + +double SAL_CALL +ScVbaOLEObject::getHeight() throw (uno::RuntimeException) +{ + uno::Reference< drawing::XShape > xShape( m_xControlShape, uno::UNO_QUERY_THROW ); + return mm2pt( xShape->getSize().Height / 100 );//1pt = 1/72in +} + +void SAL_CALL +ScVbaOLEObject::setHeight( double _height ) throw (uno::RuntimeException) +{ + awt::Size oldSize; + uno::Reference< drawing::XShape > xShape( m_xControlShape, uno::UNO_QUERY_THROW ); + oldSize = xShape->getSize(); + oldSize.Height = pt2mm( _height ) * 100; + xShape->setSize( oldSize ); +} + +double SAL_CALL +ScVbaOLEObject::getWidth() throw (uno::RuntimeException) +{ + uno::Reference< drawing::XShape > xShape( m_xControlShape, uno::UNO_QUERY_THROW ); + return mm2pt ( xShape->getSize().Width / 100 ); +} + +void SAL_CALL +ScVbaOLEObject::setWidth( double _width ) throw (uno::RuntimeException) +{ + awt::Size oldSize; + uno::Reference< drawing::XShape > xShape( m_xControlShape, uno::UNO_QUERY_THROW ); + oldSize = xShape->getSize(); + oldSize.Width = pt2mm( _width ) * 100; + xShape->setSize( oldSize ); +} +rtl::OUString& +ScVbaOLEObject::getServiceImplName() +{ + static rtl::OUString sImplName( RTL_CONSTASCII_USTRINGPARAM("ScVbaOLEObject") ); + return sImplName; +} + +uno::Sequence< rtl::OUString > +ScVbaOLEObject::getServiceNames() +{ + static uno::Sequence< rtl::OUString > aServiceNames; + if ( aServiceNames.getLength() == 0 ) + { + aServiceNames.realloc( 1 ); + aServiceNames[ 0 ] = rtl::OUString( RTL_CONSTASCII_USTRINGPARAM("org.openoffice.excel.OLEObject" ) ); + } + return aServiceNames; +} diff --git a/sc/source/ui/vba/vbaoleobject.hxx b/sc/source/ui/vba/vbaoleobject.hxx new file mode 100644 index 000000000000..86777ba96cb4 --- /dev/null +++ b/sc/source/ui/vba/vbaoleobject.hxx @@ -0,0 +1,75 @@ +/************************************************************************* + * + * OpenOffice.org - a multi-platform office productivity suite + * + * $RCSfile: vbaoleobject.hxx,v $ + * + * $Revision: 1.2 $ + * + * last change: $Author: vg $ $Date: 2007-12-07 10:56:41 $ + * + * The Contents of this file are made available subject to + * the terms of GNU Lesser General Public License Version 2.1. + * + * + * GNU Lesser General Public License Version 2.1 + * ============================================= + * Copyright 2005 by Sun Microsystems, Inc. + * 901 San Antonio Road, Palo Alto, CA 94303, USA + * + * This library is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License version 2.1, as published by the Free Software Foundation. + * + * This library is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public + * License along with this library; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, + * MA 02111-1307 USA + * + ************************************************************************/ +#ifndef SC_VBA_OLEOBJECT_HXX +#define SC_VBA_OLEOBJECT_HXX + +#include +#include +#include +#include + +#include "vbahelperinterface.hxx" + +typedef InheritedHelperInterfaceImpl1< oo::excel::XOLEObject > OLEObjectImpl_BASE; + +class ScVbaOLEObject : public OLEObjectImpl_BASE +{ + css::uno::Reference< css::awt::XWindowPeer > m_xWindowPeer; +protected: + css::uno::Reference< css::drawing::XControlShape > m_xControlShape; + virtual rtl::OUString& getServiceImplName(); + virtual css::uno::Sequence getServiceNames(); +public: + ScVbaOLEObject( const css::uno::Reference< oo::vba::XHelperInterface >& xParent, const css::uno::Reference< css::uno::XComponentContext >& xContext, + css::uno::Reference< css::drawing::XControlShape > xControlShape ); + + // XOLEObject Attributes + virtual css::uno::Reference< css::uno::XInterface > SAL_CALL getObject() throw (css::uno::RuntimeException); + virtual sal_Bool SAL_CALL getEnabled() throw (css::uno::RuntimeException); + virtual void SAL_CALL setEnabled( ::sal_Bool _enabled ) throw (css::uno::RuntimeException); + virtual sal_Bool SAL_CALL getVisible() throw (css::uno::RuntimeException); + virtual void SAL_CALL setVisible( ::sal_Bool _visible ) throw (css::uno::RuntimeException); + virtual double SAL_CALL getLeft() throw (css::uno::RuntimeException); + virtual void SAL_CALL setLeft( double _left ) throw (css::uno::RuntimeException); + virtual double SAL_CALL getTop() throw (css::uno::RuntimeException); + virtual void SAL_CALL setTop( double _top ) throw (css::uno::RuntimeException); + virtual double SAL_CALL getHeight() throw (css::uno::RuntimeException); + virtual void SAL_CALL setHeight( double _height ) throw (css::uno::RuntimeException); + virtual double SAL_CALL getWidth() throw (css::uno::RuntimeException); + virtual void SAL_CALL setWidth( double _width ) throw (css::uno::RuntimeException); + +}; +#endif //SC_VBA_OLEOBJECT_HXX + diff --git a/sc/source/ui/vba/vbaoleobjects.hxx b/sc/source/ui/vba/vbaoleobjects.hxx new file mode 100644 index 000000000000..a0840c4ccab7 --- /dev/null +++ b/sc/source/ui/vba/vbaoleobjects.hxx @@ -0,0 +1,65 @@ +/************************************************************************* + * + * OpenOffice.org - a multi-platform office productivity suite + * + * $RCSfile: vbaoleobjects.hxx,v $ + * + * $Revision: 1.2 $ + * + * last change: $Author: vg $ $Date: 2007-12-07 10:57:00 $ + * + * The Contents of this file are made available subject to + * the terms of GNU Lesser General Public License Version 2.1. + * + * + * GNU Lesser General Public License Version 2.1 + * ============================================= + * Copyright 2005 by Sun Microsystems, Inc. + * 901 San Antonio Road, Palo Alto, CA 94303, USA + * + * This library is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License version 2.1, as published by the Free Software Foundation. + * + * This library is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public + * License along with this library; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, + * MA 02111-1307 USA + * + ************************************************************************/ +#ifndef SC_VBA_OLEOBJECTS_HXX +#define SC_VBA_OLEOBJECTS_HXX + +#include +#include + +#include "vbacollectionimpl.hxx" +#include "vbahelper.hxx" + +typedef CollTestImplHelper< oo::excel::XOLEObjects > OLEObjectsImpl_BASE; + +class ScVbaOLEObjects : public OLEObjectsImpl_BASE +{ +protected: + virtual css::uno::Any getItemByStringIndex( const rtl::OUString& sIndex ) throw (css::uno::RuntimeException); + virtual rtl::OUString& getServiceImplName(); + virtual css::uno::Sequence getServiceNames(); +public: + ScVbaOLEObjects( const css::uno::Reference< oo::vba::XHelperInterface >& xParent, const css::uno::Reference< css::uno::XComponentContext >& xContext, + const css::uno::Reference< css::container::XIndexAccess >& xIndexAccess ); + + // XEnumerationAccess + virtual css::uno::Type SAL_CALL getElementType() throw (css::uno::RuntimeException); + virtual css::uno::Reference< css::container::XEnumeration > SAL_CALL createEnumeration() throw (css::uno::RuntimeException); + + // ScVbaCollectionBaseImpl + virtual css::uno::Any createCollectionObject( const css::uno::Any& aSource ); + +}; +#endif //SC_VBA_OLEOBJECTS_HXX +