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_ENUMANIMATION_HXX 25cdf0e10cSrcweir #define INCLUDED_SLIDESHOW_ENUMANIMATION_HXX 26cdf0e10cSrcweir 27cdf0e10cSrcweir #include "animation.hxx" 28cdf0e10cSrcweir 29cdf0e10cSrcweir 30cdf0e10cSrcweir /* Definition of EnumAnimation interface */ 31cdf0e10cSrcweir 32cdf0e10cSrcweir namespace slideshow 33cdf0e10cSrcweir { 34cdf0e10cSrcweir namespace internal 35cdf0e10cSrcweir { 36cdf0e10cSrcweir /** Interface defining an enum animation. 37cdf0e10cSrcweir 38cdf0e10cSrcweir This interface is a specialization of the Animation 39cdf0e10cSrcweir interface, and is used to animate attributes representable 40cdf0e10cSrcweir by a set of constant values, such as UNO constantsm, or enums. 41cdf0e10cSrcweir */ 42cdf0e10cSrcweir class EnumAnimation : public Animation 43cdf0e10cSrcweir { 44cdf0e10cSrcweir public: 45cdf0e10cSrcweir typedef sal_Int16 ValueType; 46cdf0e10cSrcweir 47cdf0e10cSrcweir /** Set the animation to value k 48cdf0e10cSrcweir 49cdf0e10cSrcweir @param k 50cdf0e10cSrcweir Current animation value (must be in an 51cdf0e10cSrcweir attribute-specific permissible range). Overflowing 52cdf0e10cSrcweir values will be clipped to the permissible range 53cdf0e10cSrcweir internally. 54cdf0e10cSrcweir */ 55cdf0e10cSrcweir virtual bool operator()( ValueType k ) = 0; 56cdf0e10cSrcweir 57cdf0e10cSrcweir /** Request the underlying value for this animation. 58cdf0e10cSrcweir 59cdf0e10cSrcweir This is necessary for pure To or By animations, as the 60cdf0e10cSrcweir Activity cannot determine a sensible start value 61cdf0e10cSrcweir otherwise. 62cdf0e10cSrcweir 63cdf0e10cSrcweir @attention Note that you are only permitted to query 64cdf0e10cSrcweir for the underlying value, if the animation has actually 65cdf0e10cSrcweir been started (via start() call). 66cdf0e10cSrcweir */ 67cdf0e10cSrcweir virtual ValueType getUnderlyingValue() const = 0; 68cdf0e10cSrcweir }; 69cdf0e10cSrcweir 70cdf0e10cSrcweir typedef ::boost::shared_ptr< EnumAnimation > EnumAnimationSharedPtr; 71cdf0e10cSrcweir 72cdf0e10cSrcweir } 73cdf0e10cSrcweir } 74cdf0e10cSrcweir 75cdf0e10cSrcweir #endif /* INCLUDED_SLIDESHOW_ENUMANIMATION_HXX */ 76