Skip to content

Commit

Permalink
Merge pull request #3 from shotwn/XPlane
Browse files Browse the repository at this point in the history
X Plane Support
  • Loading branch information
shotwn authored Apr 5, 2020
2 parents d77ceec + dc5443d commit 89f298e
Show file tree
Hide file tree
Showing 3 changed files with 52 additions and 19 deletions.
2 changes: 1 addition & 1 deletion _version.py
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
version = "0.1.3-alpha"
version = "0.1.4-alpha"

if __name__ == "__main__":
print(version)
2 changes: 2 additions & 0 deletions gui/gui.py
Original file line number Diff line number Diff line change
Expand Up @@ -54,6 +54,8 @@ def __init__(self, root):
}
""")
self.tray_actions = {}
self.tray_actions["sync_now"] = menu.addAction("Sync Now")
self.tray_actions["sync_now"].triggered.connect(lambda: self.root.sync_sim(force=True))
self.tray_actions["hide_show"] = menu.addAction("Hide")
self.tray_actions["hide_show"].triggered.connect(self.hide)
self.tray_actions["exit"] = menu.addAction("Exit")
Expand Down
67 changes: 49 additions & 18 deletions main.py
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
import sys
import time
import socket
from datetime import datetime, timezone
from datetime import datetime, timezone, timedelta
import ntplib
import threading
import pyuipc
Expand Down Expand Up @@ -36,6 +36,10 @@
"Prepar3D v4"
]

SIMULATOR_XPLANE_ID = 100
SIMULATOR_XPLANE = "X Plane"
SIMULATOR_XPLANE_YEAR_DELTA = 7


class OffsetSet:
def __init__(self, offsets):
Expand Down Expand Up @@ -86,13 +90,21 @@ def connect_pyuipc(self):
print(exc)
return None

sim_offset = self.create_offset_set({'SIM_VERSION': [0x3308, 'b']})
sim_offset = self.create_offset_set({
'SIM_VERSION': [0x3308, 'b'],
'IS_XPLANE': [0x6FFF, 'b']
})
result = sim_offset.read()
self.pyuipc_open = result['SIM_VERSION']
try:
self.opened_sim = SIMULATORS[self.pyuipc_open]
except IndexError:
self.opened_sim = f'Unknown Sim: {self.pyuipc_open}'

if result['IS_XPLANE']:
self.pyuipc_open = SIMULATOR_XPLANE_ID
self.opened_sim = SIMULATOR_XPLANE
else:
self.pyuipc_open = result['SIM_VERSION']
try:
self.opened_sim = SIMULATORS[self.pyuipc_open]
except IndexError:
self.opened_sim = f'Unknown Sim: {self.pyuipc_open}'

return True

Expand Down Expand Up @@ -242,8 +254,12 @@ def sync_thread_runner(self, restart=0):
"TIME_MINUTE": [0x023C, "b"],
"DATE_DAY": [0x023D, "b"],
"DATE_MONTH": [0x0242, "b"],
"DATE_YEAR": [0x024A, "H"],
"DATE_YEAR": [0x0240, "H"], # Fixed from local
}

if self.fs_sync.pyuipc_open == SIMULATOR_XPLANE_ID:
offsets["DAY_OF_YEAR"] = [0x023E, "h"]

self.time_offsets = self.fs_sync.create_offset_set(offsets)

try:
Expand All @@ -262,12 +278,13 @@ def sync_routine_loop(self):

data = data_delta[0]
delta = data_delta[1]
datetime = data_delta[2]

self.mw_emit([self.gui.main_window.ui.sim_time_hour.setText, "{:02d}".format(data["TIME_HOUR"])])
self.mw_emit([self.gui.main_window.ui.sim_time_seperator.setText, str(two_dots)])
self.mw_emit([self.gui.main_window.ui.sim_time_minute.setText, "{:02d}".format(data["TIME_MINUTE"])])
self.mw_emit([self.gui.main_window.ui.sim_time_second.setText, "{:02d}".format(data["TIME_SECOND"])])
self.mw_emit([self.gui.main_window.ui.sim_date.setText, "{:02d}.{:02d}.{}".format(data["DATE_DAY"], data["DATE_MONTH"], data["DATE_YEAR"])])
self.mw_emit([self.gui.main_window.ui.sim_date.setText, datetime.strftime('%d.%m.%Y')])
self.mw_emit([self.gui.main_window.ui.sim_time_second.setToolTip, "ε: ±{}s Δ: {}s".format(30, int(delta))])
# print(data)

Expand All @@ -278,11 +295,19 @@ def sync_sim(self, force=False):
Returns initial data if no sync.
Returns new data if there has been sync.
"""
if not self.fs_sync.pyuipc_open:
return

try:
data = self.time_offsets.read()
if self.fs_sync.pyuipc_open == SIMULATOR_XPLANE_ID:
data["DATE_YEAR"] += SIMULATOR_XPLANE_YEAR_DELTA
time_from_data = datetime(data["DATE_YEAR"], 1, 1, data["TIME_HOUR"], data["TIME_MINUTE"], second=data["TIME_SECOND"])
time_from_data = time_from_data + timedelta(days=data["DAY_OF_YEAR"])
else:
time_from_data = datetime(data["DATE_YEAR"], data["DATE_MONTH"], data["DATE_DAY"], data["TIME_HOUR"], data["TIME_MINUTE"], second=data["TIME_SECOND"])

now = self.offset + self.get_now()
time_from_data = datetime(data["DATE_YEAR"], data["DATE_MONTH"], data["DATE_DAY"], data["TIME_HOUR"], data["TIME_MINUTE"], second=data["TIME_SECOND"])
delta = (now - time_from_data).total_seconds()
except ValueError as exc:
# ValueError generally thrown when FSUIPC is reporting year out of range.
Expand All @@ -302,23 +327,29 @@ def sync_sim(self, force=False):
else:
if now.second > 3:
self.gui.add_message(0, 1, "Will Sync At: {:02d}:{:02d}z".format(now.hour, now.minute + 1))
return [data, delta]
return [data, delta, time_from_data]

self.time_offsets.write("TIME_SECOND", 0)

print("DOING A ZULU TIME SYNC.")

self.time_offsets.write("DATE_YEAR", now.year)
self.time_offsets.write("DATE_MONTH", now.month)
self.time_offsets.write("DATE_DAY", now.day)
self.time_offsets.write("TIME_HOUR", now.hour)
self.time_offsets.write("TIME_MINUTE", now.minute)
if self.fs_sync.pyuipc_open == SIMULATOR_XPLANE_ID:
self.time_offsets.write("DATE_YEAR", now.year - SIMULATOR_XPLANE_YEAR_DELTA)
self.time_offsets.write("DAY_OF_YEAR", int(now.strftime('%j')) - 1)
self.time_offsets.write("TIME_HOUR", now.hour)
self.time_offsets.write("TIME_MINUTE", now.minute)
else:
self.time_offsets.write("DATE_YEAR", now.year)
self.time_offsets.write("DATE_MONTH", now.month)
self.time_offsets.write("DATE_DAY", now.day)
self.time_offsets.write("TIME_HOUR", now.hour)
self.time_offsets.write("TIME_MINUTE", now.minute)

self.gui.remove_message(0, 1) # Remove will sync message
self.gui.add_message(0, 2, "Last Sync: {:02d}:{:02d}:{:02d}z".format(now.hour, now.minute, now.second))
return [self.time_offsets.read(), delta] # Return fresh data
return [self.time_offsets.read(), delta, time_from_data] # Return fresh data

return [data, delta]
return [data, delta, time_from_data]


if __name__ == "__main__":
Expand Down

0 comments on commit 89f298e

Please sign in to comment.