xref: /AOO42X/main/basegfx/test/basegfxtools.cxx (revision b1c5455db1639c48e26c568e4fa7ee78ca5d60ee)
109dbbe93SAndrew Rist /**************************************************************
2cdf0e10cSrcweir  *
309dbbe93SAndrew Rist  * Licensed to the Apache Software Foundation (ASF) under one
409dbbe93SAndrew Rist  * or more contributor license agreements.  See the NOTICE file
509dbbe93SAndrew Rist  * distributed with this work for additional information
609dbbe93SAndrew Rist  * regarding copyright ownership.  The ASF licenses this file
709dbbe93SAndrew Rist  * to you under the Apache License, Version 2.0 (the
809dbbe93SAndrew Rist  * "License"); you may not use this file except in compliance
909dbbe93SAndrew Rist  * with the License.  You may obtain a copy of the License at
10cdf0e10cSrcweir  *
1109dbbe93SAndrew Rist  *   http://www.apache.org/licenses/LICENSE-2.0
12cdf0e10cSrcweir  *
1309dbbe93SAndrew Rist  * Unless required by applicable law or agreed to in writing,
1409dbbe93SAndrew Rist  * software distributed under the License is distributed on an
1509dbbe93SAndrew Rist  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
1609dbbe93SAndrew Rist  * KIND, either express or implied.  See the License for the
1709dbbe93SAndrew Rist  * specific language governing permissions and limitations
1809dbbe93SAndrew Rist  * under the License.
19cdf0e10cSrcweir  *
2009dbbe93SAndrew Rist  *************************************************************/
2109dbbe93SAndrew Rist 
2209dbbe93SAndrew Rist 
23cdf0e10cSrcweir 
24cdf0e10cSrcweir 
25cdf0e10cSrcweir // MARKER(update_precomp.py): autogen include statement, do not remove
26cdf0e10cSrcweir #include "precompiled_basegfx.hxx"
27cdf0e10cSrcweir // autogenerated file with codegen.pl
28cdf0e10cSrcweir 
29cdf0e10cSrcweir #include "preextstl.h"
30*131e08e2SDamjan Jovanovic #include "gtest/gtest.h"
31cdf0e10cSrcweir #include "postextstl.h"
32cdf0e10cSrcweir 
33cdf0e10cSrcweir #include <basegfx/tools/keystoplerp.hxx>
34cdf0e10cSrcweir #include <basegfx/numeric/ftools.hxx>
35cdf0e10cSrcweir 
36cdf0e10cSrcweir #include <boost/tuple/tuple.hpp>
37cdf0e10cSrcweir 
38cdf0e10cSrcweir using namespace ::basegfx;
39cdf0e10cSrcweir using namespace ::boost::tuples;
40cdf0e10cSrcweir 
41cdf0e10cSrcweir namespace basegfxtools
42cdf0e10cSrcweir {
43cdf0e10cSrcweir 
44*131e08e2SDamjan Jovanovic class KeyStopLerpTest : public ::testing::Test
45cdf0e10cSrcweir {
46*131e08e2SDamjan Jovanovic protected:
47cdf0e10cSrcweir     tools::KeyStopLerp maKeyStops;
48cdf0e10cSrcweir 
getTestVector()49cdf0e10cSrcweir     static std::vector<double> getTestVector()
50cdf0e10cSrcweir     {
51cdf0e10cSrcweir         std::vector<double> aStops(3);
52cdf0e10cSrcweir         aStops[0] = 0.1;
53cdf0e10cSrcweir         aStops[1] = 0.5;
54cdf0e10cSrcweir         aStops[2] = 0.9;
55cdf0e10cSrcweir         return aStops;
56cdf0e10cSrcweir     }
57cdf0e10cSrcweir 
58cdf0e10cSrcweir public:
KeyStopLerpTest()59cdf0e10cSrcweir     KeyStopLerpTest() :
60cdf0e10cSrcweir         maKeyStops(getTestVector())
61cdf0e10cSrcweir     {}
62cdf0e10cSrcweir 
SetUp()63*131e08e2SDamjan Jovanovic     virtual void SetUp()
64cdf0e10cSrcweir     {}
65cdf0e10cSrcweir 
TearDown()66*131e08e2SDamjan Jovanovic     virtual void TearDown()
67cdf0e10cSrcweir     {}
68*131e08e2SDamjan Jovanovic };
69cdf0e10cSrcweir 
TEST_F(KeyStopLerpTest,test)70*131e08e2SDamjan Jovanovic TEST_F(KeyStopLerpTest, test)
71cdf0e10cSrcweir {
72cdf0e10cSrcweir     double fAlpha;
73cdf0e10cSrcweir     std::ptrdiff_t nIndex;
74cdf0e10cSrcweir 
75cdf0e10cSrcweir     tie(nIndex,fAlpha) = maKeyStops.lerp(-1.0);
76*131e08e2SDamjan Jovanovic     ASSERT_TRUE(nIndex==0 && fAlpha==0.0) << "-1.0";
77cdf0e10cSrcweir 
78cdf0e10cSrcweir     tie(nIndex,fAlpha) = maKeyStops.lerp(0.1);
79*131e08e2SDamjan Jovanovic     ASSERT_TRUE(nIndex==0 && fAlpha==0.0) << "0.1";
80cdf0e10cSrcweir 
81cdf0e10cSrcweir     tie(nIndex,fAlpha) = maKeyStops.lerp(0.3);
82*131e08e2SDamjan Jovanovic     ASSERT_TRUE(nIndex==0 && fTools::equal(fAlpha,0.5)) << "0.3";
83cdf0e10cSrcweir 
84cdf0e10cSrcweir     tie(nIndex,fAlpha) = maKeyStops.lerp(0.5);
85*131e08e2SDamjan Jovanovic     ASSERT_TRUE(nIndex==0 && fTools::equal(fAlpha,1.0)) << "0.5";
86cdf0e10cSrcweir 
87cdf0e10cSrcweir     tie(nIndex,fAlpha) = maKeyStops.lerp(0.51);
88*131e08e2SDamjan Jovanovic     ASSERT_TRUE(nIndex==1 && fTools::equal(fAlpha,0.025)) << "0.51";
89cdf0e10cSrcweir 
90cdf0e10cSrcweir     tie(nIndex,fAlpha) = maKeyStops.lerp(0.9);
91*131e08e2SDamjan Jovanovic     ASSERT_TRUE(nIndex==1 && fTools::equal(fAlpha,1.0)) << "0.51";
92cdf0e10cSrcweir 
93cdf0e10cSrcweir     tie(nIndex,fAlpha) = maKeyStops.lerp(1.0);
94*131e08e2SDamjan Jovanovic     ASSERT_TRUE(nIndex==1 && fAlpha==1.0) << "0.51";
95cdf0e10cSrcweir }
96cdf0e10cSrcweir 
97cdf0e10cSrcweir // -----------------------------------------------------------------------------
98*131e08e2SDamjan Jovanovic 
99cdf0e10cSrcweir } // namespace basegfxtools
100