pub struct AutoPatternConstraint<'a, 'b, Pos, Ter, Pat> {
pub position_constraints: &'a HashConstraintMap<Pos, Ter, Pat>,
pub pattern_constraints: &'b HashMap<Ter, Vec<Pat>, BuildHasherDefault<FxHasher>>,
}Expand description
A pair of an HashConstraintMap and an AutoTerrainPatternMap.
- The constraint map tells the auto-tiler which cells have undecided patterns, which cells have fixed patterns, the terrain type of the undecided cells, and the order in which to fill them.
- The terrain map tells the auto-tiler which patterns are available for each terrain type, and the order in which the patterns should be tried.
See AutoTileContext for a way to construct an AutoTerrainPatternMap.
Fields§
§position_constraints: &'a HashConstraintMap<Pos, Ter, Pat>The position constraints define the specific problem for the autotiler to solve by giving it the constraints for each cell, including the cells whose tiles are already determined and the cells that are yet to be determined.
pattern_constraints: &'b HashMap<Ter, Vec<Pat>, BuildHasherDefault<FxHasher>>The pattern contraints define the patterns that are available for each terrain.
This will usually remain fixed across many calls to the autotiler, and so it may be reused
so long as the set of tiles does not change.
See AutoTileContext for a way to construct an AutoTerrainPatternMap.
Trait Implementations§
Source§impl<'b, Pos, Ter, Pat> AutoConstrain for AutoPatternConstraint<'_, 'b, Pos, Ter, Pat>where
Pos: OffsetPosition,
Ter: Hash + Eq,
Pat: TilePattern<Offset = <Pos as OffsetPosition>::Offset, Diagonal = <Pos as OffsetPosition>::Diagonal> + Clone + Debug,
<Pos as OffsetPosition>::Offset: Debug,
impl<'b, Pos, Ter, Pat> AutoConstrain for AutoPatternConstraint<'_, 'b, Pos, Ter, Pat>where
Pos: OffsetPosition,
Ter: Hash + Eq,
Pat: TilePattern<Offset = <Pos as OffsetPosition>::Offset, Diagonal = <Pos as OffsetPosition>::Diagonal> + Clone + Debug,
<Pos as OffsetPosition>::Offset: Debug,
Source§type Terrain = ListTerrain<'b, Pat>
type Terrain = ListTerrain<'b, Pat>
The type of tile terrains. Each terrain represents a set of possible patterns.
Source§fn all_positions(
&self,
) -> impl Iterator<Item = &<AutoPatternConstraint<'_, 'b, Pos, Ter, Pat> as AutoConstrain>::Position>
fn all_positions( &self, ) -> impl Iterator<Item = &<AutoPatternConstraint<'_, 'b, Pos, Ter, Pat> as AutoConstrain>::Position>
An iterator for all the positions that the autotiler should consider when
choosing tiles. The autotiler will select tiles for position in the order
they are delivered by this iterator.
Source§fn constraint_at(
&self,
position: &Pos,
) -> TileConstraint<ListTerrain<'b, Pat>, Pat> ⓘ
fn constraint_at( &self, position: &Pos, ) -> TileConstraint<ListTerrain<'b, Pat>, Pat> ⓘ
The contraint for the given position. This allows the autotiler to examine
adjacent cells when deciding if a particular pattern is a valid choice
for the cell under consideration.
Source§fn is_legal(
&self,
from: &Pat,
offset: &<Pos as OffsetPosition>::Offset,
to: &Pat,
) -> bool
fn is_legal( &self, from: &Pat, offset: &<Pos as OffsetPosition>::Offset, to: &Pat, ) -> bool
True if the given patterns may be placed adjacent to each other with the
given offset. For example, if
offset is up, then return true if
to may be legally placed above from.Source§fn is_legal_diagonal(
&self,
from: &Pat,
diagonal: &<Pos as OffsetPosition>::Diagonal,
to: &Pat,
) -> bool
fn is_legal_diagonal( &self, from: &Pat, diagonal: &<Pos as OffsetPosition>::Diagonal, to: &Pat, ) -> bool
True if the given patterns may be placed adjacent to each other with the
given offset. For example, if
offset is up, then return true if
to may be legally placed above from.Auto Trait Implementations§
impl<'a, 'b, Pos, Ter, Pat> Freeze for AutoPatternConstraint<'a, 'b, Pos, Ter, Pat>
impl<'a, 'b, Pos, Ter, Pat> RefUnwindSafe for AutoPatternConstraint<'a, 'b, Pos, Ter, Pat>
impl<'a, 'b, Pos, Ter, Pat> Send for AutoPatternConstraint<'a, 'b, Pos, Ter, Pat>
impl<'a, 'b, Pos, Ter, Pat> Sync for AutoPatternConstraint<'a, 'b, Pos, Ter, Pat>
impl<'a, 'b, Pos, Ter, Pat> Unpin for AutoPatternConstraint<'a, 'b, Pos, Ter, Pat>
impl<'a, 'b, Pos, Ter, Pat> UnwindSafe for AutoPatternConstraint<'a, 'b, Pos, Ter, Pat>
Blanket Implementations§
Source§impl<T> AsyncTaskResult for T
impl<T> AsyncTaskResult for T
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
Source§fn into_any(self: Box<T>) -> Box<dyn Any>
fn into_any(self: Box<T>) -> Box<dyn Any>
Convert
Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>. Box<dyn Any> can
then be further downcast into Box<ConcreteType> where ConcreteType implements Trait.Source§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Convert
Rc<Trait> (where Trait: Downcast) to Rc<Any>. Rc<Any> can then be
further downcast into Rc<ConcreteType> where ConcreteType implements Trait.Source§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
Convert
&Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &Any’s vtable from &Trait’s.Source§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
Convert
&mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &mut Any’s vtable from &mut Trait’s.Source§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
Source§fn into_any(self: Box<T>) -> Box<dyn Any>
fn into_any(self: Box<T>) -> Box<dyn Any>
Converts
Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>, which can then be
downcast into Box<dyn ConcreteType> where ConcreteType implements Trait.Source§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Converts
Rc<Trait> (where Trait: Downcast) to Rc<Any>, which can then be further
downcast into Rc<ConcreteType> where ConcreteType implements Trait.Source§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
Converts
&Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &Any’s vtable from &Trait’s.Source§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
Converts
&mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &mut Any’s vtable from &mut Trait’s.Source§impl<T> DowncastSend for T
impl<T> DowncastSend for T
Source§impl<T> DowncastSync for T
impl<T> DowncastSync for T
Source§impl<T> DowncastSync for T
impl<T> DowncastSync for T
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
Source§fn in_current_span(self) -> Instrumented<Self> ⓘ
fn in_current_span(self) -> Instrumented<Self> ⓘ
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
Converts
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
Converts
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§impl<F, T> IntoSample<T> for Fwhere
T: FromSample<F>,
impl<F, T> IntoSample<T> for Fwhere
T: FromSample<F>,
fn into_sample(self) -> T
Source§impl<T, U> ObjectOrVariant<T> for Uwhere
PhantomData<U>: ObjectOrVariantHelper<T, U>,
impl<T, U> ObjectOrVariant<T> for Uwhere
PhantomData<U>: ObjectOrVariantHelper<T, U>,
Source§impl<T> Pointable for T
impl<T> Pointable for T
Source§impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
Source§fn to_subset(&self) -> Option<SS>
fn to_subset(&self) -> Option<SS>
The inverse inclusion map: attempts to construct
self from the equivalent element of its
superset. Read moreSource§fn is_in_subset(&self) -> bool
fn is_in_subset(&self) -> bool
Checks if
self is actually part of its subset T (and can be converted to it).Source§fn to_subset_unchecked(&self) -> SS
fn to_subset_unchecked(&self) -> SS
Use with care! Same as
self.to_subset but without any property checks. Always succeeds.Source§fn from_subset(element: &SS) -> SP
fn from_subset(element: &SS) -> SP
The inclusion map: converts
self to the equivalent element of its superset.