1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
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 .
22 #include <basegfx/point/b2dpoint.hxx>
28 namespace sd::slidesorter::controller
{
30 class AnimationBezierFunction
33 /** Create a cubic bezier curve whose start and end points are given
34 implicitly as P0=(0,0) and P3=(1,1). The second control point is
35 implicitly given as P2=(1-nY1,1-nX1).
37 AnimationBezierFunction (
41 ::basegfx::B2DPoint
operator() (const double nT
);
49 static double EvaluateComponent (
55 /** Turn a parametric function into one whose y-Values depend on its
56 x-Values. Note a lot of interpolation takes place. The resulting
57 accuracy should be good enough for the purpose of acceleration
58 function for animations.
60 class AnimationParametricFunction
63 typedef ::std::function
<basegfx::B2DPoint (double)> ParametricFunction
;
64 AnimationParametricFunction (const ParametricFunction
& rFunction
);
66 double operator() (const double nX
);
69 /** y-Values of the parametric function given to the constructor
70 evaluated (and interpolated) for evenly spaced x-Values.
72 ::std::vector
<double> maY
;
75 } // end of namespace ::sd::slidesorter::controller
77 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */