1 /************************************************************** 2 * 3 * Licensed to the Apache Software Foundation (ASF) under one 4 * or more contributor license agreements. See the NOTICE file 5 * distributed with this work for additional information 6 * regarding copyright ownership. The ASF licenses this file 7 * to you under the Apache License, Version 2.0 (the 8 * "License"); you may not use this file except in compliance 9 * with the License. You may obtain a copy of the License at 10 * 11 * http://www.apache.org/licenses/LICENSE-2.0 12 * 13 * Unless required by applicable law or agreed to in writing, 14 * software distributed under the License is distributed on an 15 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY 16 * KIND, either express or implied. See the License for the 17 * specific language governing permissions and limitations 18 * under the License. 19 * 20 *************************************************************/ 21 22 23 24 #include "vbaframe.hxx" 25 #include "vbanewfont.hxx" 26 #include "vbacontrols.hxx" 27 #include <ooo/vba/msforms/fmBorderStyle.hpp> 28 #include <ooo/vba/msforms/fmSpecialEffect.hpp> 29 30 using namespace com::sun::star; 31 using namespace ooo::vba; 32 33 34 const static rtl::OUString LABEL( RTL_CONSTASCII_USTRINGPARAM("Label") ); 35 36 ScVbaFrame::ScVbaFrame( 37 const uno::Reference< XHelperInterface >& xParent, 38 const uno::Reference< uno::XComponentContext >& xContext, 39 const uno::Reference< uno::XInterface >& xControl, 40 const uno::Reference< frame::XModel >& xModel, 41 ov::AbstractGeometryAttributes* pGeomHelper, 42 const css::uno::Reference< css::awt::XControl >& xDialog ) : 43 FrameImpl_BASE( xParent, xContext, xControl, xModel, pGeomHelper ), 44 mxDialog( xDialog ) 45 { 46 } 47 48 // XFrame attributes 49 50 rtl::OUString SAL_CALL ScVbaFrame::getCaption() throw (css::uno::RuntimeException) 51 { 52 rtl::OUString Label; 53 m_xProps->getPropertyValue( LABEL ) >>= Label; 54 return Label; 55 } 56 57 void SAL_CALL ScVbaFrame::setCaption( const rtl::OUString& _caption ) throw (::com::sun::star::uno::RuntimeException) 58 { 59 m_xProps->setPropertyValue( LABEL, uno::makeAny( _caption ) ); 60 } 61 62 sal_Int32 SAL_CALL ScVbaFrame::getSpecialEffect() throw (uno::RuntimeException) 63 { 64 return msforms::fmSpecialEffect::fmSpecialEffectEtched; 65 } 66 67 void SAL_CALL ScVbaFrame::setSpecialEffect( sal_Int32 /*nSpecialEffect*/ ) throw (uno::RuntimeException) 68 { 69 } 70 71 sal_Int32 SAL_CALL ScVbaFrame::getBorderStyle() throw (uno::RuntimeException) 72 { 73 return msforms::fmBorderStyle::fmBorderStyleNone; 74 } 75 76 void SAL_CALL ScVbaFrame::setBorderStyle( sal_Int32 /*nBorderStyle*/ ) throw (uno::RuntimeException) 77 { 78 } 79 80 uno::Reference< msforms::XNewFont > SAL_CALL ScVbaFrame::getFont() throw (uno::RuntimeException) 81 { 82 return new VbaNewFont( this, mxContext, m_xProps ); 83 } 84 85 // XFrame methods 86 87 uno::Any SAL_CALL ScVbaFrame::Controls( const uno::Any& rIndex ) throw (uno::RuntimeException) 88 { 89 // horizontal anchor of frame children is inside border line (add one unit to compensate border line width) 90 double fOffsetX = mpGeometryHelper->getOffsetX() + getLeft() + 1.0; 91 // vertical anchor of frame children is inside border line (add half of text height and one unit to compensate border line width) 92 double fOffsetY = mpGeometryHelper->getOffsetY() + getTop() + (getFont()->getSize() / 2.0) + 1.0; 93 94 uno::Reference< XCollection > xControls( new ScVbaControls( this, mxContext, mxDialog, m_xModel, fOffsetX, fOffsetY ) ); 95 if( rIndex.hasValue() ) 96 return uno::Any( xControls->Item( rIndex, uno::Any() ) ); 97 return uno::Any( xControls ); 98 } 99 100 // XHelperInterface 101 102 VBAHELPER_IMPL_XHELPERINTERFACE( ScVbaFrame, "ooo.vba.msforms.Frame" ) 103