KS0094 KEYESTUDIO CNC Kit V2.0: Difference between revisions
Keyestudio (talk | contribs) (Created blank page) |
Keyestudio (talk | contribs) No edit summary |
||
(11 intermediate revisions by the same user not shown) | |||
Line 1: | Line 1: | ||
<br>[[File:0080=1.png|500px|frameless|right|thumb]]<br> | |||
== Introduction == | |||
Keyestudio CNC Shield V2.0 can be used as driver expansion board for engraving machines . It has in total 3 channel slots for A4988 stepper motor driver modules (not included) for driving 3 channel of stepper motors. Each channel of stepper motor only needs 2 IO ports, which means 6 IO ports is sufficient to manage 3 stepper motors. This shield can make quick work for managing stepper motors in your project. | |||
<br>[[File:0094=2.png|500px|frameless|thumb]]<br> | |||
== Specification == | |||
1. Keyestudio CNC Shield Version 2.0 | |||
2. GRBL 0.8c compatible. (Open source firmware that runs on an Arduino V4.0 board that turns G-code commands into stepper signals) | |||
3. 3-Axis support (X, Y, Z , ) | |||
4. 2 x End stops for each axis (6 in total) | |||
5. Spindle enable and direction | |||
6. Coolant enable | |||
7. Uses removable A4988 compatible stepper drivers. (A4988, DRV8825 and others) | |||
8. Jumpers to set the Micro-Stepping for the stepper drivers. (Some drivers like the DRV8825 can do up to 1/32 micro-stepping ) | |||
9. Compact design. | |||
10. Stepper Motors can be connected with 4 pin molex connectors or soldered in place. | |||
11. Runs on 12V DC. | |||
== Kit List == | |||
* 1x keyestudio CNC Shield V2.0 | |||
* 1x keyestudio V4.0 board | |||
* 3x A4988 Driver | |||
* 1x USB Cable | |||
== Connection Diagram == | |||
<br>[[File:0094=3.png|500px|frameless|thumb]]<br> | |||
<br>[[File:0094=4.png|500px|frameless|thumb]]<br> | |||
== Install Arduino IDE and Driver == | |||
=== Download software === | |||
When we get control board, we need to download Arduino IDE and driver firstly. | |||
You could download Arduino IDE from the official website: | |||
https://www.arduino.cc/, click the SOFTWARE on the browse bar, click “DOWNLOADS” to enter download page, as shown below: | |||
<br>[[File:0085=04.png|500px|frameless|thumb]]<br> | |||
There are various versions for Arduino, just download a suitable version for your system, we will take WINDOWS system as an example to show you how to download and install. | |||
<br>[[File:04862png.png|500px|frameless|thumb]]<br> | |||
There are two versions for WINDOWS system, one is installed version, another one is download version, you just need to download file to computer directly and unzip it. These two versions can be used normally. Choose one and download on your computer. | |||
<br>[[File:04863png.png|500px|frameless|thumb]]<br> | |||
You just need to click JUST DOWNLOAD, then click the downloaded file to install it. And when the ZIP file is downloaded, you can directly unzip and start it. | |||
=== Keyestudio V4.0 Development Board === | |||
We need to know keyestudio V4.0 development board, as a core of this smart car. | |||
<br>[[File:0077-78--1.png|400px|frameless|thumb]]<br> | |||
keyestudio V4.0 development board is an Arduino uno-compatible board, which is based on ATmega328P MCU, and with a cp2102 Chip as a UART-to-USB converter. | |||
<br>[[File:0470---42.png|500px|frameless|thumb]]<br> | |||
It has 14 digital input/output pins (of which 6 can be used as PWM outputs), 6 analog inputs, a 16 MHz quartz crystal, a USB connection, a power jack, 2 ICSP headers and a reset button. | |||
<br>[[File:0428---1000.png|500px|frameless|thumb]]<br> | |||
It contains everything needed to support the microcontroller; simply connect it to a computer with a USB cable or power it via an external DC power jack (DC 7-12V) or via female headers Vin/ GND(DC 7-12V) to get started. | |||
<br>[[File:0470---40.png|500px|frameless|thumb]]<br> | |||
=== Installing driver === | |||
Let’s install the driver of keyestudio PLUS control board. The USB-TTL chip on PLUS board adopts CP2102 serial chip. The driver program of this chip is included in Arduino 1.8 version and above, which is convenient. Plug on USB port of board, the computer can recognize the hardware and automatically install the driver of CP2102. | |||
If install unsuccessfully, or you intend to install manually, open the device manager of computer. Right click Computer----- Properties----- Device Manager. | |||
<br>[[File:0085=07.png|700px|frameless|thumb]]<br> | |||
There is a yellow exclamation mark on the page, which implies installing the driver of CP2102 unsuccessfully. Then we double click the hardware and update the driver. | |||
<br>[[File:0085=08.png|500px|frameless|thumb]]<br> | |||
Click “OK” to enter the following page, click “browse my computer for updated driver software”, find out the installed or downloaded ARDUINO software. As shown below: | |||
<br>[[File:0085=09.png|500px|frameless|thumb]]<br> | |||
There is a DRIVERS folder in Arduino software installed package([[File:0085=10.png|500px|frameless|thumb]]), open driver folder and you can see the driver of CP210X series chips. | |||
We click “Browse”, then find out the driver folder, or you could enter “driver” to search in rectangular box, then click “next”, the driver will be installed successfully. (I place Arduino software folder on the desktop, you could follow my way) | |||
<br>[[File:0085=11.png|500px|frameless|thumb]]<br> | |||
Open device manager, we will find the yellow exclamation mark disappear. The driver of CP2102 is installed successfully. | |||
<br>[[File:0085=12.png|500px|frameless|thumb]]<br> | |||
<br>[[File:0085=13.png|500px|frameless|thumb]]<br> | |||
=== '''Arduino IDE Setting''' === | |||
Click[[Image:0486-12.png|200px|frameless]] icon,open Arduino IDE. | |||
<br>[[Image:0085=14.png|400px|frameless]]<br> | |||
To avoid the errors when uploading the program to the board, you need to select the correct Arduino board that matches the board connected to your computer. | |||
Then come back to the Arduino software, you should click Tools→Board, select the board. (as shown below) | |||
<br>[[Image:0085=15.png|500px|frameless]]<br> | |||
Then select the correct COM port (you can see the corresponding COM port after the driver is successfully installed) | |||
<br>[[Image:0085=16.png|500px|frameless]]<br> | |||
<br>[[Image:0085=17.png|500px|frameless]]<br> | |||
Before uploading the program to the board, let’s demonstrate the function of each symbol in the Arduino IDE toolbar.<br> | |||
A- Used to verify whether there is any compiling mistakes or not.<br> | |||
B- Used to upload the sketch to your Arduino board.<br> | |||
C- Used to create shortcut window of a new sketch.<br> | |||
D- Used to directly open an example sketch.<br> | |||
E- Used to save the sketch.<br> | |||
F- Used to send the serial data received from board to the serial monitor.<br> | |||
== Using Method == | |||
=== Test Main Board === | |||
First, write below code in IDE to test whether main board, shield and three motors work normally. | |||
Explanation | |||
1. If you properly reduce the value 800 in delayMicroseconds(800) to increase the frequency of input PWM signal, you can increase the rotation speed of stepper motor. The change of value cannot be too much or the motor will stop moving. | |||
2. Rotate the knob on A4988, you can adjust the output current of the motors to change the torque. | |||
=== Test Code: === | |||
#define EN 8 // stepper motor enable, low level effective | |||
#define X_DIR 5 //X axis, stepper motor direction control | |||
#define Y_DIR 6 //y axis, stepper motor direction control | |||
#define Z_DIR 7 //zaxis, stepper motor direction control | |||
#define X_STP 2 //x axis, stepper motor control | |||
#define Y_STP 3 //y axis, stepper motor control | |||
#define Z_STP 4 //z axis, stepper motor control | |||
<pre> | |||
/* | |||
// Function: step -control the direction and number of steps of the stepper motor | |||
// Parameter: dir -direction control, dirPin corresponds to DIR pin, stepperPin correspomds to | |||
step pin, steps is the number of steps. | |||
// no return value | |||
*/ | |||
void step(boolean dir, byte dirPin, byte stepperPin, int steps) | |||
{ | |||
digitalWrite(dirPin, dir); | |||
delay(50); | |||
for (int i = 0; i < steps; i++) { | |||
digitalWrite(stepperPin, HIGH); | |||
delayMicroseconds(800); | |||
digitalWrite(stepperPin, LOW); | |||
delayMicroseconds(800); | |||
} | |||
} | |||
void setup(){// set the IO pins for the stepper motors as output | |||
pinMode(X_DIR, OUTPUT); pinMode(X_STP, OUTPUT); | |||
pinMode(Y_DIR, OUTPUT); pinMode(Y_STP, OUTPUT); | |||
pinMode(Z_DIR, OUTPUT); pinMode(Z_STP, OUTPUT); | |||
pinMode(EN, OUTPUT); | |||
digitalWrite(EN, LOW); | |||
} | |||
void loop(){ | |||
step(false, X_DIR, X_STP, 3200); // x axis motor rotates CCW for 1 circle, as in 200 steps | |||
step(false, Y_DIR, Y_STP, 3200); // y axis motor rotates CCW for 1 circle, as in 200 steps | |||
step(false, Z_DIR, Z_STP, 3200); // z axis motor rotates CCW for 1 circle, as in 200 steps | |||
delay(1000); | |||
step(true, X_DIR, X_STP, 3200); // X axis motor rotates CW for 1 circle, as in 200 steps | |||
step(true, Y_DIR, Y_STP, 3200); // y axis motor rotates CW for 1 circle, as in 200 steps | |||
step(true, Z_DIR, Z_STP, 3200); // z axis motor rotates CW for 1 circle, as in 200 steps | |||
delay(1000); | |||
} | |||
=== Install Firmware and Grbl Controller === | |||
a. Write test program to keyestudio V4.0 | |||
copy the folder GRBL_ Arduino_Library_keyes in the data packet and paste it into to the folder libraries, in your Arduino IDE document installation. | |||
Code: | |||
#include <grblmain.h> | |||
void setup(){ | |||
startGrbl(); | |||
} | |||
void loop(){} | |||
// | |||
</pre> | |||
Compile the code above to keyestudio V4.0 via IDE. | |||
b. Install GrblController361 Software | |||
Grbl Controller is a piece of software which is used to send GCode to CNC Machines. Run Grbl Controller361 Setup in your installation packet, the interface below will come out: | |||
Click Next to continue. | |||
<br>[[Image:Ks0286-11.png|400px|frameless]]<br> | |||
For a license agreement, please check I accept the agreement and click Next. | |||
<br>[[Image:Ks0286-12.png|400px|frameless]]<br> | |||
When you are ready to continue with Setup, click Next. | |||
<br>[[Image:Ks0286-13.png|400px|frameless]]<br> | |||
To continue, click Next. If you would like to select a different folder to install, click Browse. | |||
<br>[[Image:Ks0286-14.png|400px|frameless]]<br> | |||
To continue, click Next. If you would like to select a different folder to install, click Browse. | |||
<br>[[Image:Ks0286-15.png|400px|frameless]]<br> | |||
Select the additional tasks you would like Setup to perform while installing Grbl Controller, then click Next. | |||
<br>[[Image:0094=10.png|400px|frameless]]<br> | |||
Click Install to continue with the installation. | |||
<br>[[Image:Ks0286-17.png|400px|frameless]]<br> | |||
Click Next. | |||
<br>[[Image:Ks0286-18.png|400px|frameless]]<br> | |||
At last, click ”Finish” to finish the installation. | |||
<br>[[Image:Ks0286-19.png|400px|frameless]]<br> | |||
c. Test G-Code on Grbl Controller | |||
Power the main board using a USB cable and connect correctly all your external devices, then run Grbl Controller. | |||
Choose Port name the same as IDE COM port and click “Open” to open the series port, connecting CNC Machines with computer. | |||
<br>[[Image:0094=14.png|400px|frameless]]<br> | |||
After opening the series port, the “Open” button change into “Close/Reset” and get red! | |||
At this time you can click the X axis、Y axis、Z axis as shown in below diagram to adjust the motion direction of motors. | |||
<br>[[Image:Ks0286-21.png|400px|frameless]]<br> | |||
Notes: after adjusting the axies, before beginning G-Code file, you must close and open again . | |||
Now, it is time to have a try! Click ”Choose file” to choose one G-Code file named cn. to test in the data packet for a beginner, and the interface will come out: | |||
GrblController. | |||
<br>[[Image:Ks0286-22.png|400px|frameless]]<br> | |||
Click “Begin” , and you can see how the motors move on coordinates. | |||
<br>[[Image:0094=17.png|400px|frameless]]<br> | |||
=== Adjusting the drive current === | |||
In the kit, we have applied the A4988 drive module to drive stepper motor. When using, you can turn the potentiometer on the drive module to adjust the drive current. | |||
The specific method please refer to the website link below: | |||
https://wiki.keyestudio.com/Ks0281_Keyestudio_Reprap_Stepper_Motor_Driver | |||
== Reference == | |||
Arduino IDE Download: | |||
https://www.arduino.cc/en/Main/Donate | |||
Download driver, G-Code, Grbl Controller361 setup and library : | |||
https://fs.keyestudio.com/KS0094 |
Latest revision as of 14:47, 25 November 2020
Introduction
Keyestudio CNC Shield V2.0 can be used as driver expansion board for engraving machines . It has in total 3 channel slots for A4988 stepper motor driver modules (not included) for driving 3 channel of stepper motors. Each channel of stepper motor only needs 2 IO ports, which means 6 IO ports is sufficient to manage 3 stepper motors. This shield can make quick work for managing stepper motors in your project.
Specification
1. Keyestudio CNC Shield Version 2.0 2. GRBL 0.8c compatible. (Open source firmware that runs on an Arduino V4.0 board that turns G-code commands into stepper signals) 3. 3-Axis support (X, Y, Z , ) 4. 2 x End stops for each axis (6 in total) 5. Spindle enable and direction 6. Coolant enable 7. Uses removable A4988 compatible stepper drivers. (A4988, DRV8825 and others) 8. Jumpers to set the Micro-Stepping for the stepper drivers. (Some drivers like the DRV8825 can do up to 1/32 micro-stepping ) 9. Compact design. 10. Stepper Motors can be connected with 4 pin molex connectors or soldered in place. 11. Runs on 12V DC.
Kit List
- 1x keyestudio CNC Shield V2.0
- 1x keyestudio V4.0 board
- 3x A4988 Driver
- 1x USB Cable
Connection Diagram
Install Arduino IDE and Driver
Download software
When we get control board, we need to download Arduino IDE and driver firstly. You could download Arduino IDE from the official website: https://www.arduino.cc/, click the SOFTWARE on the browse bar, click “DOWNLOADS” to enter download page, as shown below:
There are various versions for Arduino, just download a suitable version for your system, we will take WINDOWS system as an example to show you how to download and install.
There are two versions for WINDOWS system, one is installed version, another one is download version, you just need to download file to computer directly and unzip it. These two versions can be used normally. Choose one and download on your computer.
You just need to click JUST DOWNLOAD, then click the downloaded file to install it. And when the ZIP file is downloaded, you can directly unzip and start it.
Keyestudio V4.0 Development Board
We need to know keyestudio V4.0 development board, as a core of this smart car.
keyestudio V4.0 development board is an Arduino uno-compatible board, which is based on ATmega328P MCU, and with a cp2102 Chip as a UART-to-USB converter.
It has 14 digital input/output pins (of which 6 can be used as PWM outputs), 6 analog inputs, a 16 MHz quartz crystal, a USB connection, a power jack, 2 ICSP headers and a reset button.
It contains everything needed to support the microcontroller; simply connect it to a computer with a USB cable or power it via an external DC power jack (DC 7-12V) or via female headers Vin/ GND(DC 7-12V) to get started.
Installing driver
Let’s install the driver of keyestudio PLUS control board. The USB-TTL chip on PLUS board adopts CP2102 serial chip. The driver program of this chip is included in Arduino 1.8 version and above, which is convenient. Plug on USB port of board, the computer can recognize the hardware and automatically install the driver of CP2102.
If install unsuccessfully, or you intend to install manually, open the device manager of computer. Right click Computer----- Properties----- Device Manager.
There is a yellow exclamation mark on the page, which implies installing the driver of CP2102 unsuccessfully. Then we double click the hardware and update the driver.
Click “OK” to enter the following page, click “browse my computer for updated driver software”, find out the installed or downloaded ARDUINO software. As shown below:
There is a DRIVERS folder in Arduino software installed package(), open driver folder and you can see the driver of CP210X series chips.
We click “Browse”, then find out the driver folder, or you could enter “driver” to search in rectangular box, then click “next”, the driver will be installed successfully. (I place Arduino software folder on the desktop, you could follow my way)
Open device manager, we will find the yellow exclamation mark disappear. The driver of CP2102 is installed successfully.
Arduino IDE Setting
To avoid the errors when uploading the program to the board, you need to select the correct Arduino board that matches the board connected to your computer.
Then come back to the Arduino software, you should click Tools→Board, select the board. (as shown below)
Then select the correct COM port (you can see the corresponding COM port after the driver is successfully installed)
Before uploading the program to the board, let’s demonstrate the function of each symbol in the Arduino IDE toolbar.
A- Used to verify whether there is any compiling mistakes or not.
B- Used to upload the sketch to your Arduino board.
C- Used to create shortcut window of a new sketch.
D- Used to directly open an example sketch.
E- Used to save the sketch.
F- Used to send the serial data received from board to the serial monitor.
Using Method
Test Main Board
First, write below code in IDE to test whether main board, shield and three motors work normally. Explanation 1. If you properly reduce the value 800 in delayMicroseconds(800) to increase the frequency of input PWM signal, you can increase the rotation speed of stepper motor. The change of value cannot be too much or the motor will stop moving. 2. Rotate the knob on A4988, you can adjust the output current of the motors to change the torque.
Test Code:
- define EN 8 // stepper motor enable, low level effective
- define X_DIR 5 //X axis, stepper motor direction control
- define Y_DIR 6 //y axis, stepper motor direction control
- define Z_DIR 7 //zaxis, stepper motor direction control
- define X_STP 2 //x axis, stepper motor control
- define Y_STP 3 //y axis, stepper motor control
- define Z_STP 4 //z axis, stepper motor control
/* // Function: step -control the direction and number of steps of the stepper motor // Parameter: dir -direction control, dirPin corresponds to DIR pin, stepperPin correspomds to step pin, steps is the number of steps. // no return value */ void step(boolean dir, byte dirPin, byte stepperPin, int steps) { digitalWrite(dirPin, dir); delay(50); for (int i = 0; i < steps; i++) { digitalWrite(stepperPin, HIGH); delayMicroseconds(800); digitalWrite(stepperPin, LOW); delayMicroseconds(800); } } void setup(){// set the IO pins for the stepper motors as output pinMode(X_DIR, OUTPUT); pinMode(X_STP, OUTPUT); pinMode(Y_DIR, OUTPUT); pinMode(Y_STP, OUTPUT); pinMode(Z_DIR, OUTPUT); pinMode(Z_STP, OUTPUT); pinMode(EN, OUTPUT); digitalWrite(EN, LOW); } void loop(){ step(false, X_DIR, X_STP, 3200); // x axis motor rotates CCW for 1 circle, as in 200 steps step(false, Y_DIR, Y_STP, 3200); // y axis motor rotates CCW for 1 circle, as in 200 steps step(false, Z_DIR, Z_STP, 3200); // z axis motor rotates CCW for 1 circle, as in 200 steps delay(1000); step(true, X_DIR, X_STP, 3200); // X axis motor rotates CW for 1 circle, as in 200 steps step(true, Y_DIR, Y_STP, 3200); // y axis motor rotates CW for 1 circle, as in 200 steps step(true, Z_DIR, Z_STP, 3200); // z axis motor rotates CW for 1 circle, as in 200 steps delay(1000); } === Install Firmware and Grbl Controller === a. Write test program to keyestudio V4.0 copy the folder GRBL_ Arduino_Library_keyes in the data packet and paste it into to the folder libraries, in your Arduino IDE document installation. Code: #include <grblmain.h> void setup(){ startGrbl(); } void loop(){} //
Compile the code above to keyestudio V4.0 via IDE.
b. Install GrblController361 Software Grbl Controller is a piece of software which is used to send GCode to CNC Machines. Run Grbl Controller361 Setup in your installation packet, the interface below will come out:
Click Next to continue.
For a license agreement, please check I accept the agreement and click Next.
When you are ready to continue with Setup, click Next.
To continue, click Next. If you would like to select a different folder to install, click Browse.
To continue, click Next. If you would like to select a different folder to install, click Browse.
Select the additional tasks you would like Setup to perform while installing Grbl Controller, then click Next.
Click Install to continue with the installation.
Click Next.
At last, click ”Finish” to finish the installation.
c. Test G-Code on Grbl Controller
Power the main board using a USB cable and connect correctly all your external devices, then run Grbl Controller.
Choose Port name the same as IDE COM port and click “Open” to open the series port, connecting CNC Machines with computer.
After opening the series port, the “Open” button change into “Close/Reset” and get red! At this time you can click the X axis、Y axis、Z axis as shown in below diagram to adjust the motion direction of motors.
Notes: after adjusting the axies, before beginning G-Code file, you must close and open again . Now, it is time to have a try! Click ”Choose file” to choose one G-Code file named cn. to test in the data packet for a beginner, and the interface will come out:
GrblController.
Click “Begin” , and you can see how the motors move on coordinates.
Adjusting the drive current
In the kit, we have applied the A4988 drive module to drive stepper motor. When using, you can turn the potentiometer on the drive module to adjust the drive current. The specific method please refer to the website link below: https://wiki.keyestudio.com/Ks0281_Keyestudio_Reprap_Stepper_Motor_Driver
Reference
Arduino IDE Download: https://www.arduino.cc/en/Main/Donate
Download driver, G-Code, Grbl Controller361 setup and library : https://fs.keyestudio.com/KS0094