-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathAtm_servo.cpp
executable file
·168 lines (148 loc) · 4.79 KB
/
Atm_servo.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
#include "Atm_servo.h"
/* Add optional parameters for the state machine to begin()
* Add extra initialization code
*/
Atm_servo& Atm_servo::begin( int pin, int pos ) {
// clang-format off
const static state_t state_table[] PROGMEM = {
/* ON_ENTER ON_LOOP ON_EXIT EVT_MVUP EVT_MVDN EVT_TIMER ELSE */
/* IDLE */ ENT_IDLE, -1, -1, UP, DOWN, -1, -1,
/* UP */ ENT_UP, -1, -1, -1, -1, UP_NEXT, -1,
/* UP_NEXT */ -1, -1, -1, UP, DOWN, -1, FINISHED,
/* DOWN */ ENT_DOWN, -1, -1, -1, -1, DOWN_NEXT, -1,
/* DOWN_NEXT */ -1, -1, -1, UP, DOWN, -1, FINISHED,
/* FINISHED */ ENT_FINISHED, -1, -1, -1, -1, -1, IDLE,
};
// clang-format on
Machine::begin( state_table, ELSE );
this->pin = pin;
servo.attach( pin );
servo_pos = pos;
servo_dest = pos;
step_size = 180;
timer.set( step_time = 0 );
servo.write( servo_dest );
return *this;
}
/* Add C++ code for each internally handled event (input)
* The code must return 1 to trigger the event
*/
int Atm_servo::event( int id ) {
switch ( id ) {
case EVT_MVUP:
return servo_dest > servo_pos;
case EVT_MVDN:
return servo_dest < servo_pos;
case EVT_TIMER:
return timer.expired( this );
}
return 0;
}
/* Add C++ code for each action
* This generates the 'output' for the state machine
*/
void Atm_servo::action( int id ) {
switch ( id ) {
case ENT_IDLE:
return;
case ENT_UP:
push( connectors, ON_CHANGE, true, servo_pos, 1 );
servo_pos += step_size;
if ( servo_pos > servo_dest ) servo_pos = servo_dest;
servo.write( servo_pos );
timer.set( step_time );
return;
case ENT_DOWN:
push( connectors, ON_CHANGE, false, servo_pos, 0 );
servo_pos -= step_size;
if ( servo_pos < servo_dest ) servo_pos = servo_dest;
servo.write( servo_pos );
timer.set( step_time );
return;
case ENT_FINISHED:
push( connectors, ON_FINISH, 0, servo_pos, 0 );
return;
}
}
Atm_servo& Atm_servo::step( int degrees, int time ) {
step_size = degrees;
timer.set( step_time = time );
return *this;
}
Atm_servo& Atm_servo::position( int pos ) {
servo_dest = pos;
return *this;
}
int Atm_servo::position( void ) {
return servo_pos;
}
/* Optionally override the default trigger() method
* Control how your machine processes triggers
*/
Atm_servo& Atm_servo::trigger( int event ) {
switch ( event ) {
case EVT_UP:
servo_dest += step_size;
if ( servo_dest > 180 ) servo_dest = 180;
break;
case EVT_DOWN:
servo_dest -= step_size;
if ( servo_dest < 0 ) servo_dest = 0;
break;
case EVT_SWEEP:
servo_dest = servo_pos == 0 ? 180 : 0;
break;
default:
servo_dest = event;
break;
}
return *this;
}
/* Optionally override the default state() method
* Control what the machine returns when another process requests its state
*/
int Atm_servo::state( void ) {
return servo_pos;
}
/* Nothing customizable below this line
************************************************************************************************
*/
/* onChange() push connector variants ( slots 2, autostore 0, broadcast 0 )
*
* Usage in action() handler: push( connectors, ON_CHANGE, sub, v, up );
*/
Atm_servo& Atm_servo::onChange( Machine& machine, int event ) {
onPush( connectors, ON_CHANGE, 0, 2, 1, machine, event );
return *this;
}
Atm_servo& Atm_servo::onChange( atm_cb_push_t callback, int idx ) {
onPush( connectors, ON_CHANGE, 0, 2, 1, callback, idx );
return *this;
}
Atm_servo& Atm_servo::onChange( int sub, Machine& machine, int event ) {
onPush( connectors, ON_CHANGE, sub, 2, 0, machine, event );
return *this;
}
Atm_servo& Atm_servo::onChange( int sub, atm_cb_push_t callback, int idx ) {
onPush( connectors, ON_CHANGE, sub, 2, 0, callback, idx );
return *this;
}
/* onFinish() push connector variants ( slots 1, autostore 0, broadcast 0 )
*
* Usage in action() handler: push( connectors, ON_FINISH, 0, v, up );
*/
Atm_servo& Atm_servo::onFinish( Machine& machine, int event ) {
onPush( connectors, ON_FINISH, 0, 1, 1, machine, event );
return *this;
}
Atm_servo& Atm_servo::onFinish( atm_cb_push_t callback, int idx ) {
onPush( connectors, ON_FINISH, 0, 1, 1, callback, idx );
return *this;
}
/* State trace method
* Sets the symbol table and the default logging method for serial monitoring
*/
Atm_servo& Atm_servo::trace( Stream& stream ) {
Machine::setTrace( &stream, atm_serial_debug::trace, "SERVO\0EVT_MVUP\0EVT_MVDN\0EVT_TIMER\0ELSE\0IDLE\0UP\0UP_NEXT\0DOWN\0DOWN_NEXT\0FINISHED" );
return *this;
}