[−][src]Enum gfx_hal::Primitive
Describes the type of geometric primitives, created from vertex data.
Variants
PointList
Each vertex represents a single point.
LineList
Each pair of vertices represent a single line segment. For example, with [a, b, c, d, e]
, a
and b
form a line, c
and d
form a line, and e
is discarded.
LineStrip
Every two consecutive vertices represent a single line segment. Visually forms a "path" of
lines, as they are all connected. For example, with [a, b, c]
, a
and b
form a line
line, and b
and c
form a line.
TriangleList
Each triplet of vertices represent a single triangle. For example, with [a, b, c, d, e]
,
a
, b
, and c
form a triangle, d
and e
are discarded.
TriangleStrip
Every three consecutive vertices represent a single triangle. For example, with [a, b, c, d]
, a
, b
, and c
form a triangle, and b
, c
, and d
form a triangle.
LineListAdjacency
Each quadtruplet of vertices represent a single line segment with adjacency information.
For example, with [a, b, c, d]
, b
and c
form a line, and a
and d
are the adjacent
vertices.
LineStripAdjacency
Every four consecutive vertices represent a single line segment with adjacency information.
For example, with [a, b, c, d, e]
, [a, b, c, d]
form a line segment with adjacency, and
[b, c, d, e]
form a line segment with adjacency.
TriangleListAdjacency
Each sextuplet of vertices represent a single triangle with adjacency information. For
example, with [a, b, c, d, e, f]
, a
, c
, and e
form a triangle, and b
, d
, and
f
are the adjacent vertices, where b
is adjacent to the edge formed by a
and c
, d
is adjacent to the edge c
and e
, and f
is adjacent to the edge e
and a
.
TriangleStripAdjacency
Every even-numbered vertex (every other starting from the first) represents an additional
vertex for the triangle strip, while odd-numbered vertices (every other starting from the
second) represent adjacent vertices. For example, with [a, b, c, d, e, f, g, h]
, [a, c, e, g]
form a triangle strip, and [b, d, f, h]
are the adjacent vertices, where b
, d
,
and f
are adjacent to the first triangle in the strip, and d
, f
, and h
are adjacent
to the second.
PatchList(PatchSize)
Patch list, used with shaders capable of producing primitives on their own (tessellation)
Trait Implementations
impl Copy for Primitive
[src]
impl Eq for Primitive
[src]
impl Clone for Primitive
[src]
fn clone(&self) -> Primitive
[src]
fn clone_from(&mut self, source: &Self)
1.0.0[src]
Performs copy-assignment from source
. Read more
impl PartialOrd<Primitive> for Primitive
[src]
fn partial_cmp(&self, other: &Primitive) -> Option<Ordering>
[src]
fn lt(&self, other: &Primitive) -> bool
[src]
fn le(&self, other: &Primitive) -> bool
[src]
fn gt(&self, other: &Primitive) -> bool
[src]
fn ge(&self, other: &Primitive) -> bool
[src]
impl PartialEq<Primitive> for Primitive
[src]
impl Ord for Primitive
[src]
fn cmp(&self, other: &Primitive) -> Ordering
[src]
fn max(self, other: Self) -> Self
1.21.0[src]
Compares and returns the maximum of two values. Read more
fn min(self, other: Self) -> Self
1.21.0[src]
Compares and returns the minimum of two values. Read more
fn clamp(self, min: Self, max: Self) -> Self
[src]
clamp
)Restrict a value to a certain interval. Read more
impl Hash for Primitive
[src]
fn hash<__H: Hasher>(&self, state: &mut __H)
[src]
fn hash_slice<H>(data: &[Self], state: &mut H) where
H: Hasher,
1.3.0[src]
H: Hasher,
Feeds a slice of this type into the given [Hasher
]. Read more
impl Debug for Primitive
[src]
impl Serialize for Primitive
[src]
fn serialize<__S>(&self, __serializer: __S) -> Result<__S::Ok, __S::Error> where
__S: Serializer,
[src]
__S: Serializer,
impl<'de> Deserialize<'de> for Primitive
[src]
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error> where
__D: Deserializer<'de>,
[src]
__D: Deserializer<'de>,
Auto Trait Implementations
impl Unpin for Primitive
impl Sync for Primitive
impl Send for Primitive
impl UnwindSafe for Primitive
impl RefUnwindSafe for Primitive
Blanket Implementations
impl<T> Supports<T> for T
[src]
impl<T> ToOwned for T where
T: Clone,
[src]
T: Clone,
type Owned = T
The resulting type after obtaining ownership.
fn to_owned(&self) -> T
[src]
fn clone_into(&self, target: &mut T)
[src]
impl<T> From<T> for T
[src]
impl<T, U> Into<U> for T where
U: From<T>,
[src]
U: From<T>,
impl<T, U> TryFrom<U> for T where
U: Into<T>,
[src]
U: Into<T>,
type Error = Infallible
The type returned in the event of a conversion error.
fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>
[src]
impl<T, U> TryInto<U> for T where
U: TryFrom<T>,
[src]
U: TryFrom<T>,
type Error = <U as TryFrom<T>>::Error
The type returned in the event of a conversion error.
fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>
[src]
impl<T> Borrow<T> for T where
T: ?Sized,
[src]
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
[src]
T: ?Sized,
fn borrow_mut(&mut self) -> &mut T
[src]
impl<T> Any for T where
T: 'static + ?Sized,
[src]
T: 'static + ?Sized,
impl<T> DeserializeOwned for T where
T: Deserialize<'de>,
[src]
T: Deserialize<'de>,