diff options
Diffstat (limited to 'linden/indra/llprimitive/lltreeparams.h')
-rw-r--r-- | linden/indra/llprimitive/lltreeparams.h | 202 |
1 files changed, 202 insertions, 0 deletions
diff --git a/linden/indra/llprimitive/lltreeparams.h b/linden/indra/llprimitive/lltreeparams.h new file mode 100644 index 0000000..7822d31 --- /dev/null +++ b/linden/indra/llprimitive/lltreeparams.h | |||
@@ -0,0 +1,202 @@ | |||
1 | /** | ||
2 | * @file lltreeparams.h | ||
3 | * @brief Implementation of the LLTreeParams class | ||
4 | * | ||
5 | * Copyright (c) 2001-2007, Linden Research, Inc. | ||
6 | * | ||
7 | * The source code in this file ("Source Code") is provided by Linden Lab | ||
8 | * to you under the terms of the GNU General Public License, version 2.0 | ||
9 | * ("GPL"), unless you have obtained a separate licensing agreement | ||
10 | * ("Other License"), formally executed by you and Linden Lab. Terms of | ||
11 | * the GPL can be found in doc/GPL-license.txt in this distribution, or | ||
12 | * online at http://secondlife.com/developers/opensource/gplv2 | ||
13 | * | ||
14 | * There are special exceptions to the terms and conditions of the GPL as | ||
15 | * it is applied to this Source Code. View the full text of the exception | ||
16 | * in the file doc/FLOSS-exception.txt in this software distribution, or | ||
17 | * online at http://secondlife.com/developers/opensource/flossexception | ||
18 | * | ||
19 | * By copying, modifying or distributing this software, you acknowledge | ||
20 | * that you have read and understood your obligations described above, | ||
21 | * and agree to abide by those obligations. | ||
22 | * | ||
23 | * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO | ||
24 | * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, | ||
25 | * COMPLETENESS OR PERFORMANCE. | ||
26 | */ | ||
27 | |||
28 | #ifndef LL_LLTREEPARAMS_H | ||
29 | #define LL_LLTREEPARAMS_H | ||
30 | |||
31 | /* for information about formulas associated with each type | ||
32 | * check the Weber + Penn paper | ||
33 | */ | ||
34 | typedef enum EShapeRatio { SR_CONICAL, SR_SPHERICAL, SR_HEMISPHERICAL, | ||
35 | SR_CYLINDRICAL, SR_TAPERED_CYLINDRICAL, SR_FLAME, | ||
36 | SR_INVERSE_CONICAL, SR_TEND_FLAME, SR_ENVELOPE}; | ||
37 | |||
38 | const U32 TREE_BLOCK_SIZE = 16; | ||
39 | |||
40 | const U8 MAX_NUM_LEVELS = 4; | ||
41 | |||
42 | class LLTreeParams | ||
43 | { | ||
44 | public: | ||
45 | LLTreeParams(); | ||
46 | virtual ~LLTreeParams(); | ||
47 | |||
48 | static F32 ShapeRatio(EShapeRatio shape, F32 ratio); | ||
49 | |||
50 | public: | ||
51 | |||
52 | // Variables with an asterick (*) cannot be modified without a re-instancing the | ||
53 | // trunk/branches | ||
54 | |||
55 | // Variables with an exclamation point (!) should probably not be modified outside and instead | ||
56 | // be tied directly to the species | ||
57 | |||
58 | // Variables with a tilde (~) should be tied to a range specified by the | ||
59 | // species type but still slightly controllable by the user | ||
60 | |||
61 | // GENERAL | ||
62 | |||
63 | //! determines length/radius of branches on tree -- ie: general 'shape' | ||
64 | EShapeRatio mShape; | ||
65 | |||
66 | //! number of recursive branch levels...limit to MAX_NUM_LEVELS | ||
67 | U8 mLevels; | ||
68 | |||
69 | //~ percentage of trunk at bottom without branches | ||
70 | F32 mBaseSize; | ||
71 | |||
72 | //~ the general scale + variance of tree | ||
73 | F32 mScale, mScaleV; | ||
74 | |||
75 | // general scale of tree | ||
76 | F32 mScale0, mScaleV0; | ||
77 | |||
78 | |||
79 | |||
80 | // LOBING | ||
81 | |||
82 | //*! number of peaks in the radial distance about the perimeter | ||
83 | U8 mLobes; | ||
84 | // even numbers = obvius symmetry ... use odd numbers | ||
85 | |||
86 | //*! magnitude of the variations as a fraction of the radius | ||
87 | F32 mLobeDepth; | ||
88 | |||
89 | |||
90 | |||
91 | // FLARE | ||
92 | |||
93 | //*! causes exponential expansion near base of trunk | ||
94 | F32 mFlare; | ||
95 | // scales radius base by min 1 to '1 + flare' | ||
96 | |||
97 | //*! percentage of the height of the trunk to flair -- likely less than baseSize | ||
98 | F32 mFlarePercentage; | ||
99 | |||
100 | //*! number of cross sections to make for the flair | ||
101 | U8 mFlareRes; | ||
102 | |||
103 | |||
104 | |||
105 | // LEAVES | ||
106 | |||
107 | //~ number of leaves to make | ||
108 | U8 mLeaves; | ||
109 | |||
110 | //! scale of the leaves | ||
111 | F32 mLeafScaleX, mLeafScaleY; | ||
112 | |||
113 | // quality/density of leaves | ||
114 | F32 mLeafQuality; | ||
115 | |||
116 | // several params don't have level 0 values | ||
117 | |||
118 | // BRANCHES | ||
119 | |||
120 | //~ angle away from parent | ||
121 | F32 mDownAngle[MAX_NUM_LEVELS - 1]; | ||
122 | F32 mDownAngleV[MAX_NUM_LEVELS - 1]; | ||
123 | |||
124 | //~ rotation around parent | ||
125 | F32 mRotate[MAX_NUM_LEVELS - 1]; | ||
126 | F32 mRotateV[MAX_NUM_LEVELS - 1]; | ||
127 | |||
128 | //~ num branches to spawn | ||
129 | U8 mBranches[MAX_NUM_LEVELS - 1]; | ||
130 | |||
131 | //~ fractional length of branch. 1 = same length as parent branch | ||
132 | F32 mLength[MAX_NUM_LEVELS]; | ||
133 | F32 mLengthV[MAX_NUM_LEVELS]; | ||
134 | |||
135 | //!~ ratio and ratiopower determine radius/length | ||
136 | F32 mRatio, mRatioPower; | ||
137 | |||
138 | //*! taper of branches | ||
139 | F32 mTaper[MAX_NUM_LEVELS]; | ||
140 | // 0 - non-tapering cylinder | ||
141 | // 1 - taper to a point | ||
142 | // 2 - taper to a spherical end | ||
143 | // 3 - periodic tapering (concatenated spheres) | ||
144 | |||
145 | //! SEG SPLITTING | ||
146 | U8 mBaseSplits; //! num segsplits at first curve cross section of trunk | ||
147 | F32 mSegSplits[MAX_NUM_LEVELS]; //~ splits per cross section. 1 = 1 split per section | ||
148 | F32 mSplitAngle[MAX_NUM_LEVELS]; //~ angle that splits go from parent (tempered by height) | ||
149 | F32 mSplitAngleV[MAX_NUM_LEVELS]; //~ variance of the splits | ||
150 | |||
151 | // CURVE | ||
152 | F32 mCurve[MAX_NUM_LEVELS]; //* general, 1-axis, overall curve of branch | ||
153 | F32 mCurveV[MAX_NUM_LEVELS]; //* curve variance at each cross section from general overall curve | ||
154 | U8 mCurveRes[MAX_NUM_LEVELS]; //* number of cross sections for curve | ||
155 | F32 mCurveBack[MAX_NUM_LEVELS]; //* curveback is amount branch curves back towards | ||
156 | |||
157 | // vertices per cross section | ||
158 | U8 mVertices[MAX_NUM_LEVELS]; | ||
159 | |||
160 | // * no longer useful with pre-instanced branches | ||
161 | // specifies upward tendency of branches. | ||
162 | //F32 mAttractionUp; | ||
163 | // 1 = each branch will slightly go upwards by the end of the branch | ||
164 | // >1 = branches tend to go upwards earlier in their length | ||
165 | // pruning not implemented | ||
166 | // Prune parameters | ||
167 | //F32 mPruneRatio; | ||
168 | //F32 mPruneWidth, mPruneWidthPeak; | ||
169 | //F32 mPrunePowerLow, mPrunePowerHigh; | ||
170 | |||
171 | |||
172 | // NETWORK MESSAGE DATA | ||
173 | // Below is the outline for network messages regarding trees. | ||
174 | // The general idea is that a user would pick a general 'tree type' (the first variable) | ||
175 | // and then several 'open ended' variables like 'branchiness' and 'leafiness'. | ||
176 | // The effect that each of these general user variables would then affect the actual | ||
177 | // tree parameters (like # branches, # segsplits) in different ways depending on | ||
178 | // the tree type selected. Essentially, each tree type should have a formula | ||
179 | // that expands the 'leafiness' and 'branchiness' user variables into actual | ||
180 | // values for the tree parameters. | ||
181 | |||
182 | // These formulas aren't made yet and will certainly require some tuning. The | ||
183 | // estimates below for the # bits required seems like a good guesstimate. | ||
184 | |||
185 | // VARIABLE - # bits (range) - VARIABLES AFFECTED | ||
186 | // tree type - 5 bits (32) - | ||
187 | // branches - 6 bits (64) - numBranches | ||
188 | // splits - 6 bits (64) - segsplits | ||
189 | // leafiness - 3 bits (8) - numLeaves | ||
190 | // branch spread - 5 bits (32) - splitAngle(V), rotate(V) | ||
191 | // angle - 5 bits (32) - downAngle(V) | ||
192 | // branch length - 6 bits (64) - branchlength(V) | ||
193 | // randomness - 7 bits (128) - percentage for randomness of the (V)'s | ||
194 | // basesize - 5 bits (32) - basesize | ||
195 | |||
196 | // total - 48 bits | ||
197 | |||
198 | //U8 mNetSpecies; | ||
199 | |||
200 | }; | ||
201 | |||
202 | #endif | ||