diff --git a/client/bin/src/main.rs b/client/bin/src/main.rs index cad483e..843e003 100644 --- a/client/bin/src/main.rs +++ b/client/bin/src/main.rs @@ -8,7 +8,7 @@ use tinybmp::Bmp; use core::time; use embedded_graphics::{ image::Image, - mono_font::{iso_8859_1::FONT_6X10, MonoTextStyle}, + mono_font::{iso_8859_1::FONT_6X10, iso_8859_1::FONT_5X8, MonoTextStyle}, pixelcolor::BinaryColor, prelude::*, primitives::PrimitiveStyle, @@ -242,12 +242,28 @@ fn send_package(ipaddress: String, if strabaRes.failure == false { let text_style = MonoTextStyle::new(&FONT_6X10, BinaryColor::On); - let outbound = &format!("{}: {}min", strabaRes.outbound_station, (strabaRes.outbound_diff / 60)); - Text::new(outbound, Point::new(0, 15), text_style) + let text_style_station = MonoTextStyle::new(&FONT_5X8, BinaryColor::On); + let mut outbound = format!("+{}min", (strabaRes.outbound_diff / 60)); + if (strabaRes.outbound_diff < 60) { + outbound = String::from("sofort"); + } + Text::new(&strabaRes.outbound_station, Point::new(1, 15), text_style_station) .draw(&mut display) .unwrap(); - let inbound = &format!("{}: {}min", strabaRes.inbound_station, (strabaRes.inbound_diff / 60)); - Text::new(inbound, Point::new(0, 30), text_style) + Text::new(&outbound, Point::new(80, 15), text_style) + .draw(&mut display) + .unwrap(); + + let mut inbound = format!("+{}min", (strabaRes.inbound_diff / 60)); + if (strabaRes.inbound_diff < 60) { + inbound = String::from("sofort"); + } + + + Text::new(&strabaRes.inbound_station, Point::new(1, 25), text_style_station) + .draw(&mut display) + .unwrap(); + Text::new(&inbound, Point::new(80, 24), text_style) .draw(&mut display) .unwrap(); } diff --git a/client/bin/src/straba.rs b/client/bin/src/straba.rs index 7f132bb..3d01842 100644 --- a/client/bin/src/straba.rs +++ b/client/bin/src/straba.rs @@ -74,6 +74,7 @@ pub struct IsoStringDateTime { // Return value pub struct NextDeparture { + pub request_time: i64, pub outbound_station: String, pub outbound_diff: i64, pub inbound_station: String, @@ -82,23 +83,21 @@ pub struct NextDeparture { } pub fn fetch_data() -> NextDeparture { - let mut returnValue = NextDeparture { - failure : false, - outbound_station : String::from(""), - outbound_diff : -10000, - inbound_station : String::from(""), - inbound_diff : -10000, - }; let st_now = SystemTime::now(); let seconds = st_now.duration_since(UNIX_EPOCH).unwrap().as_secs(); let url = &format!("{}?datetime={}", STATION_URL, seconds); let result = reqwest::blocking::get(url); - /*let cur_time = readTime( DateTime::::default() ); - println!("Next results after {:?}", cur_time); + + let mut returnValue = NextDeparture { + failure : false, + outbound_station : String::from(""), + outbound_diff : 10000, + inbound_station : String::from(""), + inbound_diff : 10000, + request_time : seconds as i64, + }; - return Some("Debug"); -*/ println!("Start Straba Crawler"); if result.is_err() { @@ -130,20 +129,22 @@ pub fn fetch_data() -> NextDeparture { for el in (json.graphQL.response.journeys.elements) { println!("Line {:}", el.line.lineGroup.label); for stop in el.stops { - if stop.realtimeDeparture.isoString.is_some() { + // use only valid data + if stop.realtimeDeparture.isoString.is_some() && + stop.destinationLabel != "" { let txt_departure = stop.realtimeDeparture.isoString.unwrap(); let next_departure = DateTime::parse_from_rfc3339(&txt_departure).unwrap(); let diff = next_departure.timestamp() - (seconds as i64); - println!("To {:} {:}", stop.destinationLabel, txt_departure); + println!("To {:} {:} (in {:} seconds)", stop.destinationLabel, txt_departure, diff ); if returnValue.outbound_station == "" { - if stop.destinationLabel.contains("Rheinau") { + if stop.destinationLabel.contains("Rheinau") && (diff < returnValue.outbound_diff) { returnValue.outbound_station = stop.destinationLabel; returnValue.outbound_diff = diff; } else if stop.destinationLabel.contains("Hochschule") || stop.destinationLabel.contains("Hauptbahnhof") || stop.destinationLabel.contains("nau") { // Schönau - if returnValue.inbound_station == "" { + if returnValue.inbound_station == "" && (diff < returnValue.inbound_diff) { returnValue.inbound_station = stop.destinationLabel; returnValue.inbound_diff = diff; }