OBP60v/pages/autobahn.py

103 lines
2.9 KiB
Python

"""
3D-View angelehnt an die NASA Clipper GPS-Darstellung
"""
import os
import cairo
import math
from .page import Page
class Autobahn(Page):
def __init__(self, pageno, cfg, boatdata):
super().__init__(pageno, cfg, boatdata)
self.xte = self.bd.getRef("XTE")
self.cog = self.bd.getRef("COG")
self.btw = self.bd.getRef("BTW")
self.dtw = self.bd.getRef("DTW")
self.wpname = "no data"
self.symbol = cairo.ImageSurface.create_from_png(os.path.join(cfg['imgpath'], "ship.png"))
def draw(self, ctx):
# Beschriftung unter den Werten
ctx.select_font_face("Ubuntu", cairo.FontSlant.NORMAL, cairo.FontWeight.BOLD)
ctx.set_font_size(16)
ctx.move_to(50, 188);
ctx.show_text("Cross-track error")
ctx.move_to(270, 188)
ctx.show_text("Track")
ctx.move_to(45, 275);
ctx.show_text("Distance to waypoint")
ctx.move_to(260, 275);
ctx.show_text("Bearing")
ctx.stroke()
# Meßwerte
ctx.select_font_face("DSEG7 Classic")
ctx.set_font_size(60)
ctx.move_to(40, 170)
#ctx.show_text(self.xte.format())
ctx.show_text("2.3")
ctx.move_to(220, 170)
#ctx.show_text(self.cog.format())
ctx.show_text("253")
ctx.move_to(40, 257)
#ctx.show_text(self.dtw.format())
ctx.show_text("5.8")
ctx.move_to(220, 257)
#ctx.show_text(self.btw.format())
ctx.show_text("248")
# 3D-Ansicht oben
# TODO Schiffssymbol
ctx.save()
ctx.set_source_surface(self.symbol, 186, 68)
ctx.paint()
ctx.restore()
# Segmente: 2 1 0 3 4 5
seg = [True] * 6
points = {
2: ((0, 54), (46, 24), (75, 24), (0, 90)),
1: ((0, 100), (82, 24), (112, 24), (50, 100)),
0: ((60, 100), (117, 24), (147, 24), (110, 100)),
3: ((340, 100), (283, 24), (253, 24), (290, 100)),
4: ((399, 100), (318, 24), (289, 24), (350, 100)),
5: ((399, 54), (354, 24), (325, 24), (399, 90))
}
# Winkeldifferenz
diff = (self.cog.value or 0) - (self.btw.value or 0)
if diff < -180:
diff += 360
elif diff > 180:
diff -= 360
if diff > 0:
order = (3, 4, 5, 0, 1, 2)
else:
order = (0, 1, 2, 3, 4, 5)
# Anzahl aktiver Segmente
seg_step = math.radians(3)
nseg = min(abs(diff) / seg_step, 5)
i = 0
while nseg > 0:
seg[order[i]] = False
i += 1
nseg -= 1
# Segmente zeichnen
for p in range(6):
ctx.move_to(*points[p][0])
ctx.line_to(*points[p][1])
ctx.line_to(*points[p][2])
ctx.line_to(*points[p][3])
if seg[p]:
ctx.fill()
else:
ctx.stroke()