[][src]Struct map_model::pathfind::Path

pub struct Path {
    steps: VecDeque<PathStep>,
    orig_req: PathRequest,
    total_length: Distance,
    crossed_so_far: Distance,
    uber_turns: VecDeque<UberTurn>,
    currently_inside_ut: Option<UberTurn>,
}

Fields

steps: VecDeque<PathStep>orig_req: PathRequesttotal_length: Distancecrossed_so_far: Distanceuber_turns: VecDeque<UberTurn>currently_inside_ut: Option<UberTurn>

Implementations

impl Path[src]

pub(crate) fn new(
    map: &Map,
    steps: Vec<PathStep>,
    orig_req: PathRequest,
    uber_turns: Vec<UberTurn>
) -> Path
[src]

pub fn dist_crossed_from_step(&self, map: &Map, step: &PathStep) -> Distance[src]

Once we finish this PathStep, how much distance will be crossed? If the step is at the beginning or end of our path, then the full length may not be used.

pub fn one_step(req: PathRequest, map: &Map) -> Path[src]

pub fn get_req(&self) -> &PathRequest[src]

The original PathRequest used to produce this path. If the path has been modified since creation, the start and end of the request won't match up with the current path steps.

pub fn crossed_so_far(&self) -> Distance[src]

pub fn total_length(&self) -> Distance[src]

pub fn percent_dist_crossed(&self) -> f64[src]

pub fn is_empty(&self) -> bool[src]

pub fn is_last_step(&self) -> bool[src]

pub fn isnt_last_step(&self) -> bool[src]

pub fn currently_inside_ut(&self) -> &Option<UberTurn>[src]

pub fn about_to_start_ut(&self) -> Option<&UberTurn>[src]

pub fn shift(&mut self, map: &Map) -> PathStep[src]

pub fn add(&mut self, step: PathStep, map: &Map)[src]

pub fn is_upcoming_uber_turn_component(&self, t: TurnID) -> bool[src]

pub fn modify_step(&mut self, idx: usize, step: PathStep, map: &Map)[src]

Trusting the caller to do this in valid ways.

pub fn current_step(&self) -> PathStep[src]

pub fn next_step(&self) -> PathStep[src]

pub fn maybe_next_step(&self) -> Option<PathStep>[src]

pub fn last_step(&self) -> PathStep[src]

pub fn trace(
    &self,
    map: &Map,
    start_dist: Distance,
    dist_ahead: Option<Distance>
) -> Option<PolyLine>
[src]

dist_ahead is unlimited when None. Note this starts at the beginning (or end, for some walking paths) of the first lane, not accounting for the original request's start distance.

pub fn get_steps(&self) -> &VecDeque<PathStep>[src]

fn append(&mut self, other: Path, map: &Map)[src]

pub fn estimate_duration(
    &self,
    map: &Map,
    constraints: PathConstraints,
    max_speed: Option<Speed>
) -> Duration
[src]

Estimate how long following the path will take in the best case, assuming no traffic or delay at intersections. To determine the speed along each step, the agent following their path and their optional max_speed must be specified.

Trait Implementations

impl Clone for Path[src]

impl Debug for Path[src]

impl<'de> Deserialize<'de> for Path[src]

impl PartialEq<Path> for Path[src]

impl Serialize for Path[src]

impl StructuralPartialEq for Path[src]

Auto Trait Implementations

impl RefUnwindSafe for Path

impl Send for Path

impl Sync for Path

impl Unpin for Path

impl UnwindSafe for Path

Blanket Implementations

impl<T> Any for T where
    T: 'static + ?Sized
[src]

impl<T> Borrow<T> for T where
    T: ?Sized
[src]

impl<T> BorrowMut<T> for T where
    T: ?Sized
[src]

impl<T> DeserializeOwned for T where
    T: for<'de> Deserialize<'de>, 
[src]

impl<T> From<T> for T[src]

impl<T, U> Into<U> for T where
    U: From<T>, 
[src]

impl<T> Same<T> for T

type Output = T

Should always be Self

impl<T> ToOwned for T where
    T: Clone
[src]

type Owned = T

The resulting type after obtaining ownership.

impl<T, U> TryFrom<U> for T where
    U: Into<T>, 
[src]

type Error = Infallible

The type returned in the event of a conversion error.

impl<T, U> TryInto<U> for T where
    U: TryFrom<T>, 
[src]

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

The type returned in the event of a conversion error.

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