Bump version to 24.04.3.4
[LibreOffice.git] / slideshow / source / inc / numberanimation.hxx
blobe35769e973272bc59a48e83ebc9a5540bbe54723
1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2 /*
3 * This file is part of the LibreOffice project.
5 * This Source Code Form is subject to the terms of the Mozilla Public
6 * License, v. 2.0. If a copy of the MPL was not distributed with this
7 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
9 * This file incorporates work covered by the following license notice:
11 * Licensed to the Apache Software Foundation (ASF) under one or more
12 * contributor license agreements. See the NOTICE file distributed
13 * with this work for additional information regarding copyright
14 * ownership. The ASF licenses this file to you under the Apache
15 * License, Version 2.0 (the "License"); you may not use this file
16 * except in compliance with the License. You may obtain a copy of
17 * the License at http://www.apache.org/licenses/LICENSE-2.0 .
20 #ifndef INCLUDED_SLIDESHOW_SOURCE_INC_NUMBERANIMATION_HXX
21 #define INCLUDED_SLIDESHOW_SOURCE_INC_NUMBERANIMATION_HXX
23 #include "animation.hxx"
26 /* Definition of NumberAnimation interface */
28 namespace slideshow::internal
30 /** Interface defining a number animation.
32 This interface is a specialization of the Animation
33 interface, and is used to animate attributes representable
34 by a single floating point value.
36 class NumberAnimation : public Animation
38 public:
39 typedef double ValueType;
41 /** Set the animation to value x
43 @param x
44 Current animation value (must be in an
45 attribute-specific permissible range). Overflowing
46 values will be clipped to the permissible range
47 internally.
49 virtual bool operator()( double x ) = 0;
51 /** Request the underlying value for this animation.
53 This is necessary for pure To or By animations, as the
54 Activity cannot determine a sensible start value
55 otherwise.
57 @attention Note that you are only permitted to query
58 for the underlying value, if the animation has actually
59 been started (via start() call).
61 virtual double getUnderlyingValue() const = 0;
64 typedef ::std::shared_ptr< NumberAnimation > NumberAnimationSharedPtr;
68 #endif // INCLUDED_SLIDESHOW_SOURCE_INC_NUMBERANIMATION_HXX
70 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */