mirror of
https://github.com/OSURoboticsClub/Rover_2017_2018.git
synced 2025-11-08 10:11:14 +00:00
Supposed nav list buttons working
This commit is contained in:
@@ -10,6 +10,8 @@ class WaypointsCoordinator(QtCore.QThread):
|
|||||||
def __init__(self, shared_objects):
|
def __init__(self, shared_objects):
|
||||||
super(WaypointsCoordinator, self).__init__()
|
super(WaypointsCoordinator, self).__init__()
|
||||||
self.run_thread_flag = True
|
self.run_thread_flag = True
|
||||||
|
self.navigation_table_cur_click = None
|
||||||
|
self.landmark_table_cur_click = None
|
||||||
|
|
||||||
self.shared_objects = shared_objects
|
self.shared_objects = shared_objects
|
||||||
self.left_screen = self.shared_objects["screens"]["left_screen"]
|
self.left_screen = self.shared_objects["screens"]["left_screen"]
|
||||||
@@ -26,14 +28,14 @@ class WaypointsCoordinator(QtCore.QThread):
|
|||||||
manual_waypoint_decimal_longitude_spin_box)
|
manual_waypoint_decimal_longitude_spin_box)
|
||||||
|
|
||||||
# Nav Table Buttons
|
# Nav Table Buttons
|
||||||
self.nav_set_label = (self.left_screen.
|
self.nav_set_button_label = (self.left_screen.
|
||||||
navigation_waypoints_set_button)
|
navigation_waypoints_set_button)
|
||||||
self.nav_add_manual_label = (self.left_screen.
|
self.nav_add_manual_button_label = (
|
||||||
navigation_waypoints_add_manual_button)
|
self.left_screen.navigation_waypoints_add_manual_button)
|
||||||
self.nav_add_gps_label = (self.left_screen.
|
self.nav_add_gps_button_label = (self.left_screen.
|
||||||
navigation_waypoints_add_gps_button)
|
navigation_waypoints_add_gps_button)
|
||||||
self.nav_delete_label = (self.left_screen.
|
self.nav_delete_button_label = (self.left_screen.
|
||||||
navigation_waypoints_delete_button)
|
navigation_waypoints_delete_button)
|
||||||
|
|
||||||
self.settings = QtCore.QSettings()
|
self.settings = QtCore.QSettings()
|
||||||
|
|
||||||
@@ -47,7 +49,10 @@ class WaypointsCoordinator(QtCore.QThread):
|
|||||||
self.new_manual_waypoint_entry.connect(self.update_manual_entry)
|
self.new_manual_waypoint_entry.connect(self.update_manual_entry)
|
||||||
|
|
||||||
# setting up signals to save for Navigation Table
|
# setting up signals to save for Navigation Table
|
||||||
self.nav_add_gps_label.clicked.connect(self._nav_add_gps)
|
self.nav_add_gps_button_label.clicked.connect(self._nav_add_gps)
|
||||||
|
self.nav_delete_button_label.clicked.connect(self._nav_del)
|
||||||
|
self.nav_add_manual_button_label.clicked.connect(self._nav_add_manual)
|
||||||
|
self.nav_set_button_label.clicked.connect(self._nav_save)
|
||||||
|
|
||||||
self.navigation_label.cellClicked.connect(self._on_nav_clicked)
|
self.navigation_label.cellClicked.connect(self._on_nav_clicked)
|
||||||
self.landmark_label.cellClicked.connect(self._on_land_clicked)
|
self.landmark_label.cellClicked.connect(self._on_land_clicked)
|
||||||
@@ -56,9 +61,14 @@ class WaypointsCoordinator(QtCore.QThread):
|
|||||||
count = table.rowCount()
|
count = table.rowCount()
|
||||||
table.insertRow(count)
|
table.insertRow(count)
|
||||||
table.setItem(count, 0, QtWidgets.QTableWidgetItem(name))
|
table.setItem(count, 0, QtWidgets.QTableWidgetItem(name))
|
||||||
table.setItem(count, 1, QtWidgets.QTableWidgetItem(str(lat)))
|
table.setItem(count, 1, QtWidgets.QTableWidgetItem(lat))
|
||||||
table.setItem(count, 2, QtWidgets.QTableWidgetItem(str(lng)))
|
table.setItem(count, 2, QtWidgets.QTableWidgetItem(lng))
|
||||||
table.setItem(count, 3, QtWidgets.QTableWidgetItem(str(dist)))
|
table.setItem(count, 3, QtWidgets.QTableWidgetItem(dist))
|
||||||
|
|
||||||
|
def _clear_inputs(self):
|
||||||
|
self.name_edit_label.clear()
|
||||||
|
self.latitude_label.clear()
|
||||||
|
self.longitude_label.clear()
|
||||||
|
|
||||||
def _nav_add_gps(self):
|
def _nav_add_gps(self):
|
||||||
# request GPS data
|
# request GPS data
|
||||||
@@ -66,7 +76,43 @@ class WaypointsCoordinator(QtCore.QThread):
|
|||||||
lat = 44.567200
|
lat = 44.567200
|
||||||
lng = -123.27860
|
lng = -123.27860
|
||||||
distance = 200
|
distance = 200
|
||||||
self._add_to_table(str(name), lat, lng, distance, self.navigation_label)
|
self._add_to_table(str(name), str(lat),
|
||||||
|
str(lng), str(distance),
|
||||||
|
self.navigation_label)
|
||||||
|
self._clear_inputs()
|
||||||
|
|
||||||
|
def _nav_save(self):
|
||||||
|
lat = self.latitude_label.getText()
|
||||||
|
lng = self.longitude_label.getText()
|
||||||
|
self.navigation_label.setItem(self.navigation_table_cur_click,
|
||||||
|
1,
|
||||||
|
QtWidgets.QTableWidgetItem(lat))
|
||||||
|
self.navigation_label.setItem(self.navigation_label,
|
||||||
|
2,
|
||||||
|
QtWidgets.QTableWidgetItem(lng))
|
||||||
|
self._clear_inputs()
|
||||||
|
|
||||||
|
def _nav_add_manual(self):
|
||||||
|
# request GPS data
|
||||||
|
name = self.navigation_label.rowCount()
|
||||||
|
lat = self.latitude_label.getText()
|
||||||
|
lng = self.longitude_label.getText()
|
||||||
|
distance = 200
|
||||||
|
self._add_to_table(str(name), lat,
|
||||||
|
lng, str(distance),
|
||||||
|
self.navigation_label)
|
||||||
|
self._clear_inputs
|
||||||
|
|
||||||
|
def _nav_del(self):
|
||||||
|
if self.navigation_table_cur_click is not None:
|
||||||
|
self.navigation_label.removeRow(self.navigation_table_cur_click)
|
||||||
|
count = self.navigation_label.rowCount()
|
||||||
|
for x in range(self.navigation_table_cur_click, count):
|
||||||
|
self.navigation_label.setItem(x,
|
||||||
|
0,
|
||||||
|
QtWidgets.
|
||||||
|
QTableWidgetItem(str(x)))
|
||||||
|
self._clear_inputs
|
||||||
|
|
||||||
def setup_signals(self, start_signal,
|
def setup_signals(self, start_signal,
|
||||||
signals_and_slots_signal, kill_signal):
|
signals_and_slots_signal, kill_signal):
|
||||||
@@ -78,13 +124,14 @@ class WaypointsCoordinator(QtCore.QThread):
|
|||||||
self.run_thread_flag = False
|
self.run_thread_flag = False
|
||||||
|
|
||||||
def update_manual_entry(self, name, lat, lng, table):
|
def update_manual_entry(self, name, lat, lng, table):
|
||||||
print name, lat, lng, table
|
|
||||||
self.name_edit_label.setEnabled(bool(table))
|
self.name_edit_label.setEnabled(bool(table))
|
||||||
self.name_edit_label.setText(name)
|
self.name_edit_label.setText(name)
|
||||||
self.latitude_label.setValue(lat)
|
self.latitude_label.setValue(lat)
|
||||||
self.longitude_label.setValue(lng)
|
self.longitude_label.setValue(lng)
|
||||||
|
|
||||||
def _on_nav_clicked(self, row, col):
|
def _on_nav_clicked(self, row, col):
|
||||||
|
self.navigation_table_cur_click = row
|
||||||
|
self.landmark_table_cur_click = None
|
||||||
self.new_manual_waypoint_entry.emit(
|
self.new_manual_waypoint_entry.emit(
|
||||||
self.navigation_label.item(row, 0).text(),
|
self.navigation_label.item(row, 0).text(),
|
||||||
float(self.navigation_label.item(row, 1).text()),
|
float(self.navigation_label.item(row, 1).text()),
|
||||||
@@ -93,6 +140,8 @@ class WaypointsCoordinator(QtCore.QThread):
|
|||||||
)
|
)
|
||||||
|
|
||||||
def _on_land_clicked(self, row, col):
|
def _on_land_clicked(self, row, col):
|
||||||
|
self.landmark_table_cur_click = row
|
||||||
|
self.navigation_table_cur_click = None
|
||||||
self.new_manual_waypoint_entry.emit(
|
self.new_manual_waypoint_entry.emit(
|
||||||
self.landmark_label.item(row, 0).text(),
|
self.landmark_label.item(row, 0).text(),
|
||||||
float(self.landmark_label.item(row, 1).text()),
|
float(self.landmark_label.item(row, 1).text()),
|
||||||
|
|||||||
Reference in New Issue
Block a user