/* -*- 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 "oox/ppt/animationspersist.hxx" #include #include #include #include #include #include #include "oox/drawingml/shape.hxx" using namespace ::com::sun::star::uno; using namespace ::com::sun::star::presentation; using namespace ::com::sun::star::drawing; using namespace ::com::sun::star::text; namespace oox { namespace ppt { void ShapeTargetElement::convert( ::com::sun::star::uno::Any & rTarget, sal_Int16 & rSubType ) const { switch(mnType) { case XML_subSp: rSubType = ShapeAnimationSubType::AS_WHOLE; break; case XML_bg: rSubType = ShapeAnimationSubType::ONLY_BACKGROUND; break; case XML_txEl: { ParagraphTarget aParaTarget; Reference< XShape > xShape; rTarget >>= xShape; aParaTarget.Shape = xShape; rSubType = ShapeAnimationSubType::ONLY_TEXT; Reference< XText > xText( xShape, UNO_QUERY ); if( xText.is() ) { switch(mnRangeType) { case XML_charRg: // TODO calculate the corresponding paragraph for the text range.... SAL_INFO("oox.ppt", "OOX: TODO calculate the corresponding paragraph for the text range..." ); break; case XML_pRg: aParaTarget.Paragraph = static_cast< sal_Int16 >( maRange.start ); // TODO what to do with more than one. SAL_INFO("oox.ppt", "OOX: TODO what to do with more than one" ); break; } rTarget = makeAny( aParaTarget ); } break; } default: break; } } Any AnimTargetElement::convert(const SlidePersistPtr & pSlide, sal_Int16 & nSubType) const { Any aTarget; // see sd/source/files/ppt/pptinanimations.cxx:3191 (in importTargetElementContainer()) switch(mnType) { case XML_inkTgt: // TODO SAL_INFO("oox.ppt", "OOX: TODO inkTgt" ); break; case XML_sldTgt: // TODO SAL_INFO("oox.ppt", "OOX: TODO sldTgt" ); break; case XML_sndTgt: aTarget = makeAny(msValue); break; case XML_spTgt: { OUString sShapeName = msValue; // bnc#705982 - catch referenced diagram fallback shapes if( maShapeTarget.mnType == XML_dgm ) sShapeName = maShapeTarget.msSubShapeId; Any rTarget; ::oox::drawingml::ShapePtr pShape = pSlide->getShape(sShapeName); SAL_WARN_IF( !pShape, "oox.ppt", "failed to locate Shape"); if( pShape ) { Reference< XShape > xShape( pShape->getXShape() ); SAL_WARN_IF( !xShape.is(), "oox.ppt", "fail to get XShape from shape" ); if( xShape.is() ) { rTarget <<= xShape; maShapeTarget.convert(rTarget, nSubType); aTarget = rTarget; } } break; } default: break; } return aTarget; } // BEGIN CUT&PASTE from sd/source/filter/ppt/pptinanimations.cxx /** this adds an any to another any. if rNewValue is empty, rOldValue is returned. if rOldValue is empty, rNewValue is returned. if rOldValue contains a value, a sequence with rOldValue and rNewValue is returned. if rOldValue contains a sequence, a new sequence with the old sequence and rNewValue is returned. */ static Any addToSequence( const Any& rOldValue, const Any& rNewValue ) { if( !rNewValue.hasValue() ) { return rOldValue; } else if( !rOldValue.hasValue() ) { return rNewValue; } else { Sequence< Any > aNewSeq; if( rOldValue >>= aNewSeq ) { sal_Int32 nSize = aNewSeq.getLength(); aNewSeq.realloc(nSize+1); aNewSeq[nSize] = rNewValue; } else { aNewSeq.realloc(2); aNewSeq[0] = rOldValue; aNewSeq[1] = rNewValue; } return makeAny( aNewSeq ); } } // END Any AnimationCondition::convert(const SlidePersistPtr & pSlide) const { Any aAny; if( mpTarget ) { sal_Int16 nSubType; aAny = mpTarget->convert( pSlide, nSubType ); } else { aAny = maValue; } return aAny; } Any AnimationCondition::convertList(const SlidePersistPtr & pSlide, const AnimationConditionList & l) { Any aAny; for( AnimationConditionList::const_iterator iter = l.begin(); iter != l.end(); ++iter) { aAny = addToSequence( aAny, iter->convert(pSlide) ); } return aAny; } } } /* vim:set shiftwidth=4 softtabstop=4 expandtab: */