Skip to content

Arduino- TCP server that controls a servo with a WebSocket-like API

Notifications You must be signed in to change notification settings

Reza-366/arduino-tcp-server

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

1 Commit
 
 
 
 
 
 

Repository files navigation

Intro

This is a basic example of using a TCP server to control a servo. The TCP server follows the WebSocket protocol (without handshake), so you must supply a header frame before sending data. The data is just JSON.

For example, to move the servo to 80 degrees, send a TCP packet like so:

  • first byte is 0x81 (means a text packet, not fragmented)
  • second byte is 0x80 + the size of your JSON (should be less than 125 bytes)
  • the rest is your json ({"angle": 80})

For a sample implementation, see the included client.go. The included client reads an angle on stdin and displays the result on stdout. It will stay up until you kill it (Ctrl+C).

Note, this relies on aJson.

Client

The client is written in Go. For more information and installation instructions, see golang.org.

Info

By default, the server listens on 192.168.254.177:5000, and the servo is expected to be on pin 9. The servo is moved 1 degree at a time with a small delay between each one.

Issues

Currently, JSON content can be up to 0xffff, but this isn't tested. Sizes above 0xffff will be ignored and an error will be printed to Serial along with the data of the packet. This shouldn't be a problem though.

About

Arduino- TCP server that controls a servo with a WebSocket-like API

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Other 57.4%
  • Go 42.6%