fix: make rectangle_tracker subscription only return update if there is some
This commit is contained in:
parent
d38b68244a
commit
f433b3dc20
1 changed files with 41 additions and 34 deletions
|
|
@ -14,7 +14,7 @@ pub fn rectangle_tracker_subscription<
|
||||||
R: 'static + Hash + Copy + Send + Sync + Debug + Eq,
|
R: 'static + Hash + Copy + Send + Sync + Debug + Eq,
|
||||||
>(
|
>(
|
||||||
id: I,
|
id: I,
|
||||||
) -> iced::Subscription<Option<(I, RectangleUpdate<R>)>> {
|
) -> iced::Subscription<(I, RectangleUpdate<R>)> {
|
||||||
subscription::unfold(id, State::Ready, move |state| start_listening(id, state))
|
subscription::unfold(id, State::Ready, move |state| start_listening(id, state))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -26,44 +26,51 @@ pub enum State<I> {
|
||||||
|
|
||||||
async fn start_listening<I: Copy, R: 'static + Hash + Copy + Send + Sync + Debug + Eq>(
|
async fn start_listening<I: Copy, R: 'static + Hash + Copy + Send + Sync + Debug + Eq>(
|
||||||
id: I,
|
id: I,
|
||||||
state: State<R>,
|
mut state: State<R>,
|
||||||
) -> (Option<(I, RectangleUpdate<R>)>, State<R>) {
|
) -> ((I, RectangleUpdate<R>), State<R>) {
|
||||||
match state {
|
loop {
|
||||||
State::Ready => {
|
let (update, new_state) = match state {
|
||||||
let (tx, rx) = unbounded();
|
State::Ready => {
|
||||||
|
let (tx, rx) = unbounded();
|
||||||
|
|
||||||
(
|
(
|
||||||
Some((id, RectangleUpdate::Init(RectangleTracker { tx }))),
|
Some((id, RectangleUpdate::Init(RectangleTracker { tx }))),
|
||||||
State::Waiting(rx, HashMap::new()),
|
State::Waiting(rx, HashMap::new()),
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
State::Waiting(mut rx, mut map) => match rx.next().await {
|
State::Waiting(mut rx, mut map) => match rx.next().await {
|
||||||
Some(u) => {
|
Some(u) => {
|
||||||
if let Some(prev) = map.get(&u.0) {
|
if let Some(prev) = map.get(&u.0) {
|
||||||
let new = u.1;
|
let new = u.1;
|
||||||
if (prev.width - new.width).abs() > 0.1
|
if (prev.width - new.width).abs() > 0.1
|
||||||
|| (prev.height - new.height).abs() > 0.1
|
|| (prev.height - new.height).abs() > 0.1
|
||||||
|| (prev.x - new.x).abs() > 0.1
|
|| (prev.x - new.x).abs() > 0.1
|
||||||
|| (prev.y - new.y).abs() > 0.1
|
|| (prev.y - new.y).abs() > 0.1
|
||||||
{
|
{
|
||||||
map.insert(u.0, new);
|
map.insert(u.0, new);
|
||||||
return (
|
(
|
||||||
|
Some((id, RectangleUpdate::Rectangle(u))),
|
||||||
|
State::Waiting(rx, map),
|
||||||
|
)
|
||||||
|
} else {
|
||||||
|
(None, State::Waiting(rx, map))
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
map.insert(u.0, u.1);
|
||||||
|
(
|
||||||
Some((id, RectangleUpdate::Rectangle(u))),
|
Some((id, RectangleUpdate::Rectangle(u))),
|
||||||
State::Waiting(rx, map),
|
State::Waiting(rx, map),
|
||||||
);
|
)
|
||||||
}
|
}
|
||||||
} else {
|
|
||||||
map.insert(u.0, u.1);
|
|
||||||
return (
|
|
||||||
Some((id, RectangleUpdate::Rectangle(u))),
|
|
||||||
State::Waiting(rx, map),
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
(None, State::Waiting(rx, map))
|
None => (None, State::Finished),
|
||||||
}
|
},
|
||||||
None => (None, State::Finished),
|
State::Finished => iced::futures::future::pending().await,
|
||||||
},
|
};
|
||||||
State::Finished => iced::futures::future::pending().await,
|
state = new_state;
|
||||||
|
if let Some(u) = update {
|
||||||
|
return (u, state);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue