Struct nannou::noise::Terrace

source ·
pub struct Terrace<'a, T> {
    pub source: &'a dyn NoiseFn<T>,
    pub invert_terraces: bool,
    /* private fields */
}
Expand description

Noise function that maps the output value from the source function onto a terrace-forming curve.

This noise function maps the output value from the source function onto a terrace-forming curve. The start of the curve has a slode of zero; it’s slope then smoothly increases. This curve also contains control points which resets the slope to zero at that point, producing a “terracing” effect.

To add control points to the curve, use the add_control_point method.

An application must add a minimum of two control points to the curve. If there are less than two control points, the get() method panics. The control points can have any value, although no two control points can have the same value. There is no limit to the number of control points that can be added to the curve.

The noise function clamps the output value from the source function if that value is less than the value of the lowest control point or greater than the value of the highest control point.

This noise function is often used to generate terrain features such as the stereotypical desert canyon.

Fields§

§source: &'a dyn NoiseFn<T>

Outputs a value.

§invert_terraces: bool

Determines if the terrace-forming curve between all control points is inverted.

Implementations§

source§

impl<'a, T> Terrace<'a, T>

source

pub fn new(source: &'a dyn NoiseFn<T>) -> Terrace<'a, T>

source

pub fn add_control_point(self, control_point: f64) -> Terrace<'a, T>

Adds a control point to the terrace-forming curve.

Two or more control points define the terrace-forming curve. The start of this curve has a slope of zero; its slope then smoothly increases. At the control points, its slope resets to zero.

It does not matter which order these points are added in.

source

pub fn invert_terraces(self, invert_terraces: bool) -> Terrace<'a, T>

Enables or disables the inversion of the terrain-forming curve between the control points.

Trait Implementations§

source§

impl<'a, T> NoiseFn<T> for Terrace<'a, T>

source§

fn get(&self, point: T) -> f64

Auto Trait Implementations§

§

impl<'a, T> !RefUnwindSafe for Terrace<'a, T>

§

impl<'a, T> !Send for Terrace<'a, T>

§

impl<'a, T> !Sync for Terrace<'a, T>

§

impl<'a, T> Unpin for Terrace<'a, T>

§

impl<'a, T> !UnwindSafe for Terrace<'a, T>

Blanket Implementations§

source§

impl<S, D, Swp, Dwp, T> AdaptInto<D, Swp, Dwp, T> for S
where T: Component + Float, Swp: WhitePoint, Dwp: WhitePoint, D: AdaptFrom<S, Swp, Dwp, T>,

source§

fn adapt_into_using<M>(self, method: M) -> D
where M: TransformMatrix<Swp, Dwp, T>,

Convert the source color to the destination color using the specified method
source§

fn adapt_into(self) -> D

Convert the source color to the destination color using the bradford method by default
source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T, U> ConvertInto<U> for T
where U: ConvertFrom<T>,

source§

fn convert_into(self) -> U

Convert into T with values clamped to the color defined bounds Read more
source§

fn convert_unclamped_into(self) -> U

Convert into T. The resulting color might be invalid in its color space Read more
source§

fn try_convert_into(self) -> Result<U, OutOfBounds<U>>

Convert into T, returning ok if the color is inside of its defined range, otherwise an OutOfBounds error is returned which contains the unclamped color. Read more
§

impl<T> Downcast<T> for T

§

fn downcast(&self) -> &T

source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

§

impl<T> Pointable for T

§

const ALIGN: usize = _

The alignment of pointer.
§

type Init = T

The type for initializers.
§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
§

impl<T> Upcast<T> for T

§

fn upcast(&self) -> Option<&T>

§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

§

fn vzip(self) -> V