summaryrefslogtreecommitdiff
path: root/src/display.h
diff options
context:
space:
mode:
Diffstat (limited to 'src/display.h')
-rw-r--r--src/display.h71
1 files changed, 71 insertions, 0 deletions
diff --git a/src/display.h b/src/display.h
index abea377..c7cf5f8 100644
--- a/src/display.h
+++ b/src/display.h
@@ -9,17 +9,54 @@ enum class AnimationType : uint8_t {
FRAMES = 2
};
+/**
+ * Generic struct for anything which can be displayed, e.g. texts or
+ * sequences of frames.
+ */
struct animation {
+ /**
+ * Specific kind of animation described in this struct. Controls the
+ * behaviour of Display::multiplex() and Display::update().
+ */
AnimationType mode;
+
+ /**
+ * Length of data in bytes
+ */
uint8_t length;
+
+ /**
+ * * If mode == TEXT: Text scroll speed in columns per TODO
+ * * If mode == FRAMES: Frames per TODO
+ */
uint8_t speed;
+
+ /**
+ * Delay after the last text symbol / animation frame. Not yet supported.
+ */
uint8_t delay;
+
+ /**
+ * Scroll mode / direction. Not yet supported.
+ */
uint8_t direction;
+
+ /**
+ * * If mode == TEXT: character array pointing to the
+ * animation text in standard ASCII format (+ special font chars)
+ * * If mode == FRAMES: Frame array. Each element encodes
+ * a display column (starting with the leftmost one), each group of
+ * eight elements is a frame.
+ */
uint8_t *data;
};
typedef struct animation animation_t;
+/**
+ * Controls the display. Handles multiplexing, scrolling and supports loading
+ * arbitrary animations.
+ */
class Display {
private:
animation_t *active_anim;
@@ -31,13 +68,47 @@ class Display {
public:
Display();
+ /**
+ * Enable the display driver.
+ * Configures ports B and D as output and enables the display
+ * timer and interrupt.
+ */
void enable(void);
+
+ /**
+ * Disable the display driver.
+ * Turns off both the display itself and the display timer.
+ */
void disable(void);
+ /**
+ * Draws a single display column. Called every 256 microseconds
+ * by the timer interrupt (TIMER0_OVF_vect), resulting in
+ * a display refresh rate of ~500Hz (one refresh per 2048µs)
+ */
void multiplex(void);
+
+ /**
+ * Reset display and animation state. Fills the screen with "black"
+ * (that is, no active pixels) and sets the animation offset to zero.
+ */
void reset(void);
+
+ /**
+ * Update display content.
+ * Checks active_anim->speed and active_anim->type and scrolls
+ * the text / advances a frame when appropriate. Does nothing
+ * otherwise.
+ */
void update(void);
+ /**
+ * Set the active animation to be shown on the display. Automatically
+ * calls reset().
+ *
+ * @param anim active animation. Note that the data is not copied,
+ * so anim has to be kept in memory until a new one is loaded
+ */
void show(animation_t *anim);
};