| /************************************************************** |
| * |
| * 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 |
| * |
| * Unless required by applicable law or agreed to in writing, |
| * software distributed under the License is distributed on an |
| * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY |
| * KIND, either express or implied. See the License for the |
| * specific language governing permissions and limitations |
| * under the License. |
| * |
| *************************************************************/ |
| |
| |
| |
| #include "oox/vml/vmlshapecontainer.hxx" |
| |
| #include "oox/vml/vmldrawing.hxx" |
| #include "oox/vml/vmlshape.hxx" |
| |
| namespace oox { |
| namespace vml { |
| |
| // ============================================================================ |
| |
| using namespace ::com::sun::star::awt; |
| using namespace ::com::sun::star::drawing; |
| using namespace ::com::sun::star::uno; |
| |
| using ::rtl::OUString; |
| |
| // ============================================================================ |
| |
| namespace { |
| |
| template< typename ShapeType > |
| void lclMapShapesById( RefMap< OUString, ShapeType >& orMap, const RefVector< ShapeType >& rVector ) |
| { |
| for( typename RefVector< ShapeType >::const_iterator aIt = rVector.begin(), aEnd = rVector.end(); aIt != aEnd; ++aIt ) |
| { |
| const OUString& rShapeId = (*aIt)->getShapeId(); |
| OSL_ENSURE( rShapeId.getLength() > 0, "lclMapShapesById - missing shape identifier" ); |
| if( rShapeId.getLength() > 0 ) |
| { |
| OSL_ENSURE( orMap.find( rShapeId ) == orMap.end(), "lclMapShapesById - shape identifier already used" ); |
| orMap[ rShapeId ] = *aIt; |
| } |
| } |
| } |
| |
| } // namespace |
| |
| // ============================================================================ |
| |
| ShapeContainer::ShapeContainer( Drawing& rDrawing ) : |
| mrDrawing( rDrawing ) |
| { |
| } |
| |
| ShapeContainer::~ShapeContainer() |
| { |
| } |
| |
| ShapeType& ShapeContainer::createShapeType() |
| { |
| ::boost::shared_ptr< ShapeType > xShape( new ShapeType( mrDrawing ) ); |
| maTypes.push_back( xShape ); |
| return *xShape; |
| } |
| |
| void ShapeContainer::finalizeFragmentImport() |
| { |
| // map all shape templates by shape identifier |
| lclMapShapesById( maTypesById, maTypes ); |
| // map all shapes by shape identifier |
| lclMapShapesById( maShapesById, maShapes ); |
| /* process all shapes (map all children templates/shapes in group shapes, |
| resolve template references in all shapes) */ |
| maShapes.forEachMem( &ShapeBase::finalizeFragmentImport ); |
| } |
| |
| const ShapeType* ShapeContainer::getShapeTypeById( const OUString& rShapeId, bool bDeep ) const |
| { |
| // search in own shape template list |
| if( const ShapeType* pType = maTypesById.get( rShapeId ).get() ) |
| return pType; |
| // search deep in child shapes |
| if( bDeep ) |
| for( ShapeVector::const_iterator aVIt = maShapes.begin(), aVEnd = maShapes.end(); aVIt != aVEnd; ++aVIt ) |
| if( const ShapeType* pType = (*aVIt)->getChildTypeById( rShapeId ) ) |
| return pType; |
| return 0; |
| } |
| |
| const ShapeBase* ShapeContainer::getShapeById( const OUString& rShapeId, bool bDeep ) const |
| { |
| // search in own shape list |
| if( const ShapeBase* pShape = maShapesById.get( rShapeId ).get() ) |
| return pShape; |
| // search deep in child shapes |
| if( bDeep ) |
| for( ShapeVector::const_iterator aVIt = maShapes.begin(), aVEnd = maShapes.end(); aVIt != aVEnd; ++aVIt ) |
| if( const ShapeBase* pShape = (*aVIt)->getChildById( rShapeId ) ) |
| return pShape; |
| return 0; |
| } |
| |
| const ShapeBase* ShapeContainer::getFirstShape() const |
| { |
| OSL_ENSURE( mrDrawing.getType() == VMLDRAWING_WORD, "ShapeContainer::getFirstShape - illegal call, Word filter only" ); |
| OSL_ENSURE( maShapes.size() == 1, "ShapeContainer::getFirstShape - single shape expected" ); |
| return maShapes.get( 0 ).get(); |
| } |
| |
| void ShapeContainer::convertAndInsert( const Reference< XShapes >& rxShapes, const ShapeParentAnchor* pParentAnchor ) const |
| { |
| for( ShapeVector::const_iterator aIt = maShapes.begin(), aEnd = maShapes.end(); aIt != aEnd; ++aIt ) |
| (*aIt)->convertAndInsert( rxShapes, pParentAnchor ); |
| } |
| |
| // ============================================================================ |
| |
| } // namespace vml |
| } // namespace oox |