/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ /* * This file is part of the LibreOffice project. * * This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. * * This file incorporates work covered by the following license notice: * * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements. See the NOTICE file distributed * with this work for additional information regarding copyright * ownership. The ASF licenses this file to you under the Apache * License, Version 2.0 (the "License"); you may not use this file * except in compliance with the License. You may obtain a copy of * the License at http://www.apache.org/licenses/LICENSE-2.0 . */ #include #include #include #include #include using namespace ::com::sun::star::drawing; using namespace ::com::sun::star::text; namespace oox::drawingml { TextBodyProperties::TextBodyProperties() : mbAnchorCtr(false) , meVA( TextVerticalAdjust_TOP ) { } /* For Legacy purposes: TODO: Check if it is required at all! */ void TextBodyProperties::pushVertSimulation() { sal_Int32 tVert = moVert.get( XML_horz ); if( !(tVert == XML_vert || tVert == XML_eaVert || tVert == XML_vert270 || tVert == XML_mongolianVert) ) return; // #160799# fake different vertical text modes by top-bottom writing mode maPropertyMap.setProperty( PROP_TextWritingMode, WritingMode_TB_RL); // workaround for TB_LR as using WritingMode2 doesn't work if( meVA != TextVerticalAdjust_CENTER ) maPropertyMap.setProperty( PROP_TextHorizontalAdjust, (tVert == XML_vert270) ? TextHorizontalAdjust_RIGHT : TextHorizontalAdjust_LEFT); if( tVert == XML_vert270 ) maPropertyMap.setProperty( PROP_TextVerticalAdjust, TextVerticalAdjust_BOTTOM); if( ( tVert == XML_vert && meVA == TextVerticalAdjust_TOP ) || ( tVert == XML_vert270 && meVA == TextVerticalAdjust_BOTTOM ) ) maPropertyMap.setProperty( PROP_TextHorizontalAdjust, TextHorizontalAdjust_RIGHT); else if( meVA == TextVerticalAdjust_CENTER ) maPropertyMap.setProperty( PROP_TextHorizontalAdjust, TextHorizontalAdjust_CENTER); } /* Push adjusted values, taking into consideration Shape Rotation */ void TextBodyProperties::pushRotationAdjustments() { sal_Int32 nOff = 0; static sal_Int32 const aProps[] { PROP_TextLeftDistance, PROP_TextUpperDistance, PROP_TextRightDistance, PROP_TextLowerDistance }; sal_Int32 n = SAL_N_ELEMENTS( aProps ); switch( moRotation.get(0) ) { case 90*1*60000: nOff = 3; break; case 90*2*60000: nOff = 2; break; case 90*3*60000: nOff = 1; break; default: break; } for( sal_Int32 i = 0; i < n; i++ ) { sal_Int32 nVal = 0; // Hack for n#760986 // TODO: Preferred method would be to have a textbox on top // of the shape and the place it according to the (off,ext) if( nOff == 0 && moTextOffLeft ) nVal = *moTextOffLeft; if( nOff == 1 && moTextOffUpper ) nVal = *moTextOffUpper; if( nOff == 2 && moTextOffRight ) nVal = *moTextOffRight; if( nOff == 3 && moTextOffLower ) nVal = *moTextOffLower; if( nVal < 0 ) nVal = 0; if( moInsets[i] ) maPropertyMap.setProperty( aProps[ nOff ], static_cast< sal_Int32 >( *moInsets[i] + nVal )); else if( nVal ) maPropertyMap.setProperty( aProps[ nOff ], nVal ); nOff = (nOff+1) % n; } } } // namespace oox::drawingml /* vim:set shiftwidth=4 softtabstop=4 expandtab: */