-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathMeLightSensor.cpp
189 lines (173 loc) · 4.62 KB
/
MeLightSensor.cpp
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
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
/**
* \par Copyright (C), 2012-2016, MakeBlock
* \class MeLightSensor
* \brief Driver for Me-Light Sensor module.
* @file MeLightSensor.cpp
* @author MakeBlock
* @version V1.0.2
* @date 2015/11/09
* @brief Driver for Me-Light Sensor module.
*
* \par Copyright
* This software is Copyright (C), 2012-2016, MakeBlock. Use is subject to license \n
* conditions. The main licensing options available are GPL V2 or Commercial: \n
*
* \par Open Source Licensing GPL V2
* This is the appropriate option if you want to share the source code of your \n
* application with everyone you distribute it to, and you also want to give them \n
* the right to share who uses it. If you wish to use this software under Open \n
* Source Licensing, you must contribute all your source code to the open source \n
* community in accordance with the GPL Version 2 when your application is \n
* distributed. See http://www.gnu.org/copyleft/gpl.html
*
* \par Description
*
* \par Method List:
*
* 1. void MeLightSensor::setpin(uint8_t ledPin, uint8_t sensorPin)
* 2. int16_t MeLightSensor::read()
* 3. void MeLightSensor::lightOn()
* 4. void MeLightSensor::lightOff()
*
* \par History:
* <pre>
* `<Author>` `<Time>` `<Version>` `<Descr>`
* Mark Yan 2015/07/24 1.0.0 Rebuild the old lib.
* Rafael Lee 2015/09/02 1.0.1 Added function setpin and some comments.
* Mark Yan 2015/11/09 1.0.2 fix some comments error.
* </pre>
*
* @example MeLightSensorTestResetPort.ino \n
* @example MeLightSensorTest.ino \n
* @example MeLightSensorTestWithLEDon.ino
*/
/* Private define ------------------------------------------------------------*/
#include "MeLightSensor.h"
/* Private functions ---------------------------------------------------------*/
#ifdef ME_PORT_DEFINED
/**
* Alternate Constructor which can call your own function to map the light sensor to arduino port,
* no pins are used or initialized here.
* \param[in]
* None
*/
MeLightSensor::MeLightSensor(void) : MePort(0)
{
}
/**
* Alternate Constructor which can call your own function to map the light sensor to arduino port
* \param[in]
* port - RJ25 port from PORT_1 to M2
*/
MeLightSensor::MeLightSensor(uint8_t port) : MePort(port)
{
}
#else // ME_PORT_DEFINED
/**
* Alternate Constructor which can call your own function to map the light sensor to arduino port
* \param[in]
* ledPin - arduino port for led input
* \param[in]
* sensorPin - arduino port for sensor data read
*/
MeLightSensor::MeLightSensor(uint8_t ledPin, uint8_t sensorPin)
{
_ledPin = ledPin;
_sensorPin = sensorPin;
pinMode(_ledPin, OUTPUT);
pinMode(_sensorPin, INPUT);
digitalWrite(_ledPin,LOW);
}
#endif //ME_PORT_DEFINED
/**
* \par Function
* setpin
* \par Description
* Set I2C data pin, clock pin and clear display. \n
* dataPin - the DATA pin for Seven-Segment LED module. \n
* clkPin - the CLK pin for Seven-Segment LED module.
* \param[in]
* ledPin - Which pin on board that LEDpin is connecting to.
* \param[in]
* sensorPin - Which pin on board that sensorPin is connecting to.
* \par Output
* None
* \par Return
* None
* \par Others
* Set global variable _KeyPin and s2
*/
void MeLightSensor::setpin(uint8_t ledPin, uint8_t sensorPin)
{
_ledPin = ledPin;
_sensorPin = sensorPin;
pinMode(_ledPin, OUTPUT);
pinMode(_sensorPin, INPUT);
#ifdef ME_PORT_DEFINED
s1 = _ledPin;
s2 = _sensorPin;
#endif // ME_PORT_DEFINED
}
/**
* \par Function
* read
* \par Description
* Read analog value of light sensor.
* \param[in]
* None
* \par Output
* None
* \par Return
* MePort::aRead2() - DAC value of current light sensor's output.
* \par Others
*/
int16_t MeLightSensor::read(void)
{
#ifdef ME_PORT_DEFINED
return(MePort::aRead2());
#else //ME_PORT_DEFINED
return(analogRead(_sensorPin));
#endif //ME_PORT_DEFINED
}
/**
* \par Function
* lightOn
* \par Description
* Turn on the LED on the light sensor.
* \param[in]
* None
* \par Output
* None
* \par Return
* None
* \par Others
*/
void MeLightSensor::lightOn(void)
{
#ifdef ME_PORT_DEFINED
MePort::dWrite1(HIGH);
#else //ME_PORT_DEFINED
digitalWrite(_ledPin,HIGH);
#endif //ME_PORT_DEFINED
}
/**
* \par Function
* lightOff
* \par Description
* Turn off the LED on the light sensor.
* \param[in]
* None
* \par Output
* None
* \par Return
* None
* \par Others
*/
void MeLightSensor::lightOff(void)
{
#ifdef ME_PORT_DEFINED
MePort::dWrite1(LOW);
#else //ME_PORT_DEFINED
digitalWrite(_ledPin,LOW);
#endif //ME_PORT_DEFINED
}