bump product version to 6.3.0.0.beta1
[LibreOffice.git] / sd / source / ui / slidesorter / inc / controller / SlsAnimationFunction.hxx
blob9af186531936feaa84fe5d51c6e2dccaf797f833
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_SD_SOURCE_UI_SLIDESORTER_INC_CONTROLLER_SLSANIMATIONFUNCTION_HXX
21 #define INCLUDED_SD_SOURCE_UI_SLIDESORTER_INC_CONTROLLER_SLSANIMATIONFUNCTION_HXX
23 #include <basegfx/point/b2dpoint.hxx>
25 #include <functional>
26 #include <vector>
29 namespace sd { namespace slidesorter { namespace controller {
31 class AnimationBezierFunction
33 public:
34 /** Create a cubic bezier curve whose start and end points are given
35 implicitly as P0=(0,0) and P3=(1,1). The second control point is
36 implicitly given as P2=(1-nY1,1-nX1).
38 AnimationBezierFunction (
39 const double nX1,
40 const double nY1);
42 ::basegfx::B2DPoint operator() (const double nT);
44 private:
45 const double mnX1;
46 const double mnY1;
47 const double mnX2;
48 const double mnY2;
50 static double EvaluateComponent (
51 const double nT,
52 const double nV1,
53 const double nV2);
56 /** Turn a parametric function into one whose y-Values depend on its
57 x-Values. Note a lot of interpolation takes place. The resulting
58 accuracy should be good enough for the purpose of acceleration
59 function for animations.
61 class AnimationParametricFunction
63 public:
64 typedef ::std::function<basegfx::B2DPoint (double)> ParametricFunction;
65 AnimationParametricFunction (const ParametricFunction& rFunction);
67 double operator() (const double nX);
69 private:
70 /** y-Values of the parametric function given to the constructor
71 evaluated (and interpolated) for evenly spaced x-Values.
73 ::std::vector<double> maY;
76 } } } // end of namespace ::sd::slidesorter::controller
78 #endif
80 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */