Thermometer? You bet!
This commit is contained in:
parent
cec20b55bd
commit
aaaef5e7da
3 changed files with 77 additions and 5 deletions
|
@ -9,6 +9,7 @@ from hexagram.dial import Dial
|
|||
from hexagram.speedo import Speedo
|
||||
from hexagram.tacho import Tacho
|
||||
from hexagram.fuel import FuelGauge
|
||||
from hexagram.thermo import ThermoGauge
|
||||
|
||||
class ShiftIndicator(Gauge):
|
||||
__slots__ = 'x', 'y', 'rpm_redline', 'rpm_max',
|
||||
|
@ -65,7 +66,7 @@ class Cluster():
|
|||
SHIFT_INDICATOR_X = 392
|
||||
SHIFT_INDICATOR_Y = 24
|
||||
|
||||
__slots__ = 'gauges', 'speedo', 'tacho', 'fuel',
|
||||
__slots__ = 'gauges', 'speedo', 'fuel', 'tacho', 'thermo',
|
||||
|
||||
def __init__(self, rpm_redline: float, rpm_max: float):
|
||||
self.gauges: List[Gauge] = list()
|
||||
|
@ -75,18 +76,23 @@ class Cluster():
|
|||
self.HEIGHT / 2,
|
||||
200.0)
|
||||
|
||||
self.fuel = FuelGauge(self.HEIGHT / 2,
|
||||
self.HEIGHT / 2,
|
||||
self.HEIGHT / 2)
|
||||
|
||||
self.tacho = Tacho(self.WIDTH - self.HEIGHT / 2,
|
||||
self.HEIGHT / 2,
|
||||
self.HEIGHT / 2,
|
||||
8000)
|
||||
|
||||
self.fuel = FuelGauge(self.HEIGHT / 2,
|
||||
self.thermo = ThermoGauge(self.WIDTH - self.HEIGHT / 2,
|
||||
self.HEIGHT / 2,
|
||||
self.HEIGHT / 2)
|
||||
|
||||
self.gauges.append(self.speedo)
|
||||
self.gauges.append(self.fuel)
|
||||
self.gauges.append(self.tacho)
|
||||
self.gauges.append(self.thermo)
|
||||
|
||||
self.gauges.append(ShiftIndicator(self.SHIFT_INDICATOR_X,
|
||||
self.SHIFT_INDICATOR_Y,
|
||||
|
|
|
@ -53,9 +53,12 @@ class FuelGauge(Dial):
|
|||
cr.set_line_width(6.0)
|
||||
|
||||
for level in range(0, self.MAX_VALUE+1):
|
||||
if level < 4:
|
||||
if level < 2:
|
||||
min_radius = 0.84
|
||||
cr.set_source_rgb(1, 0, 0)
|
||||
elif level < 4:
|
||||
min_radius = 0.82
|
||||
cr.set_source_rgb(1, 0, 0)
|
||||
else:
|
||||
min_radius = 0.82
|
||||
cr.set_source_rgb(1, 1, 1)
|
||||
|
|
63
py/hexagram/thermo.py
Normal file
63
py/hexagram/thermo.py
Normal file
|
@ -0,0 +1,63 @@
|
|||
import enum
|
||||
import math
|
||||
import cairo
|
||||
|
||||
from hexagram.dial import Dial
|
||||
|
||||
class ThermoGauge(Dial):
|
||||
MIN_ANGLE = 144.0 * (math.pi / 180.0)
|
||||
MAX_ANGLE = 216.0 * (math.pi / 180.0)
|
||||
|
||||
MIN_VALUE = 85
|
||||
MAX_VALUE = 110
|
||||
WARN_VALUE = 106
|
||||
|
||||
FONT_FACE = "Muli"
|
||||
|
||||
def __init__(self, x: float, y: float, radius: float):
|
||||
super().__init__(x, y, radius, self.MIN_ANGLE, self.MAX_ANGLE, self.MAX_VALUE - self.MIN_VALUE)
|
||||
|
||||
def draw_value(self, cr: cairo.Context, radius: float, value: float, text: str, x_offset: float, y_offset: float):
|
||||
scale = (self.max_value - value) / self.max_value
|
||||
angle = self.min_angle + ((self.max_angle - self.min_angle) * scale) - self.ANGLE_OFFSET
|
||||
|
||||
cr.move_to(self.x + radius * self.radius * math.cos(angle) + x_offset,
|
||||
self.y + radius * self.radius * math.sin(angle) + y_offset)
|
||||
|
||||
cr.show_text(text)
|
||||
cr.stroke()
|
||||
|
||||
def draw_mark(self, cr: cairo.Context, min_radius: float, max_radius: float, value: float):
|
||||
angle = self.min_angle + \
|
||||
((self.max_angle - self.min_angle) * (value / self.max_value)) - self.ANGLE_OFFSET
|
||||
|
||||
cr.move_to(self.x + (min_radius * self.radius) * math.cos(angle),
|
||||
self.y + (min_radius * self.radius) * math.sin(angle))
|
||||
|
||||
cr.line_to(self.x + (max_radius * self.radius) * math.cos(angle),
|
||||
self.y + (max_radius * self.radius) * math.sin(angle))
|
||||
|
||||
cr.stroke()
|
||||
|
||||
def draw_bg(self, cr: cairo.Context):
|
||||
cr.select_font_face(self.FONT_FACE,
|
||||
cairo.FontSlant.NORMAL,
|
||||
cairo.FontWeight.BOLD)
|
||||
|
||||
cr.set_font_size(self.radius * 0.1)
|
||||
|
||||
cr.set_source_rgb(1, 1, 1)
|
||||
self.draw_value(cr, 0.78, 0, "C", 0, 5)
|
||||
|
||||
cr.set_source_rgb(1, 0, 0)
|
||||
self.draw_value(cr, 0.75, self.MAX_VALUE - self.MIN_VALUE, "H", -5, 5)
|
||||
|
||||
cr.set_line_width(6.0)
|
||||
|
||||
for level in range(0, self.MAX_VALUE - self.MIN_VALUE, math.ceil((self.MAX_VALUE - self.MIN_VALUE) / 9)):
|
||||
if level + self.MIN_VALUE >= self.WARN_VALUE:
|
||||
cr.set_source_rgb(0.8, 0, 0)
|
||||
else:
|
||||
cr.set_source_rgb(1, 1, 1)
|
||||
|
||||
self.draw_mark(cr, 0.83, 0.87, self.max_value - level)
|
Loading…
Add table
Reference in a new issue