Initial Stable Commit
[synfig.git] / synfig-core / trunk / src / modules / example / metaballs.h
1 /* === S I N F G =========================================================== */
2 /*!     \file metaballs.h
3 **      \brief Declares information for defining Metaballs.
4 **
5 **      $Id: metaballs.h,v 1.1.1.1 2005/01/04 01:23:09 darco Exp $
6 **
7 **      \legal
8 **      Copyright (c) 2002 Robert B. Quattlebaum Jr.
9 **
10 **      This software and associated documentation
11 **      are CONFIDENTIAL and PROPRIETARY property of
12 **      the above-mentioned copyright holder.
13 **
14 **      You may not copy, print, publish, or in any
15 **      other way distribute this software without
16 **      a prior written agreement with
17 **      the copyright holder.
18 **      \endlegal
19 */
20 /* ========================================================================= */
21
22 /* === S T A R T =========================================================== */
23
24 #ifndef __SINFG_METABALLS_H
25 #define __SINFG_METABALLS_H
26
27 /* === H E A D E R S ======================================================= */
28
29 #include <sinfg/layer_composite.h>
30 #include <sinfg/color.h>
31 #include <sinfg/vector.h>
32 #include <sinfg/value.h>
33 #include <vector>
34
35 /* === M A C R O S ========================================================= */
36
37 /* === T Y P E D E F S ===================================================== */
38
39 /* === C L A S S E S & S T R U C T S ======================================= */
40 class Metaballs : public sinfg::Layer_Composite
41 {
42         SINFG_LAYER_MODULE_EXT
43         
44 private:
45
46         sinfg::Color color;
47
48         std::vector<sinfg::Point>       centers;
49         std::vector<sinfg::Real>        radii;
50         std::vector<sinfg::Real>        weights;
51
52         sinfg::Real     threshold;
53         //Real  threshold2;
54         
55         sinfg::Real totaldensity(const sinfg::Point &pos)const;
56
57 public:
58         
59         Metaballs();
60         
61         virtual bool set_param(const sinfg::String & param, const sinfg::ValueBase &value);
62
63         virtual sinfg::ValueBase get_param(const sinfg::String & param)const;
64
65         virtual sinfg::Color get_color(sinfg::Context context, const sinfg::Point &pos)const;
66         
67         virtual bool accelerated_render(sinfg::Context context,sinfg::Surface *surface,int quality, const sinfg::RendDesc &renddesc, sinfg::ProgressCallback *cb)const;
68         
69         virtual Vocab get_param_vocab()const;
70 }; // END of class Metaballs
71
72 /* === E N D =============================================================== */
73
74 #endif