-
Notifications
You must be signed in to change notification settings - Fork 40
/
tlc_animations.h
88 lines (73 loc) · 3.29 KB
/
tlc_animations.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
/* Copyright (c) 2009 by Alex Leone <acleone ~AT~ gmail.com>
This file is part of the Arduino TLC5940 Library.
The Arduino TLC5940 Library is free software: you can redistribute it
and/or modify it under the terms of the GNU General Public License as
published by the Free Software Foundation, either version 3 of the
License, or (at your option) any later version.
The Arduino TLC5940 Library is distributed in the hope that it will be
useful, but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with The Arduino TLC5940 Library. If not, see
<http://www.gnu.org/licenses/>. */
#ifndef TLC_ANIMATIONS_H
#define TLC_ANIMATIONS_H
/** \file
TLC Animation functions. These play animations from PROGMEM. */
#include <avr/pgmspace.h>
#include <avr/io.h>
#include "tlc_config.h"
#include "Tlc5940.h"
#include "tlc_progmem_utils.h"
/** The currently playing animation */
const uint8_t *tlc_currentAnimation;
/** The number of frames in the current animation */
volatile uint16_t tlc_animationFrames;
/** The number of PWM periods to display each frame - 1 */
volatile uint16_t tlc_animationPeriodsPerFrame;
/** The current number of periods we've displayed this frame for */
volatile uint16_t tlc_animationPeriodsWait;
volatile void tlc_animationXLATCallback(void);
void tlc_playAnimation(const uint8_t /* PROGMEM */ *animation, uint16_t frames, uint16_t periodsPerFrame);
/** \addtogroup ExtendedFunctions
\code #include "tlc_animations.h" \endcode
- void tlc_playAnimation(const uint8_t PROGMEM *animation, uint16_t frames,
uint16_t periodsPerFrame) - plays an animation from progmem. */
/* @{ */
/** Plays an animation from progmem in the "background" (with interrupts).
\param animation A progmem array of grayscale data, length NUM_TLCS *
24 * frames, in reverse order. Ensure that there is not an update
waiting to happen before calling this.
\param frames the number of frames in animation
\param periodsPerFrame number of PWM periods to wait between each frame
(0 means play the animation as fast as possible).
The default PWM period for a 16MHz clock is 1.024ms. */
void tlc_playAnimation(const uint8_t /* PROGMEM */ *animation, uint16_t frames, uint16_t periodsPerFrame)
{
tlc_currentAnimation = animation;
tlc_animationFrames = frames;
tlc_animationPeriodsPerFrame = periodsPerFrame;
tlc_animationPeriodsWait = 0;
tlc_onUpdateFinished = tlc_animationXLATCallback;
tlc_animationXLATCallback();
}
/** This is called by the XLAT interrupt every PWM period to do stuff. */
volatile void tlc_animationXLATCallback(void)
{
if (tlc_animationPeriodsWait) {
tlc_animationPeriodsWait--;
set_XLAT_interrupt();
} else {
if (tlc_animationFrames) {
tlc_setGSfromProgmem(tlc_currentAnimation +
(--tlc_animationFrames * NUM_TLCS * 24));
tlc_animationPeriodsWait = tlc_animationPeriodsPerFrame;
Tlc.update();
} else { // animation is done
tlc_onUpdateFinished = 0;
}
}
}
/* @} */
#endif