summaryrefslogtreecommitdiff
path: root/src/flam3.c
diff options
context:
space:
mode:
authorErik Reckase <e.reckase@gmail.com>2010-06-23 10:31:31 +0000
committerScott Draves <spot@draves.org>2015-02-15 12:20:12 -0500
commit933c9a4532637d1373f3299035f62e041c495d87 (patch)
tree69a2d9a3a9a10ce0d3a7c73d49579a6ce53529fc /src/flam3.c
parentce1ef42a60b4cfdf5c00bf4eb90399090374e31e (diff)
downloadpucket-933c9a4532637d1373f3299035f62e041c495d87.tar.gz
pucket-933c9a4532637d1373f3299035f62e041c495d87.tar.bz2
pucket-933c9a4532637d1373f3299035f62e041c495d87.zip
Added flux variation.
git-svn-id: https://flam3.googlecode.com/svn/trunk@15 77852712-ef1d-11de-8684-7d64432d61a3
Diffstat (limited to 'src/flam3.c')
-rw-r--r--src/flam3.c19
1 files changed, 18 insertions, 1 deletions
diff --git a/src/flam3.c b/src/flam3.c
index 3525a48..959833a 100644
--- a/src/flam3.c
+++ b/src/flam3.c
@@ -673,6 +673,7 @@ void apply_motion_parameters(flam3_xform *xf, flam3_xform *addto, double blend)
APPMOT(auger_weight);
APPMOT(auger_freq);
APPMOT(auger_scale);
+ APPMOT(flux_spread);
for (j = 0; j < flam3_nvariations; j++)
APPMOT(var[j]);
@@ -961,6 +962,9 @@ void flam3_copy_params(flam3_xform *dest, flam3_xform *src, int varn) {
dest->auger_weight = src->auger_weight;
dest->auger_freq = src->auger_freq;
dest->auger_scale = src->auger_scale;
+ } else if (varn==VAR_FLUX) {
+ /* flux */
+ dest->flux_spread = src->flux_spread;
}
}
@@ -1799,7 +1803,7 @@ void flam3_print_xform(FILE *f, flam3_xform *x, int final_flag, int numstd, doub
int cell_var=0,cpow_var=0,curve_var=0,escher_var=0,lazys_var=0;
int modulus_var=0,oscope_var=0,popcorn2_var=0,separation_var=0;
int split_var=0,splits_var=0,stripes_var=0,wedge_var=0,wedgeJ_var=0;
- int wedgeS_var=0,whorl_var=0,waves2_var=0,auger_var=0;
+ int wedgeS_var=0,whorl_var=0,waves2_var=0,auger_var=0,flux_var=0;
int j;
int lnv;
@@ -1914,6 +1918,8 @@ void flam3_print_xform(FILE *f, flam3_xform *x, int final_flag, int numstd, doub
waves2_var=1;
else if (j==VAR_AUGER)
auger_var=1;
+ else if (j==VAR_FLUX)
+ flux_var=1;
}
}
@@ -2129,6 +2135,9 @@ void flam3_print_xform(FILE *f, flam3_xform *x, int final_flag, int numstd, doub
fprintf(f, "auger_scale=\"%g\" ", x->auger_scale);
}
+ if (flux_var==1)
+ fprintf(f, "flux_spread=\"%g\" ", x->flux_spread);
+
fprintf(f, "coefs=\"");
for (j = 0; j < 3; j++) {
if (j) fprintf(f, " ");
@@ -2284,6 +2293,8 @@ void flam3_print_xform(FILE *f, flam3_xform *x, int final_flag, int numstd, doub
PRINTNON(auger_weight);
PRINTNON(auger_freq);
PRINTNON(auger_scale);
+
+ PRINTNON(flux_spread);
if (!zero_matrix(x->c)) {
fprintf(f, "coefs=\"");
@@ -3343,6 +3354,12 @@ void flam3_random(flam3_genome *cp, int *ivars, int ivars_n, int sym, int spec_x
cp->xform[i].auger_scale = flam3_random01();
}
+ if (cp->xform[i].var[VAR_FLUX] > 0) {
+ /* Create random params for flux */
+ cp->xform[i].flux_spread = 0.5 + flam3_random01()/2.0;
+ }
+
+
}
/* Randomly add symmetry (but not if we've already added a final xform) */