mirror of
https://github.com/sunnypilot/sunnypilot.git
synced 2026-02-19 14:43:57 +08:00
# Conflicts: # .github/workflows/release.yaml # README.md # RELEASES.md # common/params_keys.h # docs/CARS.md # opendbc_repo # panda # release/build_stripped.sh # selfdrive/controls/lib/longitudinal_planner.py # selfdrive/modeld/modeld.py # selfdrive/ui/feedback/feedbackd.py # selfdrive/ui/translations/main_ar.ts # selfdrive/ui/translations/main_de.ts # selfdrive/ui/translations/main_es.ts # selfdrive/ui/translations/main_fr.ts # selfdrive/ui/translations/main_ja.ts # selfdrive/ui/translations/main_ko.ts # selfdrive/ui/translations/main_pt-BR.ts # selfdrive/ui/translations/main_th.ts # selfdrive/ui/translations/main_tr.ts # selfdrive/ui/translations/main_zh-CHS.ts # selfdrive/ui/translations/main_zh-CHT.ts # system/version.py # uv.lock
52 lines
2.0 KiB
Python
52 lines
2.0 KiB
Python
"""
|
|
Copyright (c) 2021-, Haibin Wen, sunnypilot, and a number of other contributors.
|
|
|
|
This file is part of sunnypilot and is licensed under the MIT License.
|
|
See the LICENSE.md file in the root directory for more details.
|
|
"""
|
|
import json
|
|
import platform
|
|
|
|
from openpilot.common.params import Params
|
|
from openpilot.sunnypilot.mapd.live_map_data.base_map_data import BaseMapData
|
|
from openpilot.sunnypilot.navd.helpers import Coordinate
|
|
|
|
|
|
class OsmMapData(BaseMapData):
|
|
def __init__(self):
|
|
super().__init__()
|
|
self.params = Params()
|
|
self.mem_params = Params("/dev/shm/params") if platform.system() != "Darwin" else self.params
|
|
|
|
def update_location(self) -> None:
|
|
if self.last_position is None or self.last_altitude is None:
|
|
return
|
|
|
|
params = {
|
|
"latitude": self.last_position.latitude,
|
|
"longitude": self.last_position.longitude,
|
|
"altitude": self.last_altitude,
|
|
}
|
|
|
|
self.mem_params.put("LastGPSPosition", json.dumps(params))
|
|
|
|
def get_current_speed_limit(self) -> float:
|
|
return float(self.mem_params.get("MapSpeedLimit") or 0.0)
|
|
|
|
def get_current_road_name(self) -> str:
|
|
return str(self.mem_params.get("RoadName") or "")
|
|
|
|
def get_next_speed_limit_and_distance(self) -> tuple[float, float]:
|
|
next_speed_limit_section_str = self.mem_params.get("NextMapSpeedLimit")
|
|
next_speed_limit_section = next_speed_limit_section_str if next_speed_limit_section_str else {}
|
|
next_speed_limit = next_speed_limit_section.get('speedlimit', 0.0)
|
|
next_speed_limit_latitude = next_speed_limit_section.get('latitude')
|
|
next_speed_limit_longitude = next_speed_limit_section.get('longitude')
|
|
next_speed_limit_distance = 0.0
|
|
|
|
if next_speed_limit_latitude and next_speed_limit_longitude:
|
|
next_speed_limit_coordinates = Coordinate(next_speed_limit_latitude, next_speed_limit_longitude)
|
|
next_speed_limit_distance = (self.last_position or Coordinate(0, 0)).distance_to(next_speed_limit_coordinates)
|
|
|
|
return next_speed_limit, next_speed_limit_distance
|