Fix bugs in previous commit that caused FTBFS in synfig and ETL FTBFS with older...
[synfig.git] / synfig-core / tags / synfig_0_61_07_rc2 / src / modules / lyr_std / warp.h
1 /* === S Y N F I G ========================================================= */
2 /*!     \file warp.h
3 **      \brief Template Header
4 **
5 **      $Id$
6 **
7 **      \legal
8 **      Copyright (c) 2002-2005 Robert B. Quattlebaum Jr., Adrian Bentley
9 **
10 **      This package is free software; you can redistribute it and/or
11 **      modify it under the terms of the GNU General Public License as
12 **      published by the Free Software Foundation; either version 2 of
13 **      the License, or (at your option) any later version.
14 **
15 **      This package is distributed in the hope that it will be useful,
16 **      but WITHOUT ANY WARRANTY; without even the implied warranty of
17 **      MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
18 **      General Public License for more details.
19 **      \endlegal
20 **
21 ** === N O T E S ===========================================================
22 **
23 ** ========================================================================= */
24
25 /* === S T A R T =========================================================== */
26
27 #ifndef __SYNFIG_WARP_H
28 #define __SYNFIG_WARP_H
29
30 /* === H E A D E R S ======================================================= */
31
32 #include <synfig/vector.h>
33 #include <synfig/angle.h>
34 #include <synfig/layer.h>
35 #include <synfig/rect.h>
36
37 /* === M A C R O S ========================================================= */
38
39 /* === T Y P E D E F S ===================================================== */
40
41 /* === C L A S S E S & S T R U C T S ======================================= */
42
43 using namespace synfig;
44 using namespace std;
45 using namespace etl;
46 class Warp_Trans;
47
48 class Warp : public Layer
49 {
50         SYNFIG_LAYER_MODULE_EXT
51         friend class Warp_Trans;
52 private:
53
54         Point src_tl,src_br,dest_tl,dest_tr,dest_bl,dest_br;
55
56         Real horizon;
57
58         Real cache_a,cache_b,cache_c,cache_d,cache_e,cache_f,cache_i,cache_j;
59
60         Real matrix[3][3];
61         Real inv_matrix[3][3];
62
63         Point transform_forward(const Point& p)const;
64         Point transform_backward(const Point& p)const;
65
66         Real transform_forward_z(const Point& p)const;
67         Real transform_backward_z(const Point& p)const;
68
69         bool clip;
70
71 public:
72         void sync();
73
74         Warp();
75         ~Warp();
76
77         virtual synfig::Rect get_full_bounding_rect(synfig::Context context)const;
78         virtual synfig::Rect get_bounding_rect()const;
79
80         virtual bool set_param(const synfig::String & param, const synfig::ValueBase &value);
81         virtual ValueBase get_param(const synfig::String & param)const;
82         virtual Color get_color(Context context, const Point &pos)const;
83         virtual bool accelerated_render(Context context,Surface *surface,int quality, const RendDesc &renddesc, ProgressCallback *cb)const;
84         synfig::Layer::Handle hit_check(synfig::Context context, const synfig::Point &point)const;
85         virtual Vocab get_param_vocab()const;
86         virtual etl::handle<synfig::Transform> get_transform()const;
87 };
88
89 /* === E N D =============================================================== */
90
91 #endif