 








 
Supports 6~14V Wide Range Voltage Input, With 360° Magnetic Encoder

| PRODUCT TYPE | ST3020 serial bus servo | 
|---|---|
| TORQUE | 25kg.cm@12V | 
| ROTATION ANGLE | 360° (0~4095) | 
| POSITION SENSOR RESOLUTION | 0.088° (360°/4096) | 
| MECHANISM LIMIT ANGLE | No Limit | 
| WORKING VOLTAGE | 6 ~ 14 V (typ. 12V) | 
| GEAR | high precision metal gear | 
| NO-LOAD SPEED | 0.167sec/60° (60RPM)@12V | 
| ENCODER TYPE | 12Bits magnetic encoder | 
| ID RANGE | 1 ~ 253 | 
| BAUDRATE | 38400bps ~ 1Mbps (1Mbps by default) | 
| FEEDBACK | Position, Load, Speed, Input Voltage, Current, Temperature | 
| NO-LOAD CURRENT | 200mA@12V | 
| LOCKED-ROTOR CURRENT | 2.7A@12V | 
| KT | 9.26kg.cm/A | 
* images here are for reference ONLY
Allows Controlling Up To 253 Serial Bus Servos At The Same Time
 
Note: though one channel UART can control up to 253 serial bus servos, due to the high power of the servos, it is necessary to consider whether the power supply solution is enough when using too many servos. For reference only, the servo driver board is NOT included
Supports 6.0~14V Wide Range Voltage Input, And Can Be Directly Powered By 2S
Or 3S Lithium Batteries. Up To 25kg.Cm Torque On 12V Voltage, Suitable For Building
Quadruped Robots, Hexapod Walkers, Robotic Arms And Other Robotic Projects
Requiring Multiple Servos

Adopts High-Reliability Design, Suitable For Industrial Equipments, Robotics, And Other Application Scenarios That Require Angle Or Speed Closed-Loop Control

Adopts 12-bit high-precision magnetic encoding angle sensor. Compared with the carbon film potentiometer, the angle of the magnetic encoder is enlarged to 360°, and the resolution is increased by 4 times. Since there is a gap and no friction between the magnetic encoder and the radial magnet, the lifetime of the servo is effectively extended.

The Speed And Acceleration Values Are Settable To Make The Motion Effect Softer

360° Installation At Any Position, One Button To Set The Current Position As Middle Position. Easy To Install And Debug
 
1. In the default program, a hotspot will be created automatically after the servo driver board is turned on. Use your mobile phone to connect to this hotspot, open the browser, and enter the IP address to enter the control interface.
 
2. Click Release to unlock, then turn the servo to the middle position where you need to set
 
3. Click Set Middle Position then confirm.
 
4. Turn the servo to any angle, then click Middle, and the servo will automatically return to the middle position initially set.
The Servo Will Provide Various Feedback Like Position, Load, Speed,
Input Voltage, Current And Temperature In Real Time
 
* images here are for reference ONLY
 
Angle servo mode
Default mode, the angle position is controllable at 0~360° degrees
 
Speed closed-loop motor mode
Motor mode, intelligently control and maintain speed when the load changes
 
Step mode
Can perform step motion relative to the current position
Supports Angle Position Control In Both Positive And Negative Directions Up To 7.5
Loops Under The Default Precision Setting, But The Number Of Loops Will Not Be Saved In Case Of Power Loss. Lowering The Angle Resolution Can Double The Number Of Control Loops
 
With the flat key shaft flange designed for this serial bus servo, the output shaft of the servo can be installed on more devices, making full use of various working modes and excellent low-speed performance. It can be used to install various transmission parts such as 6mm shaft couplings, wheels, timing pulleys, and gears.

* for reference only, the flat key shaft flange and wheels are Not included.
More Convenient To Develop The Structural Components, Combination Use More Flexible

 
Aluminum alloy middle case
Improved heat tolerance, size stability, rigidity, and mechanical performance
 
High strength aluminum servo wheels
Using T6061 aluminum alloy, good anti-corrosion performance
 
High precision copper and steel gears
The combination of the two types of gears allows the servo to work with lower working noise, and enhances its stability and mechanical performance
 
All-metal bracket
More convenient to combine it with other devices
We provide the open-source web control demo of the servo driver board and a secondary development tutorial, which can be directly used for remote setting and remote control of the servo. At the same time, we also provide a 3D model for you to build your project quickly.



Serial bus servo drive circuit schematic.
Generally, we control the ST series servos by compiling and uploading the demo through the Arduino IDE. However, compiling through Arduino requires installing various dependency libraries before use. Therefore, we provide an ESP32 download tool. With this tool, users can download the demo to the driver board without needing to download other dependency libraries or the Arduino IDE software.
Upload Speed: "921600" CPU Frequency: "240MHz(WiFi/BT)" Flash Frequency: "80MHz" Flash Mode: "QIO" Flash Size: "4MB(32Mb)" '''Partition Scheme: "Huge APP(3MB No OTA/1MB SPIFFS)" PSRAM: "Disabled"'''
Each demo that controls the servo needs to initialize the servo, and the initialization is done before it can be used.
#include <SCServo.h>
SMS_STS st;
void setup(){
Serial1.begin(1000000); //Serial port initialization, and if using devices like ESP32, custom serial ports can also be selected.
// Serial1.begin(1000000, SERIAL_8N1, RX, TX); // Custom serial ports
st.pSerial = &Serial1;
while(!Serial1) {}
}
Among the servos connected in series, each ID should only correspond to one servo. Otherwise, the servo feedback information cannot be obtained properly.
When changing the servo ID, it is advisable to ensure that the driver board is only connected to one servo. The ID will be permanently stored in the servo.
#include <SCServo.h>
SMS_STS st;
int ID_ChangeFrom = 1; // The original ID of the servo whose ID is to be changed is factory defaulted to 1.
int ID_Changeto = 2; // New ID
void setup(){
Serial1.begin(1000000);
st.pSerial = &Serial1;
while(!Serial1) {}
st.unLockEprom(ID_ChangeFrom); //Unlock EPROM-SAFE
st.writeByte(ID_ChangeFrom, SMS_STS_ID, ID_Changeto);//Change ID
st.LockEprom(ID_Changeto); // Lock EPROM-SAFE
}
void loop(){
}
Used to test whether a particular servo is properly connected.
#include <SCServo.h>
SMS_STS st;
int TEST_ID = 3; // Servo ID to be tested
void setup()
{
Serial.begin(115200);
Serial1.begin(1000000, SERIAL_8N1, RX, TX); // Custom serial ports
st.pSerial = &Serial1;
while(!Serial1) {}
}
void loop()
{
int ID = st.Ping(TEST_ID); //If you ping the servo with that ID and receive no response, it will return -1.
if(ID!=-1){
Serial.print("Servo ID:");
Serial.println(ID, DEC);
delay(100);
}else{
Serial.println("Ping servo ID error!");
delay(2000);
}
}
Can be used to control individual servo rotation.
#include <SCServo.h>
SMS_STS st;
void setup()
{
Serial1.begin(1000000);
st.pSerial = &Serial1;
while(!Serial1) {}
}
void loop()
{
st.WritePos(1, 1000, 1500, 50); //To control the servo with ID 1, rotate it to position 1000 at a speed of 1500, with a start-stop acceleration of 50.
delay(754);//[(P1-P0)/V]*1000+100
st.WritePos(1, 20, 1500, 50); // To control the servo with ID 1, rotate it to position 20 at a speed of 1500, with a start-stop acceleration of 50.
delay(754);//[(P1-P0)/V]*1000+100
}
Can be used to control multiple servos at the same time (rotating to different positions and at different speeds).
#include <SCServo.h>
SMS_STS st;
// the uart used to control servos.
// GPIO 18 - S_RXD, GPIO 19 - S_TXD, as default.
#define S_RXD 18 //Customize the IO of the serial port, if you don't use the custom serial port below Serial1.begin(1000000, SERIAL_8N1, S_RXD, S_TXD); you need to change to Serial1.begin(1000000);.
#define S_TXD 19
byte ID[2];
s16 Position[2];
u16 Speed[2];
byte ACC[2];
void setup()
{
Serial1.begin(1000000, SERIAL_8N1, S_RXD, S_TXD);
st.pSerial = &Serial1;
delay(1000);
ID[0] = 1; // Save the servo ID to be controlled to ID[].
ID[1] = 2; //Save the servo ID to be controlled to ID[].
Speed[0] = 3400; // Set the servo speed, Speed[0] corresponds to the servo with ID[0] above.
Speed[1] = 3400; // Set the servo speed, Speed[1] corresponds to the servo with ID[1] above.
ACC[0] = 50; // Set the start/stop acceleration, the lower the value the lower the acceleration, and the maximum can be set to 150.
ACC[1] = 50;
}
void loop()
{
Position[0] = 3000; // Set the target position of the servo with ID[0] (in this case ID 1) in the range 0-4095
Position[1] = 3000; // Set the target position of the servo with ID[1] (here with ID 2) in the range 0-4095
st.SyncWritePosEx(ID, 2, Position, Speed, ACC);//servo(ID1/ID2) speed=3400,acc=50,move to position=3000.
delay(2000);
Position[0] = 100;
Position[1] = 100;
st.SyncWritePosEx(ID, 2, Position, Speed, ACC);//servo(ID1/ID2) speed=3400,acc=50,move to position=100.
delay(2000);
}
#define S_RXD 18
#define S_TXD 19
#include <SCServo.h>
SMS_STS sms_sts;
void setup()
{
Serial1.begin(1000000, SERIAL_8N1, S_RXD, S_TXD);
Serial.begin(115200);
sms_sts.pSerial = &Serial1;
delay(1000);
}
void loop()
{
int Pos;
int Speed;
int Load;
int Voltage;
int Temper;
int Move;
int Current;
if(sms_sts.FeedBack(1)!=-1){
Pos = sms_sts.ReadPos(-1);
Speed = sms_sts.ReadSpeed(-1);
Load = sms_sts.ReadLoad(-1);
Voltage = sms_sts.ReadVoltage(-1);
Temper = sms_sts.ReadTemper(-1);
Move = sms_sts.ReadMove(-1);
Current = sms_sts.ReadCurrent(-1);
Serial.print("Position:");
Serial.println(Pos);
Serial.print("Speed:");
Serial.println(Speed);
Serial.print("Load:");
Serial.println(Load);
Serial.print("Voltage:");
Serial.println(Voltage);
Serial.print("Temper:");
Serial.println(Temper);
Serial.print("Move:");
Serial.println(Move);
Serial.print("Current:");
Serial.println(Current);
delay(10);
}else{
Serial.println("FeedBack err");
delay(500);
}
Pos = sms_sts.ReadPos(1); // Get position feedback
if(Pos!=-1){
Serial.print("Servo position:");
Serial.println(Pos, DEC);
delay(10);
}else{
Serial.println("read position err");
delay(500);
}
Voltage = sms_sts.ReadVoltage(1); //Get voltage feedback
if(Voltage!=-1){
Serial.print("Servo Voltage:");
Serial.println(Voltage, DEC);
delay(10);
}else{
Serial.println("read Voltage err");
delay(500);
}
Temper = sms_sts.ReadTemper(1); // Get temperature feedback
if(Temper!=-1){
Serial.print("Servo temperature:");
Serial.println(Temper, DEC);
delay(10);
}else{
Serial.println("read temperature err");
delay(500);
}
Speed = sms_sts.ReadSpeed(1); // Get speed feedback
if(Speed!=-1){
Serial.print("Servo Speed:");
Serial.println(Speed, DEC);
delay(10);
}else{
Serial.println("read Speed err");
delay(500);
}
Load = sms_sts.ReadLoad(1); // Get load feedback
if(Load!=-1){
Serial.print("Servo Load:");
Serial.println(Load, DEC);
delay(10);
}else{
Serial.println("read Load err");
delay(500);
}
Current = sms_sts.ReadCurrent(1); // Get current feedback
if(Current!=-1){
Serial.print("Servo Current:");
Serial.println(Current, DEC);
delay(10);
}else{
Serial.println("read Current err");
delay(500);
}
Move = sms_sts.ReadMove(1); // Getting movement feedback
if(Move!=-1){
Serial.print("Servo Move:");
Serial.println(Move, DEC);
delay(10);
}else{
Serial.println("read Move err");
delay(500);
}
Serial.println();
}








ชำระเงินค่าสินค้าโดยการโอนเงินเข้าบัญชีธนาคาร KBANK, SCB, BBL,TMB
กรุณาเก็บหลักฐานการโอนเงินของท่านไว้เพื่อแจ้งการชำระเงินด้วยค่ะ
ท่านสามารถแจ้งการชำระเงินผ่านระบบอัตโนมัติได้โดย Click Link ข้างล่างค่ะ
https://www.arduitronics.com/informpayment
 
		| หน้าที่เข้าชม | 15,444,873 ครั้ง | 
| ผู้ชมทั้งหมด | 5,947,951 ครั้ง | 
| เปิดร้าน | 21 พ.ค. 2556 | 
| ร้านค้าอัพเดท | 22 ต.ค. 2568 | 
