|  |  | @ -95,7 +95,7 @@ static void parse_banner(cereal::NavInstruction::Builder &instruction, const QMa | 
			
		
	
		
		
			
				
					
					|  |  |  | } |  |  |  | } | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | RouteEngine::RouteEngine() { |  |  |  | RouteEngine::RouteEngine() { | 
			
		
	
		
		
			
				
					
					|  |  |  |   sm = new SubMaster({"liveLocationKalman"}); |  |  |  |   sm = new SubMaster({"liveLocationKalman", "managerState"}); | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |   pm = new PubMaster({"navInstruction", "navRoute"}); |  |  |  |   pm = new PubMaster({"navInstruction", "navRoute"}); | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |   // Timers
 |  |  |  |   // Timers
 | 
			
		
	
	
		
		
			
				
					|  |  | @ -130,6 +130,18 @@ void RouteEngine::timerUpdate() { | 
			
		
	
		
		
			
				
					
					|  |  |  |     return; |  |  |  |     return; | 
			
		
	
		
		
			
				
					
					|  |  |  |   } |  |  |  |   } | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |   if (sm->updated("managerState")) { | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     for (auto const &p : (*sm)["managerState"].getManagerState().getProcesses()) { | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |       if (p.getName() == "ui" && p.getRunning()) { | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |         if (ui_pid && *ui_pid != p.getPid()){ | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |           qWarning() << "UI restarting, sending route"; | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |           QTimer::singleShot(5000, this, &RouteEngine::sendRoute); | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |         } | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |         ui_pid = p.getPid(); | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |       } | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     } | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |   } | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |   auto location = (*sm)["liveLocationKalman"].getLiveLocationKalman(); |  |  |  |   auto location = (*sm)["liveLocationKalman"].getLiveLocationKalman(); | 
			
		
	
		
		
			
				
					
					|  |  |  |   auto pos = location.getPositionGeodetic(); |  |  |  |   auto pos = location.getPositionGeodetic(); | 
			
		
	
		
		
			
				
					
					|  |  |  |   auto orientation = location.getCalibratedOrientationNED(); |  |  |  |   auto orientation = location.getCalibratedOrientationNED(); | 
			
		
	
	
		
		
			
				
					|  |  | @ -216,6 +228,7 @@ void RouteEngine::timerUpdate() { | 
			
		
	
		
		
			
				
					
					|  |  |  | } |  |  |  | } | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | void RouteEngine::clearRoute() { |  |  |  | void RouteEngine::clearRoute() { | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |   route = QGeoRoute(); | 
			
		
	
		
		
			
				
					
					|  |  |  |   segment = QGeoRouteSegment(); |  |  |  |   segment = QGeoRouteSegment(); | 
			
		
	
		
		
			
				
					
					|  |  |  |   nav_destination = QMapbox::Coordinate(); |  |  |  |   nav_destination = QMapbox::Coordinate(); | 
			
		
	
		
		
			
				
					
					|  |  |  | } |  |  |  | } | 
			
		
	
	
		
		
			
				
					|  |  | @ -289,16 +302,28 @@ void RouteEngine::calculateRoute(QMapbox::Coordinate destination) { | 
			
		
	
		
		
			
				
					
					|  |  |  | } |  |  |  | } | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | void RouteEngine::routeCalculated(QGeoRouteReply *reply) { |  |  |  | void RouteEngine::routeCalculated(QGeoRouteReply *reply) { | 
			
		
	
		
		
			
				
					
					|  |  |  |   MessageBuilder msg; |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |   cereal::Event::Builder evt = msg.initEvent(); |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |   cereal::NavRoute::Builder nav_route = evt.initNavRoute(); |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |   if (reply->error() == QGeoRouteReply::NoError) { |  |  |  |   if (reply->error() == QGeoRouteReply::NoError) { | 
			
		
	
		
		
			
				
					
					|  |  |  |     if (reply->routes().size() != 0) { |  |  |  |     if (reply->routes().size() != 0) { | 
			
		
	
		
		
			
				
					
					|  |  |  |       qWarning() << "Got route response"; |  |  |  |       qWarning() << "Got route response"; | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |       route = reply->routes().at(0); |  |  |  |       route = reply->routes().at(0); | 
			
		
	
		
		
			
				
					
					|  |  |  |       segment = route.firstRouteSegment(); |  |  |  |       segment = route.firstRouteSegment(); | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     } else { | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |       qWarning() << "Got empty route response"; | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     } | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |   } else { | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     qWarning() << "Got error in route reply" << reply->errorString(); | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |   } | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |   sendRoute(); | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |   reply->deleteLater(); | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | } | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | void RouteEngine::sendRoute() { | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |   MessageBuilder msg; | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |   cereal::Event::Builder evt = msg.initEvent(); | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |   cereal::NavRoute::Builder nav_route = evt.initNavRoute(); | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |   auto path = route.path(); |  |  |  |   auto path = route.path(); | 
			
		
	
		
		
			
				
					
					|  |  |  |   auto coordinates = nav_route.initCoordinates(path.size()); |  |  |  |   auto coordinates = nav_route.initCoordinates(path.size()); | 
			
		
	
	
		
		
			
				
					|  |  | @ -310,14 +335,5 @@ void RouteEngine::routeCalculated(QGeoRouteReply *reply) { | 
			
		
	
		
		
			
				
					
					|  |  |  |     i++; |  |  |  |     i++; | 
			
		
	
		
		
			
				
					
					|  |  |  |   } |  |  |  |   } | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     } else { |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |       qWarning() << "Got empty route response"; |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |     } |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |   } else { |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |     qWarning() << "Got error in route reply" << reply->errorString(); |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |   } |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |   pm->send("navRoute", msg); |  |  |  |   pm->send("navRoute", msg); | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |   reply->deleteLater(); |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  | } |  |  |  | } | 
			
		
	
	
		
		
			
				
					|  |  | 
 |