/************************************************************************* * * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * Copyright 2008 by Sun Microsystems, Inc. * * OpenOffice.org - a multi-platform office productivity suite * * $RCSfile: unoshap3.cxx,v $ * $Revision: 1.32 $ * * This file is part of OpenOffice.org. * * OpenOffice.org is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License version 3 * only, as published by the Free Software Foundation. * * OpenOffice.org 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 version 3 for more details * (a copy is included in the LICENSE file that accompanied this code). * * You should have received a copy of the GNU Lesser General Public License * version 3 along with OpenOffice.org. If not, see * * for a copy of the LGPLv3 License. * ************************************************************************/ // MARKER(update_precomp.py): autogen include statement, do not remove #include "precompiled_svx.hxx" #define _SVX_USE_UNOGLOBALS_ #include #include #include #include #include #include #include #include #include #include #include #include #include #include "globl3d.hxx" #include #include #include #include #include #include "svx/unoshprp.hxx" #include "svx/svdmodel.hxx" #include #include #include #include using ::rtl::OUString; using namespace ::vos; using namespace ::cppu; using namespace ::com::sun::star; using namespace ::com::sun::star::uno; using namespace ::com::sun::star::lang; using namespace ::com::sun::star::container; #define INTERFACE_TYPE( xint ) \ ::getCppuType((const Reference< xint >*)0) #define QUERYINT( xint ) \ if( rType == ::getCppuType((const Reference< xint >*)0) ) \ aAny <<= Reference< xint >(this) /*********************************************************************** * class Svx3DSceneObject * ***********************************************************************/ //---------------------------------------------------------------------- Svx3DSceneObject::Svx3DSceneObject( SdrObject* pObj, SvxDrawPage* pDrawPage ) throw() : SvxShape( pObj, aSvxMapProvider.GetMap(SVXMAP_3DSCENEOBJECT) ) , mxPage( pDrawPage ) { } //---------------------------------------------------------------------- Svx3DSceneObject::~Svx3DSceneObject() throw() { } //---------------------------------------------------------------------- void Svx3DSceneObject::Create( SdrObject* pNewObj, SvxDrawPage* pNewPage ) throw() { SvxShape::Create( pNewObj, pNewPage ); mxPage = pNewPage; } //---------------------------------------------------------------------- uno::Any SAL_CALL Svx3DSceneObject::queryAggregation( const uno::Type & rType ) throw(uno::RuntimeException) { uno::Any aAny; QUERYINT( drawing::XShapes ); else QUERYINT( container::XIndexAccess ); else QUERYINT( container::XElementAccess ); else return SvxShape::queryAggregation( rType ); return aAny; } uno::Any SAL_CALL Svx3DSceneObject::queryInterface( const uno::Type & rType ) throw( uno::RuntimeException ) { return SvxShape::queryInterface( rType ); } void SAL_CALL Svx3DSceneObject::acquire() throw ( ) { SvxShape::acquire(); } void SAL_CALL Svx3DSceneObject::release() throw ( ) { SvxShape::release(); } // XTypeProvider uno::Sequence< uno::Type > SAL_CALL Svx3DSceneObject::getTypes() throw (uno::RuntimeException) { return SvxShape::getTypes(); } uno::Sequence< sal_Int8 > SAL_CALL Svx3DSceneObject::getImplementationId() throw (uno::RuntimeException) { static uno::Sequence< sal_Int8 > aId; if( aId.getLength() == 0 ) { aId.realloc( 16 ); rtl_createUuid( (sal_uInt8 *)aId.getArray(), 0, sal_True ); } return aId; } //---------------------------------------------------------------------- void SAL_CALL Svx3DSceneObject::add( const Reference< drawing::XShape >& xShape ) throw( uno::RuntimeException) { OGuard aGuard( Application::GetSolarMutex() ); SvxShape* pShape = SvxShape::getImplementation( xShape ); if(!mpObj.is() || !mxPage.is() || pShape == NULL || NULL != pShape->GetSdrObject() ) throw uno::RuntimeException(); SdrObject* pSdrShape = mxPage->_CreateSdrObject( xShape ); if( pSdrShape->ISA(E3dObject) ) { mpObj->GetSubList()->NbcInsertObject( pSdrShape ); if(pShape) pShape->Create( pSdrShape, mxPage.get() ); } else { SdrObject::Free( pSdrShape ); throw uno::RuntimeException(); } if( mpModel ) mpModel->SetChanged(); } //---------------------------------------------------------------------- void SAL_CALL Svx3DSceneObject::remove( const Reference< drawing::XShape >& xShape ) throw( uno::RuntimeException ) { OGuard aGuard( Application::GetSolarMutex() ); SvxShape* pShape = SvxShape::getImplementation( xShape ); if(!mpObj.is() || pShape == NULL) throw uno::RuntimeException(); SdrObject* pSdrShape = pShape->GetSdrObject(); if(pSdrShape == NULL || pSdrShape->GetObjList()->GetOwnerObj() != mpObj.get()) { throw uno::RuntimeException(); } else { SdrObjList& rList = *pSdrShape->GetObjList(); const sal_uInt32 nObjCount = rList.GetObjCount(); sal_uInt32 nObjNum = 0; while( nObjNum < nObjCount ) { if(rList.GetObj( nObjNum ) == pSdrShape ) break; nObjNum++; } if( nObjNum < nObjCount ) { SdrObject* pObject = rList.NbcRemoveObject( nObjNum ); SdrObject::Free( pObject ); } else { DBG_ASSERT( 0, "Fatality! SdrObject is not belonging to its SdrObjList! [CL]" ); } } } //---------------------------------------------------------------------- sal_Int32 SAL_CALL Svx3DSceneObject::getCount() throw( uno::RuntimeException ) { OGuard aGuard( Application::GetSolarMutex() ); sal_Int32 nRetval = 0; if(mpObj.is() && mpObj->ISA(E3dPolyScene) && mpObj->GetSubList()) nRetval = mpObj->GetSubList()->GetObjCount(); return nRetval; } //---------------------------------------------------------------------- uno::Any SAL_CALL Svx3DSceneObject::getByIndex( sal_Int32 Index ) throw( lang::IndexOutOfBoundsException, lang::WrappedTargetException, uno::RuntimeException) { OGuard aGuard( Application::GetSolarMutex() ); if( !mpObj.is() || mpObj->GetSubList() == NULL ) throw uno::RuntimeException(); if( mpObj->GetSubList()->GetObjCount() <= (sal_uInt32)Index ) throw lang::IndexOutOfBoundsException(); SdrObject* pDestObj = mpObj->GetSubList()->GetObj( Index ); if(pDestObj == NULL) throw lang::IndexOutOfBoundsException(); Reference< drawing::XShape > xShape( pDestObj->getUnoShape(), uno::UNO_QUERY ); uno::Any aAny; aAny <<= xShape; return aAny; } //---------------------------------------------------------------------- // ::com::sun::star::container::XElementAccess uno::Type SAL_CALL Svx3DSceneObject::getElementType() throw( uno::RuntimeException ) { return ::getCppuType(( const Reference< drawing::XShape>*)0); } //---------------------------------------------------------------------- sal_Bool SAL_CALL Svx3DSceneObject::hasElements() throw( uno::RuntimeException ) { OGuard aGuard( Application::GetSolarMutex() ); return mpObj.is() && mpObj->GetSubList() && (mpObj->GetSubList()->GetObjCount() > 0); } //---------------------------------------------------------------------- static bool ConvertHomogenMatrixToObject( E3dObject* pObject, const Any& rValue ) { drawing::HomogenMatrix m; if( rValue >>= m ) { basegfx::B3DHomMatrix aMat; aMat.set(0, 0, m.Line1.Column1); aMat.set(0, 1, m.Line1.Column2); aMat.set(0, 2, m.Line1.Column3); aMat.set(0, 3, m.Line1.Column4); aMat.set(1, 0, m.Line2.Column1); aMat.set(1, 1, m.Line2.Column2); aMat.set(1, 2, m.Line2.Column3); aMat.set(1, 3, m.Line2.Column4); aMat.set(2, 0, m.Line3.Column1); aMat.set(2, 1, m.Line3.Column2); aMat.set(2, 2, m.Line3.Column3); aMat.set(2, 3, m.Line3.Column4); aMat.set(3, 0, m.Line4.Column1); aMat.set(3, 1, m.Line4.Column2); aMat.set(3, 2, m.Line4.Column3); aMat.set(3, 3, m.Line4.Column4); pObject->SetTransform(aMat); return true; } return false; } static void ConvertObjectToHomogenMatric( E3dObject* pObject, Any& rValue ) { drawing::HomogenMatrix aHomMat; const basegfx::B3DHomMatrix& rMat = pObject->GetTransform(); aHomMat.Line1.Column1 = rMat.get(0, 0); aHomMat.Line1.Column2 = rMat.get(0, 1); aHomMat.Line1.Column3 = rMat.get(0, 2); aHomMat.Line1.Column4 = rMat.get(0, 3); aHomMat.Line2.Column1 = rMat.get(1, 0); aHomMat.Line2.Column2 = rMat.get(1, 1); aHomMat.Line2.Column3 = rMat.get(1, 2); aHomMat.Line2.Column4 = rMat.get(1, 3); aHomMat.Line3.Column1 = rMat.get(2, 0); aHomMat.Line3.Column2 = rMat.get(2, 1); aHomMat.Line3.Column3 = rMat.get(2, 2); aHomMat.Line3.Column4 = rMat.get(2, 3); aHomMat.Line4.Column1 = rMat.get(3, 0); aHomMat.Line4.Column2 = rMat.get(3, 1); aHomMat.Line4.Column3 = rMat.get(3, 2); aHomMat.Line4.Column4 = rMat.get(3, 3); rValue <<= aHomMat; } //---------------------------------------------------------------------- #include struct ImpRememberTransAndRect { basegfx::B3DHomMatrix maMat; Rectangle maRect; }; bool Svx3DSceneObject::setPropertyValueImpl( const SfxItemPropertyMap* pProperty, const ::com::sun::star::uno::Any& rValue ) throw(::com::sun::star::beans::UnknownPropertyException, ::com::sun::star::beans::PropertyVetoException, ::com::sun::star::lang::IllegalArgumentException, ::com::sun::star::lang::WrappedTargetException, ::com::sun::star::uno::RuntimeException) { switch( pProperty->nWID ) { case OWN_ATTR_3D_VALUE_TRANSFORM_MATRIX: { // Transformationsmatrix in das Objekt packen if( ConvertHomogenMatrixToObject( static_cast< E3dObject* >( mpObj.get() ), rValue ) ) return true; break; } case OWN_ATTR_3D_VALUE_CAMERA_GEOMETRY: { // set CameraGeometry at scene E3dScene* pScene = static_cast< E3dScene* >( mpObj.get() ); drawing::CameraGeometry aCamGeo; if(rValue >>= aCamGeo) { basegfx::B3DPoint aVRP(aCamGeo.vrp.PositionX, aCamGeo.vrp.PositionY, aCamGeo.vrp.PositionZ); basegfx::B3DVector aVPN(aCamGeo.vpn.DirectionX, aCamGeo.vpn.DirectionY, aCamGeo.vpn.DirectionZ); basegfx::B3DVector aVUP(aCamGeo.vup.DirectionX, aCamGeo.vup.DirectionY, aCamGeo.vup.DirectionZ); // rescue scene transformation ImpRememberTransAndRect aSceneTAR; aSceneTAR.maMat = pScene->GetTransform(); aSceneTAR.maRect = pScene->GetSnapRect(); // rescue object transformations SdrObjListIter aIter(*pScene->GetSubList(), IM_DEEPWITHGROUPS); List aObjTrans; while(aIter.IsMore()) { E3dObject* p3DObj = (E3dObject*)aIter.Next(); basegfx::B3DHomMatrix* pNew = new basegfx::B3DHomMatrix; *pNew = p3DObj->GetTransform(); aObjTrans.Insert(pNew, LIST_APPEND); } // reset object transformations aIter.Reset(); while(aIter.IsMore()) { E3dObject* p3DObj = (E3dObject*)aIter.Next(); p3DObj->NbcResetTransform(); } // reset scene transformation and make a complete recalc pScene->NbcResetTransform(); // fill old camera from new parameters Camera3D aCam(pScene->GetCamera()); const Volume3D& rVolume = pScene->GetBoundVolume(); double fW = rVolume.getWidth(); double fH = rVolume.getHeight(); const SfxItemSet& rSceneSet = pScene->GetMergedItemSet(); double fCamPosZ = (double)((const SfxUInt32Item&)rSceneSet.Get(SDRATTR_3DSCENE_DISTANCE)).GetValue(); double fCamFocal = (double)((const SfxUInt32Item&)rSceneSet.Get(SDRATTR_3DSCENE_FOCAL_LENGTH)).GetValue(); aCam.SetAutoAdjustProjection(FALSE); aCam.SetViewWindow(- fW / 2, - fH / 2, fW, fH); basegfx::B3DPoint aLookAt; basegfx::B3DPoint aCamPos(0.0, 0.0, fCamPosZ); aCam.SetPosAndLookAt(aCamPos, aLookAt); aCam.SetFocalLength(fCamFocal / 100.0); aCam.SetDefaults(basegfx::B3DPoint(0.0, 0.0, fCamPosZ), aLookAt, fCamFocal / 100.0); aCam.SetDeviceWindow(Rectangle(0, 0, (long)fW, (long)fH)); // set at scene pScene->SetCamera(aCam); // #91047# use imported VRP, VPN and VUP (if used) sal_Bool bVRPUsed(!aVRP.equal(basegfx::B3DPoint(0.0, 0.0, 1.0))); sal_Bool bVPNUsed(!aVPN.equal(basegfx::B3DVector(0.0, 0.0, 1.0))); sal_Bool bVUPUsed(!aVUP.equal(basegfx::B3DVector(0.0, 1.0, 0.0))); if(bVRPUsed || bVPNUsed || bVUPUsed) { pScene->GetCameraSet().SetViewportValues(aVRP, aVPN, aVUP); } // set object transformations again at objects aIter.Reset(); sal_uInt32 nIndex(0L); while(aIter.IsMore()) { E3dObject* p3DObj = (E3dObject*)aIter.Next(); basegfx::B3DHomMatrix* pMat = (basegfx::B3DHomMatrix*)aObjTrans.GetObject(nIndex++); p3DObj->NbcSetTransform(*pMat); delete pMat; } // set scene transformation again at scene pScene->NbcSetTransform(aSceneTAR.maMat); pScene->FitSnapRectToBoundVol(); pScene->NbcSetSnapRect(aSceneTAR.maRect); // #86559# init transformation set to allow correct // calculation of BoundRect pScene->InitTransformationSet(); return true; } break; } default: return SvxShape::setPropertyValueImpl(pProperty, rValue); } throw IllegalArgumentException(); } //---------------------------------------------------------------------- bool Svx3DSceneObject::getPropertyValueImpl( const SfxItemPropertyMap* pProperty, ::com::sun::star::uno::Any& rValue ) throw(::com::sun::star::beans::UnknownPropertyException, ::com::sun::star::lang::WrappedTargetException, ::com::sun::star::uno::RuntimeException) { switch( pProperty->nWID ) { case OWN_ATTR_3D_VALUE_TRANSFORM_MATRIX: { // Objekt in eine homogene 4x4 Matrix packen ConvertObjectToHomogenMatric( static_cast< E3dObject* >( mpObj.get() ), rValue ); break; } case OWN_ATTR_3D_VALUE_CAMERA_GEOMETRY: { // get CameraGeometry from scene E3dScene* pScene = static_cast< E3dScene* >( mpObj.get() ); drawing::CameraGeometry aCamGeo; // fill Vectors from scene camera B3dCamera& aCameraSet = pScene->GetCameraSet(); basegfx::B3DPoint aVRP(aCameraSet.GetVRP()); basegfx::B3DVector aVPN(aCameraSet.GetVPN()); basegfx::B3DVector aVUP(aCameraSet.GetVUV()); // transfer to structure aCamGeo.vrp.PositionX = aVRP.getX(); aCamGeo.vrp.PositionY = aVRP.getY(); aCamGeo.vrp.PositionZ = aVRP.getZ(); aCamGeo.vpn.DirectionX = aVPN.getX(); aCamGeo.vpn.DirectionY = aVPN.getY(); aCamGeo.vpn.DirectionZ = aVPN.getZ(); aCamGeo.vup.DirectionX = aVUP.getX(); aCamGeo.vup.DirectionY = aVUP.getY(); aCamGeo.vup.DirectionZ = aVUP.getZ(); rValue <<= aCamGeo; break; } default: return SvxShape::getPropertyValueImpl( pProperty, rValue ); } return true; } // ::com::sun::star::lang::XServiceInfo uno::Sequence< OUString > SAL_CALL Svx3DSceneObject::getSupportedServiceNames() throw(uno::RuntimeException) { uno::Sequence< OUString > aSeq( SvxShape::getSupportedServiceNames() ); SvxServiceInfoHelper::addToSequence( aSeq, 1, "com.sun.star.drawing.Shape3DScene" ); return aSeq; } /*********************************************************************** * * ***********************************************************************/ //---------------------------------------------------------------------- Svx3DCubeObject::Svx3DCubeObject( SdrObject* pObj ) throw() : SvxShape( pObj, aSvxMapProvider.GetMap(SVXMAP_3DCUBEOBJEKT) ) { } //---------------------------------------------------------------------- Svx3DCubeObject::~Svx3DCubeObject() throw() { } //---------------------------------------------------------------------- bool Svx3DCubeObject::setPropertyValueImpl( const SfxItemPropertyMap* pProperty, const ::com::sun::star::uno::Any& rValue ) throw(::com::sun::star::beans::UnknownPropertyException, ::com::sun::star::beans::PropertyVetoException, ::com::sun::star::lang::IllegalArgumentException, ::com::sun::star::lang::WrappedTargetException, ::com::sun::star::uno::RuntimeException) { OGuard aGuard( Application::GetSolarMutex() ); switch( pProperty->nWID ) { case OWN_ATTR_3D_VALUE_TRANSFORM_MATRIX: { // Transformationsmatrix in das Objekt packen if( ConvertHomogenMatrixToObject( static_cast< E3dObject* >( mpObj.get() ), rValue ) ) return true; break; } case OWN_ATTR_3D_VALUE_POSITION: { // Position in das Objekt packen drawing::Position3D aUnoPos; if( rValue >>= aUnoPos ) { basegfx::B3DPoint aPos(aUnoPos.PositionX, aUnoPos.PositionY, aUnoPos.PositionZ); static_cast< E3dCubeObj* >( mpObj.get() )->SetCubePos(aPos); return true; } break; } case OWN_ATTR_3D_VALUE_SIZE: { // Groesse in das Objekt packen drawing::Direction3D aDirection; if( rValue >>= aDirection ) { basegfx::B3DVector aSize(aDirection.DirectionX, aDirection.DirectionY, aDirection.DirectionZ); static_cast< E3dCubeObj* >( mpObj.get() )->SetCubeSize(aSize); return true; } break; } case OWN_ATTR_3D_VALUE_POS_IS_CENTER: { sal_Bool bNew = sal_False; // sal_Bool bPosIsCenter in das Objekt packen if( rValue >>= bNew ) { static_cast< E3dCubeObj* >( mpObj.get() )->SetPosIsCenter(bNew); return true; } break; } default: return SvxShape::setPropertyValueImpl( pProperty, rValue ); } throw IllegalArgumentException(); } //---------------------------------------------------------------------- bool Svx3DCubeObject::getPropertyValueImpl( const SfxItemPropertyMap* pProperty, ::com::sun::star::uno::Any& rValue ) throw(::com::sun::star::beans::UnknownPropertyException, ::com::sun::star::lang::WrappedTargetException, ::com::sun::star::uno::RuntimeException) { switch( pProperty->nWID ) { case OWN_ATTR_3D_VALUE_TRANSFORM_MATRIX: { // Transformation in eine homogene Matrix packen ConvertObjectToHomogenMatric( static_cast< E3dObject* >( mpObj.get() ), rValue ); break; } case OWN_ATTR_3D_VALUE_POSITION: { // Position packen const basegfx::B3DPoint& rPos = ((E3dCubeObj*)mpObj.get())->GetCubePos(); drawing::Position3D aPos; aPos.PositionX = rPos.getX(); aPos.PositionY = rPos.getY(); aPos.PositionZ = rPos.getZ(); rValue <<= aPos; break; } case OWN_ATTR_3D_VALUE_SIZE: { // Groesse packen const basegfx::B3DVector& rSize = static_cast(mpObj.get())->GetCubeSize(); drawing::Direction3D aDir; aDir.DirectionX = rSize.getX(); aDir.DirectionY = rSize.getY(); aDir.DirectionZ = rSize.getZ(); rValue <<= aDir; break; } case OWN_ATTR_3D_VALUE_POS_IS_CENTER: { rValue <<= static_cast(mpObj.get())->GetPosIsCenter(); break; } default: return SvxShape::getPropertyValueImpl( pProperty, rValue ); } return true; } // ::com::sun::star::lang::XServiceInfo uno::Sequence< OUString > SAL_CALL Svx3DCubeObject::getSupportedServiceNames() throw(uno::RuntimeException) { uno::Sequence< OUString > aSeq( SvxShape::getSupportedServiceNames() ); SvxServiceInfoHelper::addToSequence( aSeq, 2, "com.sun.star.drawing.Shape3D", "com.sun.star.drawing.Shape3DCube"); return aSeq; } /*********************************************************************** * * ***********************************************************************/ //---------------------------------------------------------------------- Svx3DSphereObject::Svx3DSphereObject( SdrObject* pObj ) throw() : SvxShape( pObj, aSvxMapProvider.GetMap(SVXMAP_3DSPHEREOBJECT) ) { } //---------------------------------------------------------------------- Svx3DSphereObject::~Svx3DSphereObject() throw() { } //---------------------------------------------------------------------- bool Svx3DSphereObject::setPropertyValueImpl( const SfxItemPropertyMap* pProperty, const ::com::sun::star::uno::Any& rValue ) throw(::com::sun::star::beans::UnknownPropertyException, ::com::sun::star::beans::PropertyVetoException, ::com::sun::star::lang::IllegalArgumentException, ::com::sun::star::lang::WrappedTargetException, ::com::sun::star::uno::RuntimeException) { switch( pProperty->nWID ) { case OWN_ATTR_3D_VALUE_TRANSFORM_MATRIX: { // Transformationsmatrix in das Objekt packen if( ConvertHomogenMatrixToObject( static_cast< E3dObject* >( mpObj.get() ), rValue ) ) return true; break; } case OWN_ATTR_3D_VALUE_POSITION: { // Position in das Objekt packen drawing::Position3D aUnoPos; if( rValue >>= aUnoPos ) { basegfx::B3DPoint aPos(aUnoPos.PositionX, aUnoPos.PositionY, aUnoPos.PositionZ); static_cast(mpObj.get())->SetCenter(aPos); return true; } break; } case OWN_ATTR_3D_VALUE_SIZE: { // Groesse in das Objekt packen drawing::Direction3D aDir; if( rValue >>= aDir ) { basegfx::B3DVector aPos(aDir.DirectionX, aDir.DirectionY, aDir.DirectionZ); static_cast(mpObj.get())->SetSize(aPos); return true; } break; } default: return SvxShape::setPropertyValueImpl( pProperty, rValue ); } throw IllegalArgumentException(); } //---------------------------------------------------------------------- bool Svx3DSphereObject::getPropertyValueImpl( const SfxItemPropertyMap* pProperty, ::com::sun::star::uno::Any& rValue ) throw(::com::sun::star::beans::UnknownPropertyException, ::com::sun::star::lang::WrappedTargetException, ::com::sun::star::uno::RuntimeException) { switch( pProperty->nWID ) { case OWN_ATTR_3D_VALUE_TRANSFORM_MATRIX: { // Transformation in eine homogene Matrix packen ConvertObjectToHomogenMatric( static_cast< E3dObject* >( mpObj.get() ), rValue ); break; } case OWN_ATTR_3D_VALUE_POSITION: { // Position packen const basegfx::B3DPoint& rPos = ((E3dSphereObj*)mpObj.get())->Center(); drawing::Position3D aPos; aPos.PositionX = rPos.getX(); aPos.PositionY = rPos.getY(); aPos.PositionZ = rPos.getZ(); rValue <<= aPos; break; } case OWN_ATTR_3D_VALUE_SIZE: { // Groesse packen const basegfx::B3DVector& rSize = ((E3dSphereObj*)mpObj.get())->Size(); drawing::Direction3D aDir; aDir.DirectionX = rSize.getX(); aDir.DirectionY = rSize.getY(); aDir.DirectionZ = rSize.getZ(); rValue <<= aDir; break; } default: return SvxShape::getPropertyValueImpl( pProperty, rValue ); } return true; } // ::com::sun::star::lang::XServiceInfo uno::Sequence< OUString > SAL_CALL Svx3DSphereObject::getSupportedServiceNames() throw(uno::RuntimeException) { uno::Sequence< OUString > aSeq( SvxShape::getSupportedServiceNames() ); SvxServiceInfoHelper::addToSequence( aSeq, 2, "com.sun.star.drawing.Shape3D", "com.sun.star.drawing.Shape3DSphere"); return aSeq; } /*********************************************************************** * * ***********************************************************************/ //---------------------------------------------------------------------- Svx3DLatheObject::Svx3DLatheObject( SdrObject* pObj ) throw() : SvxShape( pObj, aSvxMapProvider.GetMap(SVXMAP_3DLATHEOBJECT) ) { } //---------------------------------------------------------------------- Svx3DLatheObject::~Svx3DLatheObject() throw() { } static bool PolyPolygonShape3D_to_B3dPolyPolygon( const Any& rValue, basegfx::B3DPolyPolygon& rResultPolygon ) { drawing::PolyPolygonShape3D aSourcePolyPolygon; if( !(rValue >>= aSourcePolyPolygon) ) return false; sal_Int32 nOuterSequenceCount = aSourcePolyPolygon.SequenceX.getLength(); if(nOuterSequenceCount != aSourcePolyPolygon.SequenceY.getLength() || nOuterSequenceCount != aSourcePolyPolygon.SequenceZ.getLength()) return false; drawing::DoubleSequence* pInnerSequenceX = aSourcePolyPolygon.SequenceX.getArray(); drawing::DoubleSequence* pInnerSequenceY = aSourcePolyPolygon.SequenceY.getArray(); drawing::DoubleSequence* pInnerSequenceZ = aSourcePolyPolygon.SequenceZ.getArray(); for(sal_Int32 a(0L);agetLength(); if(nInnerSequenceCount != pInnerSequenceY->getLength() || nInnerSequenceCount != pInnerSequenceZ->getLength()) { return false; } basegfx::B3DPolygon aNewPolygon; double* pArrayX = pInnerSequenceX->getArray(); double* pArrayY = pInnerSequenceY->getArray(); double* pArrayZ = pInnerSequenceZ->getArray(); for(sal_Int32 b(0L);brealloc(nPointCount); pOuterSequenceY->realloc(nPointCount); pOuterSequenceZ->realloc(nPointCount); double* pInnerSequenceX = pOuterSequenceX->getArray(); double* pInnerSequenceY = pOuterSequenceY->getArray(); double* pInnerSequenceZ = pOuterSequenceZ->getArray(); for(sal_uInt32 b(0L);bnWID ) { case OWN_ATTR_3D_VALUE_TRANSFORM_MATRIX: { // Transformationsmatrix in das Objekt packen if( ConvertHomogenMatrixToObject( static_cast< E3dObject* >( mpObj.get() ), rValue ) ) return true; break; } case OWN_ATTR_3D_VALUE_POLYPOLYGON3D: { // Polygondefinition in das Objekt packen basegfx::B3DPolyPolygon aNewB3DPolyPolygon; if( PolyPolygonShape3D_to_B3dPolyPolygon( rValue, aNewB3DPolyPolygon ) ) { // #105127# SetPolyPoly3D sets the Svx3DVerticalSegmentsItem to the number // of points of the polygon. Thus, value gets lost. To avoid this, rescue // item here and re-set after setting the polygon. const sal_uInt32 nPrevVerticalSegs(static_cast(mpObj.get())->GetVerticalSegments()); // Polygon setzen const basegfx::B3DHomMatrix aIdentity; const basegfx::B2DPolyPolygon aB2DPolyPolygon(basegfx::tools::createB2DPolyPolygonFromB3DPolyPolygon(aNewB3DPolyPolygon, aIdentity)); static_cast(mpObj.get())->SetPolyPoly2D(aB2DPolyPolygon); const sal_uInt32 nPostVerticalSegs(static_cast(mpObj.get())->GetVerticalSegments()); if(nPrevVerticalSegs != nPostVerticalSegs) { // restore the vertical segment count static_cast(mpObj.get())->SetMergedItem(Svx3DVerticalSegmentsItem(nPrevVerticalSegs)); } return true; } break; } default: return SvxShape::setPropertyValueImpl( pProperty, rValue ); } throw IllegalArgumentException(); } //---------------------------------------------------------------------- bool Svx3DLatheObject::getPropertyValueImpl( const SfxItemPropertyMap* pProperty, ::com::sun::star::uno::Any& rValue ) throw(::com::sun::star::beans::UnknownPropertyException, ::com::sun::star::lang::WrappedTargetException, ::com::sun::star::uno::RuntimeException) { switch( pProperty->nWID ) { case OWN_ATTR_3D_VALUE_TRANSFORM_MATRIX: { // Transformation in eine homogene Matrix packen drawing::HomogenMatrix aHomMat; basegfx::B3DHomMatrix aMat = static_cast(mpObj.get())->GetTransform(); // pack evtl. transformed matrix to output aHomMat.Line1.Column1 = aMat.get(0, 0); aHomMat.Line1.Column2 = aMat.get(0, 1); aHomMat.Line1.Column3 = aMat.get(0, 2); aHomMat.Line1.Column4 = aMat.get(0, 3); aHomMat.Line2.Column1 = aMat.get(1, 0); aHomMat.Line2.Column2 = aMat.get(1, 1); aHomMat.Line2.Column3 = aMat.get(1, 2); aHomMat.Line2.Column4 = aMat.get(1, 3); aHomMat.Line3.Column1 = aMat.get(2, 0); aHomMat.Line3.Column2 = aMat.get(2, 1); aHomMat.Line3.Column3 = aMat.get(2, 2); aHomMat.Line3.Column4 = aMat.get(2, 3); aHomMat.Line4.Column1 = aMat.get(3, 0); aHomMat.Line4.Column2 = aMat.get(3, 1); aHomMat.Line4.Column3 = aMat.get(3, 2); aHomMat.Line4.Column4 = aMat.get(3, 3); rValue <<= aHomMat; break; } case OWN_ATTR_3D_VALUE_POLYPOLYGON3D: { const basegfx::B2DPolyPolygon& rPolyPoly = static_cast(mpObj.get())->GetPolyPoly2D(); const basegfx::B3DPolyPolygon aB3DPolyPolygon(basegfx::tools::createB3DPolyPolygonFromB2DPolyPolygon(rPolyPoly)); B3dPolyPolygon_to_PolyPolygonShape3D(aB3DPolyPolygon, rValue); break; } default: return SvxShape::getPropertyValueImpl( pProperty, rValue ); } return true; } // ::com::sun::star::lang::XServiceInfo uno::Sequence< OUString > SAL_CALL Svx3DLatheObject::getSupportedServiceNames() throw(uno::RuntimeException) { uno::Sequence< OUString > aSeq( SvxShape::getSupportedServiceNames() ); SvxServiceInfoHelper::addToSequence( aSeq, 2, "com.sun.star.drawing.Shape3D", "com.sun.star.drawing.Shape3DLathe"); return aSeq; } /*********************************************************************** * * ***********************************************************************/ Svx3DExtrudeObject::Svx3DExtrudeObject( SdrObject* pObj ) throw() : SvxShape( pObj, aSvxMapProvider.GetMap(SVXMAP_3DEXTRUDEOBJECT) ) { } //---------------------------------------------------------------------- Svx3DExtrudeObject::~Svx3DExtrudeObject() throw() { } //---------------------------------------------------------------------- bool Svx3DExtrudeObject::setPropertyValueImpl( const SfxItemPropertyMap* pProperty, const ::com::sun::star::uno::Any& rValue ) throw(::com::sun::star::beans::UnknownPropertyException, ::com::sun::star::beans::PropertyVetoException, ::com::sun::star::lang::IllegalArgumentException, ::com::sun::star::lang::WrappedTargetException, ::com::sun::star::uno::RuntimeException) { switch( pProperty->nWID ) { case OWN_ATTR_3D_VALUE_TRANSFORM_MATRIX: { // Transformationsmatrix in das Objekt packen if( ConvertHomogenMatrixToObject( static_cast< E3dObject* >( mpObj.get() ), rValue ) ) return true; break; } case OWN_ATTR_3D_VALUE_POLYPOLYGON3D: { // Polygondefinition in das Objekt packen basegfx::B3DPolyPolygon aNewB3DPolyPolygon; if( PolyPolygonShape3D_to_B3dPolyPolygon( rValue, aNewB3DPolyPolygon ) ) { // Polygon setzen const basegfx::B3DHomMatrix aIdentity; const basegfx::B2DPolyPolygon aB2DPolyPolygon(basegfx::tools::createB2DPolyPolygonFromB3DPolyPolygon(aNewB3DPolyPolygon, aIdentity)); static_cast(mpObj.get())->SetExtrudePolygon(aB2DPolyPolygon); return true; } break; } default: return SvxShape::setPropertyValueImpl( pProperty, rValue ); } throw IllegalArgumentException(); } //---------------------------------------------------------------------- bool Svx3DExtrudeObject::getPropertyValueImpl( const SfxItemPropertyMap* pProperty, ::com::sun::star::uno::Any& rValue ) throw(::com::sun::star::beans::UnknownPropertyException, ::com::sun::star::lang::WrappedTargetException, ::com::sun::star::uno::RuntimeException) { switch( pProperty->nWID ) { case OWN_ATTR_3D_VALUE_TRANSFORM_MATRIX: { // Transformation in eine homogene Matrix packen drawing::HomogenMatrix aHomMat; basegfx::B3DHomMatrix aMat = ((E3dObject*)mpObj.get())->GetTransform(); // pack evtl. transformed matrix to output aHomMat.Line1.Column1 = aMat.get(0, 0); aHomMat.Line1.Column2 = aMat.get(0, 1); aHomMat.Line1.Column3 = aMat.get(0, 2); aHomMat.Line1.Column4 = aMat.get(0, 3); aHomMat.Line2.Column1 = aMat.get(1, 0); aHomMat.Line2.Column2 = aMat.get(1, 1); aHomMat.Line2.Column3 = aMat.get(1, 2); aHomMat.Line2.Column4 = aMat.get(1, 3); aHomMat.Line3.Column1 = aMat.get(2, 0); aHomMat.Line3.Column2 = aMat.get(2, 1); aHomMat.Line3.Column3 = aMat.get(2, 2); aHomMat.Line3.Column4 = aMat.get(2, 3); aHomMat.Line4.Column1 = aMat.get(3, 0); aHomMat.Line4.Column2 = aMat.get(3, 1); aHomMat.Line4.Column3 = aMat.get(3, 2); aHomMat.Line4.Column4 = aMat.get(3, 3); rValue <<= aHomMat; break; } case OWN_ATTR_3D_VALUE_POLYPOLYGON3D: { // Polygondefinition packen const basegfx::B2DPolyPolygon& rPolyPoly = static_cast(mpObj.get())->GetExtrudePolygon(); const basegfx::B3DPolyPolygon aB3DPolyPolygon(basegfx::tools::createB3DPolyPolygonFromB2DPolyPolygon(rPolyPoly)); B3dPolyPolygon_to_PolyPolygonShape3D(aB3DPolyPolygon, rValue); break; } default: return SvxShape::getPropertyValueImpl( pProperty, rValue ); } return true; } // ::com::sun::star::lang::XServiceInfo uno::Sequence< OUString > SAL_CALL Svx3DExtrudeObject::getSupportedServiceNames() throw(uno::RuntimeException) { uno::Sequence< OUString > aSeq( SvxShape::getSupportedServiceNames() ); SvxServiceInfoHelper::addToSequence( aSeq, 2, "com.sun.star.drawing.Shape3D", "com.sun.star.drawing.Shape3DExtrude"); return aSeq; } /*********************************************************************** * * ***********************************************************************/ //---------------------------------------------------------------------- Svx3DPolygonObject::Svx3DPolygonObject( SdrObject* pObj ) throw() : SvxShape( pObj, aSvxMapProvider.GetMap(SVXMAP_3DPOLYGONOBJECT) ) { } //---------------------------------------------------------------------- Svx3DPolygonObject::~Svx3DPolygonObject() throw() { } //---------------------------------------------------------------------- bool Svx3DPolygonObject::setPropertyValueImpl( const SfxItemPropertyMap* pProperty, const ::com::sun::star::uno::Any& rValue ) throw(::com::sun::star::beans::UnknownPropertyException, ::com::sun::star::beans::PropertyVetoException, ::com::sun::star::lang::IllegalArgumentException, ::com::sun::star::lang::WrappedTargetException, ::com::sun::star::uno::RuntimeException) { switch( pProperty->nWID ) { case OWN_ATTR_3D_VALUE_TRANSFORM_MATRIX: { // Transformationsmatrix in das Objekt packen if( ConvertHomogenMatrixToObject( static_cast< E3dObject* >( mpObj.get() ), rValue ) ) return true; break; } case OWN_ATTR_3D_VALUE_POLYPOLYGON3D: { // Polygondefinition in das Objekt packen basegfx::B3DPolyPolygon aNewB3DPolyPolygon; if( PolyPolygonShape3D_to_B3dPolyPolygon( rValue, aNewB3DPolyPolygon ) ) { // Polygon setzen static_cast(mpObj.get())->SetPolyPolygon3D(aNewB3DPolyPolygon); return true; } break; } case OWN_ATTR_3D_VALUE_NORMALSPOLYGON3D: { // Normalendefinition in das Objekt packen basegfx::B3DPolyPolygon aNewB3DPolyPolygon; if( PolyPolygonShape3D_to_B3dPolyPolygon( rValue, aNewB3DPolyPolygon ) ) { // Polygon setzen static_cast(mpObj.get())->SetPolyNormals3D(aNewB3DPolyPolygon); return true; } break; } case OWN_ATTR_3D_VALUE_TEXTUREPOLYGON3D: { // Texturdefinition in das Objekt packen basegfx::B3DPolyPolygon aNewB3DPolyPolygon; if( PolyPolygonShape3D_to_B3dPolyPolygon( rValue, aNewB3DPolyPolygon ) ) { // Polygon setzen const basegfx::B3DHomMatrix aIdentity; const basegfx::B2DPolyPolygon aB2DPolyPolygon(basegfx::tools::createB2DPolyPolygonFromB3DPolyPolygon(aNewB3DPolyPolygon, aIdentity)); static_cast(mpObj.get())->SetPolyTexture2D(aB2DPolyPolygon); return true; } break; } case OWN_ATTR_3D_VALUE_LINEONLY: { sal_Bool bNew = sal_False; if( rValue >>= bNew ) { static_cast(mpObj.get())->SetLineOnly(bNew); return true; } break; } default: return SvxShape::setPropertyValueImpl( pProperty, rValue ); } throw IllegalArgumentException(); } //---------------------------------------------------------------------- bool Svx3DPolygonObject::getPropertyValueImpl( const SfxItemPropertyMap* pProperty, ::com::sun::star::uno::Any& rValue ) throw(::com::sun::star::beans::UnknownPropertyException, ::com::sun::star::lang::WrappedTargetException, ::com::sun::star::uno::RuntimeException) { switch( pProperty->nWID ) { case OWN_ATTR_3D_VALUE_TRANSFORM_MATRIX: { ConvertObjectToHomogenMatric( static_cast< E3dObject* >( mpObj.get() ), rValue ); break; } case OWN_ATTR_3D_VALUE_POLYPOLYGON3D: { B3dPolyPolygon_to_PolyPolygonShape3D(static_cast(mpObj.get())->GetPolyPolygon3D(),rValue); break; } case OWN_ATTR_3D_VALUE_NORMALSPOLYGON3D: { B3dPolyPolygon_to_PolyPolygonShape3D(static_cast(mpObj.get())->GetPolyNormals3D(),rValue); break; } case OWN_ATTR_3D_VALUE_TEXTUREPOLYGON3D: { // Texturdefinition packen const basegfx::B2DPolyPolygon& rPolyPoly = static_cast(mpObj.get())->GetPolyTexture2D(); const basegfx::B3DPolyPolygon aB3DPolyPolygon(basegfx::tools::createB3DPolyPolygonFromB2DPolyPolygon(rPolyPoly)); B3dPolyPolygon_to_PolyPolygonShape3D(aB3DPolyPolygon,rValue); break; } case OWN_ATTR_3D_VALUE_LINEONLY: { rValue <<= (sal_Bool)static_cast(mpObj.get())->GetLineOnly(); break; } default: return SvxShape::getPropertyValueImpl( pProperty, rValue ); } return true; } // ::com::sun::star::lang::XServiceInfo uno::Sequence< OUString > SAL_CALL Svx3DPolygonObject::getSupportedServiceNames() throw(uno::RuntimeException) { Sequence< OUString > aSeq( SvxShape::getSupportedServiceNames() ); SvxServiceInfoHelper::addToSequence( aSeq, 2, "com.sun.star.drawing.Shape3D", "com.sun.star.drawing.Shape3DPolygon"); return aSeq; } // eof