Remove .gitignore do nothing is ignored.
[synfig.git] / synfig-core / trunk / src / modules / mod_particle / plant.h
index bcda00d..b399a8a 100644 (file)
@@ -1,20 +1,22 @@
 /* === S Y N F I G ========================================================= */
 /*!    \file plant.h
-**     \brief Template Header
+**     \brief Header file for implementation of the "Plant" layer
 **
-**     $Id: plant.h,v 1.1.1.1 2005/01/04 01:23:14 darco Exp $
+**     $Id$
 **
 **     \legal
-**     Copyright (c) 2002 Robert B. Quattlebaum Jr.
+**     Copyright (c) 2002-2005 Robert B. Quattlebaum Jr., Adrian Bentley
+**     Copyright (c) 2007, 2008 Chris Moore
 **
-**     This software and associated documentation
-**     are CONFIDENTIAL and PROPRIETARY property of
-**     the above-mentioned copyright holder.
+**     This package is free software; you can redistribute it and/or
+**     modify it under the terms of the GNU General Public License as
+**     published by the Free Software Foundation; either version 2 of
+**     the License, or (at your option) any later version.
 **
-**     You may not copy, print, publish, or in any
-**     other way distribute this software without
-**     a prior written agreement with
-**     the copyright holder.
+**     This package is distributed in the hope that it will be useful,
+**     but WITHOUT ANY WARRANTY; without even the implied warranty of
+**     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+**     General Public License for more details.
 **     \endlegal
 */
 /* ========================================================================= */
@@ -55,13 +57,15 @@ private:
        std::vector<synfig::BLinePoint> bline;
        bool bline_loop;
 
+       Point origin;
+
        synfig::Gradient gradient;
 
        struct Particle
        {
                synfig::Point point;
                synfig::Color color;
-               
+
                Particle(const synfig::Point &point,const synfig::Color& color):
                        point(point),color(color) { }
        };
@@ -71,6 +75,7 @@ private:
        synfig::Angle split_angle;
        synfig::Vector gravity;
        synfig::Real velocity;
+       synfig::Real perp_velocity;
        synfig::Real step;
        synfig::Real mass;
        synfig::Real drag;
@@ -79,25 +84,29 @@ private:
        int sprouts;
        synfig::Real random_factor;
        Random random;
-       
+
        bool size_as_alpha;
+       bool reverse;
        mutable bool needs_sync_;
-       
+       mutable synfig::Mutex mutex;
 
        void branch(int n, int depth,float t, float stunt_growth, synfig::Point position,synfig::Vector velocity)const;
+       void sync()const;
+       String version;
+       bool use_width;
 
 public:
 
        Plant();
 
-       void sync()const;
-
        void calc_bounding_rect()const;
 
        virtual bool set_param(const String & param, const synfig::ValueBase &value);
 
        virtual ValueBase get_param(const String & param)const;
 
+       virtual bool set_version(const synfig::String &ver);
+
        virtual Vocab get_param_vocab()const;
 
        virtual bool accelerated_render(synfig::Context context,synfig::Surface *surface,int quality, const synfig::RendDesc &renddesc, synfig::ProgressCallback *cb)const;\