KS0094 KEYESTUDIO CNC Kit V2.0: Difference between revisions

From Keyestudio Wiki
Jump to navigation Jump to search
(Created blank page)
 
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


thumb


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.


thumb

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


thumb

thumb

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:


thumb

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.


thumb

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.


thumb

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.


thumb


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.


thumb

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.


thumb

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.


thumb


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.


thumb

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.


thumb

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:


thumb

There is a DRIVERS folder in Arduino software installed package(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)


thumb


Open device manager, we will find the yellow exclamation mark disappear. The driver of CP2102 is installed successfully.
thumb

thumb


Arduino IDE Setting

Click0486-12.png icon,open Arduino IDE.
0085=14.png

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)
0085=15.png


Then select the correct COM port (you can see the corresponding COM port after the driver is successfully installed)


0085=16.png

0085=17.png

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:

  1. define EN 8 // stepper motor enable, low level effective
  2. define X_DIR 5 //X axis, stepper motor direction control
  3. define Y_DIR 6 //y axis, stepper motor direction control
  4. define Z_DIR 7 //zaxis, stepper motor direction control
  5. define X_STP 2 //x axis, stepper motor control
  6. define Y_STP 3 //y axis, stepper motor control
  7. 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.


Ks0286-11.png


For a license agreement, please check I accept the agreement and click Next.


Ks0286-12.png

When you are ready to continue with Setup, click Next.


Ks0286-13.png

To continue, click Next. If you would like to select a different folder to install, click Browse.


Ks0286-14.png

To continue, click Next. If you would like to select a different folder to install, click Browse.


Ks0286-15.png

Select the additional tasks you would like Setup to perform while installing Grbl Controller, then click Next.


0094=10.png

Click Install to continue with the installation.


Ks0286-17.png

Click Next.


Ks0286-18.png


At last, click ”Finish” to finish the installation. 



Ks0286-19.png


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.


0094=14.png

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.


Ks0286-21.png

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.


Ks0286-22.png

Click “Begin” , and you can see how the motors move on coordinates.


0094=17.png


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