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 #if ! defined INCLUDED_SLIDESHOW_CLIPPINGFUNCTOR_HXX
25cdf0e10cSrcweir #define INCLUDED_SLIDESHOW_CLIPPINGFUNCTOR_HXX
26cdf0e10cSrcweir 
27cdf0e10cSrcweir #include <basegfx/numeric/ftools.hxx>
28cdf0e10cSrcweir #include <basegfx/vector/b2dsize.hxx>
29cdf0e10cSrcweir #include <basegfx/matrix/b2dhommatrix.hxx>
30cdf0e10cSrcweir #include <basegfx/polygon/b2dpolypolygontools.hxx>
31cdf0e10cSrcweir #include <transitioninfo.hxx>
32cdf0e10cSrcweir #include <parametricpolypolygon.hxx>
33cdf0e10cSrcweir 
34cdf0e10cSrcweir 
35cdf0e10cSrcweir namespace slideshow
36cdf0e10cSrcweir {
37cdf0e10cSrcweir     namespace internal
38cdf0e10cSrcweir     {
39cdf0e10cSrcweir         /** Generates the final clipping polygon.
40cdf0e10cSrcweir 
41cdf0e10cSrcweir         	This class serves as the functor, which generates the
42cdf0e10cSrcweir         	final clipping polygon from a given ParametricPolyPolygon
43cdf0e10cSrcweir         	and a TransitionInfo.
44cdf0e10cSrcweir 
45cdf0e10cSrcweir             The ParametricPolyPolygon can be obtained from the
46cdf0e10cSrcweir             ParametricPolyPolygonFactory, see there.
47cdf0e10cSrcweir 
48cdf0e10cSrcweir             The TransitionInfo further parameterizes the polygon
49cdf0e10cSrcweir             generated by the ParametricPolyPolygon, with common
50cdf0e10cSrcweir             modifications such as rotation, flipping, or change of
51cdf0e10cSrcweir             direction. This allows the ParametricPolyPolygonFactory to
52cdf0e10cSrcweir             provide only prototypical shapes, with the ClippingFunctor
53cdf0e10cSrcweir             further customizing the output.
54cdf0e10cSrcweir          */
55cdf0e10cSrcweir         class ClippingFunctor
56cdf0e10cSrcweir         {
57cdf0e10cSrcweir         public:
58cdf0e10cSrcweir             ClippingFunctor(
59cdf0e10cSrcweir                 const ParametricPolyPolygonSharedPtr&   rPolygon,
60cdf0e10cSrcweir                 const TransitionInfo&                   rTransitionInfo,
61cdf0e10cSrcweir                 bool                                    bDirectionForward,
62cdf0e10cSrcweir                 bool                                    bModeIn );
63cdf0e10cSrcweir 
64cdf0e10cSrcweir             /** Generate clip polygon.
65cdf0e10cSrcweir 
66cdf0e10cSrcweir             	@param nValue
67cdf0e10cSrcweir                 Value to generate the polygon for. Must be in the
68cdf0e10cSrcweir                 range [0,1].
69cdf0e10cSrcweir 
70cdf0e10cSrcweir                 @param rTargetSize
71cdf0e10cSrcweir                 Size the clip polygon should cover. This is typically
72cdf0e10cSrcweir                 the size of the object the effect is applied on.
73cdf0e10cSrcweir              */
74cdf0e10cSrcweir             ::basegfx::B2DPolyPolygon operator()( double 					nValue,
75cdf0e10cSrcweir                                                   const ::basegfx::B2DSize& rTargetSize );
76cdf0e10cSrcweir 
77cdf0e10cSrcweir         private:
78cdf0e10cSrcweir             ParametricPolyPolygonSharedPtr     mpParametricPoly;
79cdf0e10cSrcweir             ::basegfx::B2DHomMatrix            maStaticTransformation;
80cdf0e10cSrcweir             // AW: Not needed
81cdf0e10cSrcweir 			// ::basegfx::B2DPolyPolygon          maBackgroundRect;
82cdf0e10cSrcweir             bool                               mbForwardParameterSweep;
83cdf0e10cSrcweir             bool                               mbSubtractPolygon;
84cdf0e10cSrcweir             const bool                         mbScaleIsotrophically;
85cdf0e10cSrcweir             bool                               mbFlip;
86cdf0e10cSrcweir         };
87cdf0e10cSrcweir 
88cdf0e10cSrcweir     }
89cdf0e10cSrcweir }
90cdf0e10cSrcweir 
91cdf0e10cSrcweir #endif /* INCLUDED_SLIDESHOW_CLIPPINGFUNCTOR_HXX */
92