Struct nannou::geom::graph::node::Dfs [−][src]
A depth-first-search over nodes in the graph, yielding each node’s unique index alongside its absolute transform.
The traversal may start at any given node.
Note: The algorithm may not behave correctly if nodes are removed during iteration. It may not necessarily visit added nodes or edges.
Implementations
impl<S> Dfs<S> where
S: BaseFloat,
[src]
S: BaseFloat,
pub fn new(graph: &Graph<S>) -> Self
[src]
Create a new Dfs starting from the graph’s origin.
pub fn start_from(graph: &Graph<S>, start: Index) -> Self
[src]
Create a new Dfs starting from the node at the given node.
pub fn reset(&mut self, graph: &Graph<S>)
[src]
Clears the visit state.
pub fn move_to(&mut self, start: Index)
[src]
Keep the discovered map but clear the visit stack and restart the dfs from the given node.
pub fn next_transform(
&mut self,
graph: &Graph<S>
) -> Option<(Index, Transform<S>)>
[src]
&mut self,
graph: &Graph<S>
) -> Option<(Index, Transform<S>)>
Return the tranform for the next node in the DFS.
Returns None
if the traversal is finished.
pub fn next_vertices<F, I>(
&mut self,
graph: &Graph<S>,
vertices_fn: F
) -> Option<(Index, TransformedVertices<I::IntoIter, S>)> where
F: FnOnce(&Index) -> I,
I: IntoIterator,
I::Item: ApplyTransform<S>,
[src]
&mut self,
graph: &Graph<S>,
vertices_fn: F
) -> Option<(Index, TransformedVertices<I::IntoIter, S>)> where
F: FnOnce(&Index) -> I,
I: IntoIterator,
I::Item: ApplyTransform<S>,
Return the vertices for the next node in the DFS.
Uses Dfs::next_transform
internally.
Returns None
if the traversal is finished.
pub fn next_triangles<F, I, V>(
&mut self,
graph: &Graph<S>,
triangles_fn: F
) -> Option<(Index, TransformedTriangles<I::IntoIter, V, S>)> where
F: FnOnce(&Index) -> I,
I: IntoIterator<Item = Tri<V>>,
V: Vertex + ApplyTransform<S>,
[src]
&mut self,
graph: &Graph<S>,
triangles_fn: F
) -> Option<(Index, TransformedTriangles<I::IntoIter, V, S>)> where
F: FnOnce(&Index) -> I,
I: IntoIterator<Item = Tri<V>>,
V: Vertex + ApplyTransform<S>,
Return the triangles for the next node in the DFS.
Uses Dfs::next_transform
and Node::triangles
internally.
Returns None
if the traversal is finished.
Trait Implementations
impl<S: Clone> Clone for Dfs<S> where
S: BaseFloat,
[src]
S: BaseFloat,
impl<S: Debug> Debug for Dfs<S> where
S: BaseFloat,
[src]
S: BaseFloat,
impl<'a, S> Walker<&'a Graph<S>> for Dfs<S> where
S: BaseFloat,
[src]
S: BaseFloat,
Auto Trait Implementations
impl<S> RefUnwindSafe for Dfs<S> where
S: RefUnwindSafe,
S: RefUnwindSafe,
impl<S> Send for Dfs<S> where
S: Send,
S: Send,
impl<S> Sync for Dfs<S> where
S: Sync,
S: Sync,
impl<S> Unpin for Dfs<S> where
S: Unpin,
S: Unpin,
impl<S> UnwindSafe for Dfs<S> where
S: UnwindSafe,
S: UnwindSafe,
Blanket Implementations
impl<S, D, Swp, Dwp, T> AdaptInto<D, Swp, Dwp, T> for S where
T: Component + Float,
D: AdaptFrom<S, Swp, Dwp, T>,
Swp: WhitePoint,
Dwp: WhitePoint,
[src]
T: Component + Float,
D: AdaptFrom<S, Swp, Dwp, T>,
Swp: WhitePoint,
Dwp: WhitePoint,
pub fn adapt_into_using<M>(self, method: M) -> D where
M: TransformMatrix<Swp, Dwp, T>,
[src]
M: TransformMatrix<Swp, Dwp, T>,
pub fn adapt_into(self) -> D
[src]
impl<T> Any for T where
T: 'static + ?Sized,
[src]
T: 'static + ?Sized,
impl<T> Borrow<T> for T where
T: ?Sized,
[src]
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
[src]
T: ?Sized,
pub fn borrow_mut(&mut self) -> &mut T
[src]
impl<T, U> ConvertInto<U> for T where
U: ConvertFrom<T>,
[src]
U: ConvertFrom<T>,
pub fn convert_into(self) -> U
[src]
pub fn convert_unclamped_into(self) -> U
[src]
pub fn try_convert_into(self) -> Result<U, OutOfBounds<U>>
[src]
impl<T> Downcast<T> for T
impl<T> From<T> for T
[src]
impl<T> Instrument for T
[src]
pub fn instrument(self, span: Span) -> Instrumented<Self>
[src]
pub fn in_current_span(self) -> Instrumented<Self>
[src]
impl<T, U> Into<U> for T where
U: From<T>,
[src]
U: From<T>,
impl<T> Pointable for T
pub const ALIGN: usize
type Init = T
The type for initializers.
pub unsafe fn init(init: <T as Pointable>::Init) -> usize
pub unsafe fn deref<'a>(ptr: usize) -> &'a T
pub unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T
pub unsafe fn drop(ptr: usize)
impl<T> SetParameter for T
pub fn set<T>(&mut self, value: T) -> <T as Parameter<Self>>::Result where
T: Parameter<Self>,
T: Parameter<Self>,
impl<T> ToOwned for T where
T: Clone,
[src]
T: Clone,
type Owned = T
The resulting type after obtaining ownership.
pub fn to_owned(&self) -> T
[src]
pub fn clone_into(&self, target: &mut T)
[src]
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.
pub 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.
pub fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>
[src]
impl<T> Upcast<T> for T
impl<V, T> VZip<V> for T where
V: MultiLane<T>,
V: MultiLane<T>,