-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathMeMbotDCMotor.cpp
98 lines (93 loc) · 2.53 KB
/
MeMbotDCMotor.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
/**
* \par Copyright (C), 2012-2016, MakeBlock
* \brief Driver for Mbot DC Motor.
* \file MeMbotDCMotor.cpp
* @author MakeBlock
* @version V1.0.1
* @date 2015/11/09
* @brief Driver for Mbot DC Motor.
*
* \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
* This file is Hardware adaptation layer between Mbot board and all
* MakeBlock drives
*
* \par Method List:
*
* 1. void MBotDCMotor::move(int direction, int speed);
*
* \par History:
* <pre>
* `<Author>` `<Time>` `<Version>` `<Descr>`
* Mark Yan 2015/09/01 1.0.0 Rebuild the old lib.
* Mark Yan 2015/11/09 1.0.1 fix some comments error.
* </pre>
*/
#include "MeMbotDCMotor.h"
/**
* Alternate Constructor which can call your own function to map the MBot DCMotor to arduino port,
* the slot2 pin will be used here since specify slot is not be set.
* \param[in]
* port - RJ25 port from PORT_1 to M2
*/
#ifdef ME_PORT_DEFINED
MBotDCMotor::MBotDCMotor(uint8_t port) : MeDCMotor(port)
{
}
/**
* \par Function
* move
* \par Description
* MBot DCMotor moves with the speed and direction.
* \param[in]
* direction - The direction of the MBot DCMotor's movement
* \param[in]
* speed - The speed of MBot DCMotor's movement.
* \par Output
* None
* \par Return
* None
* \par Others
* None
*/
void MBotDCMotor::move(int direction, int speed)
{
int leftSpeed = 0;
int rightSpeed = 0;
if(direction==1)
{
leftSpeed = -speed;
rightSpeed = speed;
}
else if(direction==2)
{
leftSpeed = speed;
rightSpeed = -speed;
}
else if(direction==3)
{
leftSpeed = speed;
rightSpeed = speed;
}
else if(direction==4)
{
leftSpeed = -speed;
rightSpeed = -speed;
}
MeDCMotor::reset(M1);
MeDCMotor::run(leftSpeed);
MeDCMotor::reset(M2);
MeDCMotor::run(rightSpeed);
}
#endif //ME_PORT_DEFINED