logo
pub struct ElementDefinition {
    pub name: String,
    pub count: usize,
    pub properties: LinkedHashMap<String, PropertyDef, RandomState>,
}
Expand description

Models the definition of an element.

Elements describe single entities consisting of different properties. A single point is an element. We might model it as consisting of three coordinates: x, y, and z. Usually, one finds a list of elements in a ply file.

Fields

name: String

Name of the element.

Each element within a PLY file needs a unique name. There are common conventions like using “vertex” and “face” to assure interoperability between applications. For further information, please consult your target applications or the original specification.

count: usize

Describes, how many elements appear in a PLY file.

The count is used when reading since we need to know how many elements we should interprete as having this type. The count is also needed for writing, since it will be written to the header.

properties: LinkedHashMap<String, PropertyDef, RandomState>

An element is modeled by multiple properties, those are named values or lists.

Examples

  • Point: We can define a point by its three coordinates. Hence we have three properties: x, y, and z. Reasonable types would be float or double.
  • Polygon: A polygon can be defined as a list of points. Since the points are stored in a list, we can define a list of indices. Good types would be some of the unsigned integer lists.

Implementations

Creates a new element definition.

The name should be unique for each element in a PLY file.

You should never need to set count manuall, since it is set by the consistency check (see make_consistent() of Ply).

No properties are set.

Trait Implementations

Returns a copy of the value. Read more

Performs copy-assignment from source. Read more

Formats the value using the given formatter. Read more

Returns a key under which the element should be stored in a key-value store.

This method tests for self and other values to be equal, and is used by ==. Read more

This method tests for !=.

Auto Trait Implementations

Blanket Implementations

Gets the TypeId of self. Read more

Immutably borrows from an owned value. Read more

Mutably borrows from an owned value. Read more

Returns the argument unchanged.

Calls U::from(self).

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

Should always be Self

The inverse inclusion map: attempts to construct self from the equivalent element of its superset. Read more

Checks if self is actually part of its subset T (and can be converted to it).

Use with care! Same as self.to_subset but without any property checks. Always succeeds.

The inclusion map: converts self to the equivalent element of its superset.

The resulting type after obtaining ownership.

Creates owned data from borrowed data, usually by cloning. Read more

Uses borrowed data to replace owned data, usually by cloning. Read more

The type returned in the event of a conversion error.

Performs the conversion.

The type returned in the event of a conversion error.

Performs the conversion.