/* -*- 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 #include #include #include "XMLAnchorTypePropHdl.hxx" #include #include #include using namespace ::com::sun::star::uno; using namespace ::com::sun::star::frame; using namespace ::com::sun::star::drawing; using namespace ::com::sun::star::beans; using namespace ::com::sun::star::text; using namespace ::com::sun::star::container; using namespace ::com::sun::star::xml::sax; XMLTextShapeImportHelper::XMLTextShapeImportHelper( SvXMLImport& rImp ) : XMLShapeImportHelper( rImp, rImp.GetModel(), XMLTextImportHelper::CreateShapeExtPropMapper(rImp) ), rImport( rImp ), sAnchorType("AnchorType"), sAnchorPageNo("AnchorPageNo"), sVertOrientPosition("VertOrientPosition") { Reference < XDrawPageSupplier > xDPS( rImp.GetModel(), UNO_QUERY ); if( xDPS.is() ) { Reference < XShapes > xShapes( xDPS->getDrawPage(), UNO_QUERY ); pushGroupForSorting( xShapes ); } } XMLTextShapeImportHelper::~XMLTextShapeImportHelper() { popGroupAndSort(); } void XMLTextShapeImportHelper::addShape( Reference< XShape >& rShape, const Reference< XAttributeList >& xAttrList, Reference< XShapes >& rShapes ) { if( rShapes.is() ) { // It's a group shape or 3DScene , so we have to call the base class method. XMLShapeImportHelper::addShape( rShape, xAttrList, rShapes ); return; } TextContentAnchorType eAnchorType = TextContentAnchorType_AT_PARAGRAPH; sal_Int16 nPage = 0; sal_Int32 nY = 0; UniReference < XMLTextImportHelper > xTxtImport = rImport.GetTextImport(); const SvXMLTokenMap& rTokenMap = xTxtImport->GetTextFrameAttrTokenMap(); sal_Int16 nAttrCount = xAttrList.is() ? xAttrList->getLength() : 0; for( sal_Int16 i=0; i < nAttrCount; i++ ) { const OUString& rAttrName = xAttrList->getNameByIndex( i ); const OUString& rValue = xAttrList->getValueByIndex( i ); OUString aLocalName; sal_uInt16 nPrefix = rImport.GetNamespaceMap().GetKeyByAttrName( rAttrName, &aLocalName ); switch( rTokenMap.Get( nPrefix, aLocalName ) ) { case XML_TOK_TEXT_FRAME_ANCHOR_TYPE: { TextContentAnchorType eNew; // OD 2004-06-01 #i26791# - allow all anchor types if ( XMLAnchorTypePropHdl::convert( rValue, eNew ) ) { eAnchorType = eNew; } } break; case XML_TOK_TEXT_FRAME_ANCHOR_PAGE_NUMBER: { sal_Int32 nTmp; if (::sax::Converter::convertNumber(nTmp, rValue, 1, SHRT_MAX)) nPage = (sal_Int16)nTmp; } break; case XML_TOK_TEXT_FRAME_Y: rImport.GetMM100UnitConverter().convertMeasureToCore( nY, rValue ); break; } } Reference < XPropertySet > xPropSet( rShape, UNO_QUERY ); Any aAny; // anchor type aAny <<= eAnchorType; xPropSet->setPropertyValue( sAnchorType, aAny ); Reference < XTextContent > xTxtCntnt( rShape, UNO_QUERY ); xTxtImport->InsertTextContent( xTxtCntnt ); // page number (must be set after the frame is inserted, because it // will be overwritten then inserting the frame. switch( eAnchorType ) { case TextContentAnchorType_AT_PAGE: // only set positive page numbers if ( nPage > 0 ) { aAny <<= nPage; xPropSet->setPropertyValue( sAnchorPageNo, aAny ); } break; case TextContentAnchorType_AS_CHARACTER: aAny <<= nY; xPropSet->setPropertyValue( sVertOrientPosition, aAny ); break; default: break; } } /* vim:set shiftwidth=4 softtabstop=4 expandtab: */