cfe8a2ff40fc91130fc8a3ee4e1e4c0bb1a9feec
[synfig.git] / blur.h
1 /* === S Y N F I G ========================================================= */
2 /*!     \file mod_filter/blur.h
3 **      \brief Header file for implementation of the "Blur" layer
4 **
5 **      $Id$
6 **
7 **      \legal
8 **      Copyright (c) 2002-2005 Robert B. Quattlebaum Jr., Adrian Bentley
9 **      Copyright (c) 2008 Chris Moore
10 **
11 **      This package is free software; you can redistribute it and/or
12 **      modify it under the terms of the GNU General Public License as
13 **      published by the Free Software Foundation; either version 2 of
14 **      the License, or (at your option) any later version.
15 **
16 **      This package is distributed in the hope that it will be useful,
17 **      but WITHOUT ANY WARRANTY; without even the implied warranty of
18 **      MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
19 **      General Public License for more details.
20 **      \endlegal
21 */
22 /* ========================================================================= */
23
24 /* === H E A D E R S ======================================================= */
25
26 #ifndef __SYNFIG_LAYER_BLUR_H__
27 #define __SYNFIG_LAYER_BLUR_H__
28
29 /* -- H E A D E R S --------------------------------------------------------- */
30
31 #include <synfig/layer_composite.h>
32 #include <synfig/color.h>
33 #include <synfig/vector.h>
34 #include <synfig/blur.h>
35
36 using namespace synfig;
37 using namespace std;
38 using namespace etl;
39
40 class Blur_Layer : public synfig::Layer_Composite
41 {
42         SYNFIG_LAYER_MODULE_EXT
43 private:
44         synfig::Point   size;
45         int                             type;
46
47 public:
48         Blur_Layer();
49
50         virtual bool set_param(const String & param, const synfig::ValueBase &value);
51
52         virtual ValueBase get_param(const String & param)const;
53
54         virtual Color get_color(Context context, const Point &pos)const;
55
56         virtual bool accelerated_render(Context context,Surface *surface,int quality, const RendDesc &renddesc, ProgressCallback *cb)const;
57         virtual synfig::Rect get_full_bounding_rect(Context context)const;
58
59         virtual Vocab get_param_vocab()const;
60
61         virtual bool reads_context()const { return true; }
62 }; // END of class Blur
63
64 /* -- E X T E R N S --------------------------------------------------------- */
65
66 /* -- E N D ----------------------------------------------------------------- */
67
68 #endif