/**
- * Lindenmayer System
+ * Lindenmayer system generator
*/
class LindenmayerSystem
{
*/
~LindenmayerSystem();
+
/**
* Clear all parameters
*/
*/
void generate();
+ /**
+ * Render L-system data
+ */
+ void render();
+
+
/**
* Set the initial rule (the axiom)
* @param axiom the axiom
void setAngle(double degrees);
/**
- * Set depth of recursion
+ * Set recursion depth
* @param depth depth of recursion
*/
void setDepth(int depth);
/**
- * Set diameter of segment
+ * Set initial segment diameter
* @param diameter the diameter
*/
void setDiameter(double diameter);
/**
- * Set diameter factor
+ * Set segment diameter factor
* @param diameterFactor the diameter factor
*/
void setDiameterFactor(double diameterFactor);
+
/**
* Get the initial rule (the axiom)
* @return the axiom
double getAngle();
/**
- * Get depth of recursion
+ * Get recursion depth
* @return depth of recursion
*/
int getDepth();
/**
- * Get the generated model
- * @return generated model
+ * Get initial segment diameter
+ * @return the diameter
*/
- Model *getModel();
+ double getDiameter();
+
+ /**
+ * Get segment diameter factor
+ * @return the diameter factor
+ */
+ double getDiameterFactor();
protected:
/**
* Recursively apply the replacement rules
- * @param rule rule
+ * @param rule the rule
* @param level recursion level
*/
void recursiveWalk(string rule, int level);
+
// Parameters
Rule _axiom;
RuleSet _rules;
int _depth;
+ double _segmentDiameter;
Model *_model; // The active model
Turtle *_turtle; // The rendering turtle