1*aaef562fSAndrew Rist /************************************************************** 2cdf0e10cSrcweir * 3*aaef562fSAndrew Rist * Licensed to the Apache Software Foundation (ASF) under one 4*aaef562fSAndrew Rist * or more contributor license agreements. See the NOTICE file 5*aaef562fSAndrew Rist * distributed with this work for additional information 6*aaef562fSAndrew Rist * regarding copyright ownership. The ASF licenses this file 7*aaef562fSAndrew Rist * to you under the Apache License, Version 2.0 (the 8*aaef562fSAndrew Rist * "License"); you may not use this file except in compliance 9*aaef562fSAndrew Rist * with the License. You may obtain a copy of the License at 10*aaef562fSAndrew Rist * 11*aaef562fSAndrew Rist * http://www.apache.org/licenses/LICENSE-2.0 12*aaef562fSAndrew Rist * 13*aaef562fSAndrew Rist * Unless required by applicable law or agreed to in writing, 14*aaef562fSAndrew Rist * software distributed under the License is distributed on an 15*aaef562fSAndrew Rist * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY 16*aaef562fSAndrew Rist * KIND, either express or implied. See the License for the 17*aaef562fSAndrew Rist * specific language governing permissions and limitations 18*aaef562fSAndrew Rist * under the License. 19*aaef562fSAndrew Rist * 20*aaef562fSAndrew Rist *************************************************************/ 21*aaef562fSAndrew Rist 22*aaef562fSAndrew Rist 23cdf0e10cSrcweir 24cdf0e10cSrcweir #ifndef INCLUDED_SLIDESHOW_ANIMATIONACTIVITY_HXX 25cdf0e10cSrcweir #define INCLUDED_SLIDESHOW_ANIMATIONACTIVITY_HXX 26cdf0e10cSrcweir 27cdf0e10cSrcweir #include "activity.hxx" 28cdf0e10cSrcweir #include "animatableshape.hxx" 29cdf0e10cSrcweir #include "shapeattributelayer.hxx" 30cdf0e10cSrcweir 31cdf0e10cSrcweir 32cdf0e10cSrcweir /* Definition of AnimationActivity interface */ 33cdf0e10cSrcweir 34cdf0e10cSrcweir namespace slideshow 35cdf0e10cSrcweir { 36cdf0e10cSrcweir namespace internal 37cdf0e10cSrcweir { 38cdf0e10cSrcweir 39cdf0e10cSrcweir /** Extends the Activity interface with animation-specific functions 40cdf0e10cSrcweir */ 41cdf0e10cSrcweir class AnimationActivity : public Activity 42cdf0e10cSrcweir { 43cdf0e10cSrcweir public: 44cdf0e10cSrcweir /** Sets targets (shape and attributeLayer) 45cdf0e10cSrcweir 46cdf0e10cSrcweir Since attribute layers can only be generated when the 47cdf0e10cSrcweir animation starts, the Activity owner must be able to 48cdf0e10cSrcweir pass it into the Activity after initial creation. The 49cdf0e10cSrcweir same applies to the actual shape the animation must 50cdf0e10cSrcweir run for, since e.g. subsetted shapes are generated 51cdf0e10cSrcweir close before the animation starts, too (this is not 52cdf0e10cSrcweir necessary in and out of itself, but for performance 53cdf0e10cSrcweir reasons. Otherwise, character iterations produce tons 54cdf0e10cSrcweir of subset shapes). 55cdf0e10cSrcweir 56cdf0e10cSrcweir @param rShape 57cdf0e10cSrcweir Shape to play the animation on. 58cdf0e10cSrcweir 59cdf0e10cSrcweir @param rAttrLayer 60cdf0e10cSrcweir Attribute layer to change the animated values on. 61cdf0e10cSrcweir */ 62cdf0e10cSrcweir virtual void setTargets( const AnimatableShapeSharedPtr& rShape, 63cdf0e10cSrcweir const ShapeAttributeLayerSharedPtr& rAttrLayer ) = 0; 64cdf0e10cSrcweir }; 65cdf0e10cSrcweir 66cdf0e10cSrcweir typedef ::boost::shared_ptr< AnimationActivity > AnimationActivitySharedPtr; 67cdf0e10cSrcweir 68cdf0e10cSrcweir } 69cdf0e10cSrcweir } 70cdf0e10cSrcweir 71cdf0e10cSrcweir #endif /* INCLUDED_SLIDESHOW_ANIMATIONACTIVITY_HXX */ 72