-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathDimmer.h
106 lines (84 loc) · 2.55 KB
/
Dimmer.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
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
/**
* File: Dimmer.h
* Description:
* SoftTimer library is a lightweight but effective event based timeshare solution for Arduino.
*
* Author: Balazs Kelemen
* Contact: [email protected]
* Copyright: 2012 Balazs Kelemen
* Copying permission statement:
This file is part of SoftTimer.
SoftTimer 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.
This program 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 this program. If not, see <http://www.gnu.org/licenses/>.
*/
#ifndef DIMMER_H
#define DIMMER_H
#include "Task.h"
#include "SoftPwmTask.h"
#include "Arduino.h"
#define DIMMER_DIRECTION_HIGH 1
#define DIMMER_DIRECTION_LOW -1
#define DEFAULT_STEP_COUNT 8
class Dimmer : public Task
{
public:
/**
* We use the SoftPwmTask for dimming.
* pwm - The predefined SoftPwm task.
* frequencyMs - Milliseconds will be passed in the OFF->ON->OFF cicle.
*/
Dimmer(SoftPwmTask* pwm, int frequencyMs);
/**
* Start an unlimited pulsation from the current value on, in the current direction.
*/
void startPulsate();
/**
* Hold current PWM value on the output.
*/
void hold();
/**
* Stop PWM, and set output to LOW.
*/
void off();
/**
* Make the dimming to change direction.
*/
void revertDirection();
/**
* Milliseconds will be passed in the OFF->ON->OFF cicle.
*/
void setFrequency(int frequencyMs);
/**
* Get the upper level of the pwm.
*/
byte getUpperLimit();
/**
* Current dim level PWM value. Note that the maximum is pwm->upperLimit.
*/
float value;
/**
* Stop if zero, or pwm->upperLimit is reached.
*/
boolean stopOnLimit;
/**
* Can be one of DIMMER_DIRECTION_HIGH or DIMMER_DIRECTION_LOW.
*/
char direction;
/**
* Level-arranging steps should be performed within each full OFF->ON change. Will be applied if setFrequency() is called.
*/
byte stepCount;
private:
SoftPwmTask* _pwm;
float _stepLevel;
static void step(Task* me);
};
#endif