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