2021-06-09 16:11:48 +00:00
|
|
|
# label.py Extension to micro-gui providing the Label class
|
|
|
|
|
|
|
|
# Released under the MIT License (MIT). See LICENSE.
|
|
|
|
# Copyright (c) 2021 Peter Hinch
|
|
|
|
from gui.core.ugui import Widget, display
|
|
|
|
from gui.core.writer import Writer
|
|
|
|
from gui.core.colors import *
|
|
|
|
|
|
|
|
# text: str display string int save width
|
|
|
|
class Label(Widget):
|
|
|
|
def __init__(self, writer, row, col, text, invert=False, fgcolor=None, bgcolor=BLACK, bdcolor=False):
|
2021-06-24 08:58:57 +00:00
|
|
|
self.writer = writer
|
2021-06-09 16:11:48 +00:00
|
|
|
# Determine width of object
|
|
|
|
if isinstance(text, int):
|
|
|
|
width = text
|
|
|
|
text = None
|
|
|
|
else:
|
|
|
|
width = writer.stringlen(text)
|
|
|
|
height = writer.height
|
|
|
|
self.invert = invert
|
|
|
|
super().__init__(writer, row, col, height, width, fgcolor, bgcolor, bdcolor)
|
|
|
|
if text is not None:
|
|
|
|
self.value(text, invert)
|
|
|
|
|
|
|
|
def value(self, text=None, invert=False, fgcolor=None, bgcolor=None, bdcolor=None):
|
2021-06-24 08:58:57 +00:00
|
|
|
if self.writer.stringlen(text) > self.width:
|
|
|
|
raise ValueError('Label.value() string is too long.')
|
2021-06-09 16:11:48 +00:00
|
|
|
txt = super().value(text) # Sets .draw ensuring refresh
|
|
|
|
# Redraw even if no text supplied: colors may have changed.
|
|
|
|
self.invert = invert
|
|
|
|
self.fgcolor = self.def_fgcolor if fgcolor is None else fgcolor
|
|
|
|
self.bgcolor = self.def_bgcolor if bgcolor is None else bgcolor
|
|
|
|
if bdcolor is False:
|
|
|
|
self.def_bdcolor = False
|
|
|
|
self.bdcolor = self.def_bdcolor if bdcolor is None else bdcolor
|
|
|
|
return txt
|
|
|
|
|
|
|
|
def show(self):
|
|
|
|
if super().show(): # Draw or erase border
|
|
|
|
if isinstance(txt := super().value(), str):
|
|
|
|
display.print_left(self.writer, self.col, self.row, txt, self.fgcolor, self.bgcolor, self.invert)
|