VTK
|
Generate a surface covered with randomly placed hills. More...
#include <vtkParametricRandomHills.h>
Generate a surface covered with randomly placed hills.
vtkParametricRandomHills generates a surface covered with randomly placed hills. Hills will vary in shape and height since the presence of nearby hills will contribute to the shape and height of a given hill. An option is provided for placing hills on a regular grid on the surface. In this case the hills will all have the same shape and height.
For further information about this surface, please consult the technical description "Parametric surfaces" in http://www.vtk.org/documents.php in the "VTK Technical Documents" section in the VTk.org web pages.
Definition at line 46 of file vtkParametricRandomHills.h.
Reimplemented from vtkParametricFunction.
Definition at line 50 of file vtkParametricRandomHills.h.
vtkParametricRandomHills::vtkParametricRandomHills | ( | ) | [protected] |
vtkParametricRandomHills::~vtkParametricRandomHills | ( | ) | [protected] |
static int vtkParametricRandomHills::IsTypeOf | ( | const char * | name | ) | [static] |
Return 1 if this class type is the same type of (or a subclass of) the named class. Returns 0 otherwise. This method works in combination with vtkTypeMacro found in vtkSetGet.h.
Reimplemented from vtkParametricFunction.
virtual int vtkParametricRandomHills::IsA | ( | const char * | name | ) | [virtual] |
Return 1 if this class is the same type of (or a subclass of) the named class. Returns 0 otherwise. This method works in combination with vtkTypeMacro found in vtkSetGet.h.
Reimplemented from vtkParametricFunction.
static vtkParametricRandomHills* vtkParametricRandomHills::SafeDownCast | ( | vtkObjectBase * | o | ) | [static] |
Reimplemented from vtkParametricFunction.
virtual vtkObjectBase* vtkParametricRandomHills::NewInstanceInternal | ( | ) | const [protected, virtual] |
Reimplemented from vtkParametricFunction.
Reimplemented from vtkParametricFunction.
void vtkParametricRandomHills::PrintSelf | ( | ostream & | os, |
vtkIndent | indent | ||
) | [virtual] |
Methods invoked by print to print information about the object including superclasses. Typically not called by the user (use Print() instead) but used in the hierarchical print process to combine the output of several classes.
Reimplemented from vtkParametricFunction.
virtual int vtkParametricRandomHills::GetDimension | ( | ) | [inline, virtual] |
Return the parametric dimension of the class.
Implements vtkParametricFunction.
Definition at line 54 of file vtkParametricRandomHills.h.
static vtkParametricRandomHills* vtkParametricRandomHills::New | ( | ) | [static] |
Construct a surface of random hills with the following parameters: MinimumU = -10, MaximumU = 10, MinimumV = -10, MaximumV = 10, JoinU = 0, JoinV = 0, TwistU = 0, TwistV = 0; ClockwiseOrdering = 1, DerivativesAvailable = 0, Number of hills = 30, Variance of the hills 2.5 in both x- and y- directions, Scaling factor for the variances 1/3 in both x- and y- directions, Amplitude of each hill = 2, Scaling factor for the amplitude = 1/3, RandomSeed = 1, AllowRandomGeneration = 1.
Reimplemented from vtkObject.
virtual void vtkParametricRandomHills::SetNumberOfHills | ( | int | ) | [virtual] |
Set/Get the number of hills. Default is 30.
virtual int vtkParametricRandomHills::GetNumberOfHills | ( | ) | [virtual] |
Set/Get the number of hills. Default is 30.
virtual void vtkParametricRandomHills::SetHillXVariance | ( | double | ) | [virtual] |
Set/Get the hill variance in the x-direction. Default is 2.5.
virtual double vtkParametricRandomHills::GetHillXVariance | ( | ) | [virtual] |
Set/Get the hill variance in the x-direction. Default is 2.5.
virtual void vtkParametricRandomHills::SetHillYVariance | ( | double | ) | [virtual] |
Set/Get the hill variance in the y-direction. Default is 2.5.
virtual double vtkParametricRandomHills::GetHillYVariance | ( | ) | [virtual] |
Set/Get the hill variance in the y-direction. Default is 2.5.
virtual void vtkParametricRandomHills::SetHillAmplitude | ( | double | ) | [virtual] |
Set/Get the hill amplitude (height). Default is 2.
virtual double vtkParametricRandomHills::GetHillAmplitude | ( | ) | [virtual] |
Set/Get the hill amplitude (height). Default is 2.
virtual void vtkParametricRandomHills::SetRandomSeed | ( | int | ) | [virtual] |
Set/Get the Seed for the random number generator, a value of 1 will initialize the random number generator, a negative value will initialize it with the system time. Default is 1.
virtual int vtkParametricRandomHills::GetRandomSeed | ( | ) | [virtual] |
Set/Get the Seed for the random number generator, a value of 1 will initialize the random number generator, a negative value will initialize it with the system time. Default is 1.
virtual void vtkParametricRandomHills::SetAllowRandomGeneration | ( | int | ) | [virtual] |
Set/Get the random generation flag. A value of 0 will disable the generation of random hills on the surface allowing a reproducible number of identically shaped hills to be generated. If zero, then the number of hills used will be the nearest perfect square less than or equal to the number of hills. For example, selecting 30 hills will result in a 5 X 5 array of hills being generated. Thus a square array of hills will be generated. Any other value means that the hills will be placed randomly on the surface. Default is 1.
virtual int vtkParametricRandomHills::GetAllowRandomGeneration | ( | ) | [virtual] |
Set/Get the random generation flag. A value of 0 will disable the generation of random hills on the surface allowing a reproducible number of identically shaped hills to be generated. If zero, then the number of hills used will be the nearest perfect square less than or equal to the number of hills. For example, selecting 30 hills will result in a 5 X 5 array of hills being generated. Thus a square array of hills will be generated. Any other value means that the hills will be placed randomly on the surface. Default is 1.
virtual void vtkParametricRandomHills::AllowRandomGenerationOn | ( | ) | [virtual] |
Set/Get the random generation flag. A value of 0 will disable the generation of random hills on the surface allowing a reproducible number of identically shaped hills to be generated. If zero, then the number of hills used will be the nearest perfect square less than or equal to the number of hills. For example, selecting 30 hills will result in a 5 X 5 array of hills being generated. Thus a square array of hills will be generated. Any other value means that the hills will be placed randomly on the surface. Default is 1.
virtual void vtkParametricRandomHills::AllowRandomGenerationOff | ( | ) | [virtual] |
Set/Get the random generation flag. A value of 0 will disable the generation of random hills on the surface allowing a reproducible number of identically shaped hills to be generated. If zero, then the number of hills used will be the nearest perfect square less than or equal to the number of hills. For example, selecting 30 hills will result in a 5 X 5 array of hills being generated. Thus a square array of hills will be generated. Any other value means that the hills will be placed randomly on the surface. Default is 1.
virtual void vtkParametricRandomHills::SetXVarianceScaleFactor | ( | double | ) | [virtual] |
Set/Get the scaling factor for the variance in the x-direction. Default is 1/3.
virtual double vtkParametricRandomHills::GetXVarianceScaleFactor | ( | ) | [virtual] |
Set/Get the scaling factor for the variance in the x-direction. Default is 1/3.
virtual void vtkParametricRandomHills::SetYVarianceScaleFactor | ( | double | ) | [virtual] |
Set/Get the scaling factor for the variance in the y-direction. Default is 1/3.
virtual double vtkParametricRandomHills::GetYVarianceScaleFactor | ( | ) | [virtual] |
Set/Get the scaling factor for the variance in the y-direction. Default is 1/3.
virtual void vtkParametricRandomHills::SetAmplitudeScaleFactor | ( | double | ) | [virtual] |
Set/Get the scaling factor for the amplitude. Default is 1/3.
virtual double vtkParametricRandomHills::GetAmplitudeScaleFactor | ( | ) | [virtual] |
Set/Get the scaling factor for the amplitude. Default is 1/3.
void vtkParametricRandomHills::GenerateTheHills | ( | void | ) |
Generate the centers of the hills, their standard deviations and their amplitudes. This function creates a series of vectors representing the u, v coordinates of each hill, its variance in the u, v directions and the amplitude.
virtual void vtkParametricRandomHills::Evaluate | ( | double | uvw[3], |
double | Pt[3], | ||
double | Duvw[9] | ||
) | [virtual] |
Construct a terrain consisting of hills on a surface. This function performs the mapping , returning it as Pt. It also returns the partial derivatives Du and Dv. . Then the normal is .
Implements vtkParametricFunction.
virtual double vtkParametricRandomHills::EvaluateScalar | ( | double | uvw[3], |
double | Pt[3], | ||
double | Duvw[9] | ||
) | [virtual] |
Calculate a user defined scalar using one or all of uvw, Pt, Duvw. uvw are the parameters with Pt being the the Cartesian point, Duvw are the derivatives of this point with respect to u, v and w. Pt, Duvw are obtained from Evaluate(). This function is only called if the ScalarMode has the value vtkParametricFunctionSource::SCALAR_FUNCTION_DEFINED If the user does not need to calculate a scalar, then the instantiated function should return zero.
Implements vtkParametricFunction.
int vtkParametricRandomHills::NumberOfHills [protected] |
Definition at line 161 of file vtkParametricRandomHills.h.
double vtkParametricRandomHills::HillXVariance [protected] |
Definition at line 162 of file vtkParametricRandomHills.h.
double vtkParametricRandomHills::HillYVariance [protected] |
Definition at line 163 of file vtkParametricRandomHills.h.
double vtkParametricRandomHills::HillAmplitude [protected] |
Definition at line 164 of file vtkParametricRandomHills.h.
int vtkParametricRandomHills::RandomSeed [protected] |
Definition at line 165 of file vtkParametricRandomHills.h.
double vtkParametricRandomHills::XVarianceScaleFactor [protected] |
Definition at line 166 of file vtkParametricRandomHills.h.
double vtkParametricRandomHills::YVarianceScaleFactor [protected] |
Definition at line 167 of file vtkParametricRandomHills.h.
double vtkParametricRandomHills::AmplitudeScaleFactor [protected] |
Definition at line 168 of file vtkParametricRandomHills.h.
int vtkParametricRandomHills::AllowRandomGeneration [protected] |
Definition at line 169 of file vtkParametricRandomHills.h.
int vtkParametricRandomHills::previousNumberOfHills [protected] |
Definition at line 172 of file vtkParametricRandomHills.h.
Definition at line 173 of file vtkParametricRandomHills.h.
Definition at line 174 of file vtkParametricRandomHills.h.
Definition at line 175 of file vtkParametricRandomHills.h.
int vtkParametricRandomHills::previousRandomSeed [protected] |
Definition at line 176 of file vtkParametricRandomHills.h.
Definition at line 177 of file vtkParametricRandomHills.h.
Definition at line 178 of file vtkParametricRandomHills.h.
Definition at line 179 of file vtkParametricRandomHills.h.
Definition at line 180 of file vtkParametricRandomHills.h.