2015-06-30 11:07:15 +08:00
[![Gobot ](https://raw.githubusercontent.com/hybridgroup/gobot-site/master/source/images/elements/gobot-logo-small.png )](http://gobot.io/)
2013-12-06 06:35:30 +08:00
2017-01-05 00:53:09 +08:00
[![GitHub release ](https://img.shields.io/github/release/hybridgroup/gobot.svg )](https://github.com/hybridgroup/gobot/releases)
2016-02-04 10:51:12 +08:00
[![Build Status ](https://travis-ci.org/hybridgroup/gobot.png?branch=dev )](https://travis-ci.org/hybridgroup/gobot)
2017-07-12 23:24:23 +08:00
[![Build status ](https://ci.appveyor.com/api/projects/status/ix29evnbdrhkr7ud/branch/dev?svg=true )](https://ci.appveyor.com/project/deadprogram/gobot/branch/dev)
2017-02-16 20:34:04 +08:00
[![Coverage Status ](https://codecov.io/gh/hybridgroup/gobot/branch/dev/graph/badge.svg )](https://codecov.io/gh/hybridgroup/gobot)
2016-02-26 07:00:21 +08:00
[![Go Report Card ](https://goreportcard.com/badge/hybridgroup/gobot )](https://goreportcard.com/report/hybridgroup/gobot)
2017-11-11 21:00:19 +08:00
[![License ](https://img.shields.io/badge/License-Apache%202.0-blue.svg )](https://github.com/hybridgroup/gobot/blob/master/LICENSE.txt)
2017-01-05 00:46:43 +08:00
[![GoDoc ](https://godoc.org/gobot.io/x/gobot?status.svg )](https://godoc.org/gobot.io/x/gobot)
2017-01-05 00:12:45 +08:00
2017-01-05 00:50:03 +08:00
Gobot (http://gobot.io/) is a framework using the Go programming language (http://golang.org/) for robotics, physical computing, and the Internet of Things.
It provides a simple, yet powerful way to create solutions that incorporate multiple, different hardware devices at the same time.
Want to use Javascript robotics? Check out our sister project Cylon.js (http://cylonjs.com/)
Want to use Ruby on robots? Check out our sister project Artoo (http://artoo.io)
2013-11-10 02:51:30 +08:00
2015-01-15 18:52:07 +08:00
## Getting Started
2016-12-08 20:24:03 +08:00
Get the Gobot source with: `go get -d -u gobot.io/x/gobot/...`
2014-10-29 23:35:28 +08:00
2013-11-10 02:51:30 +08:00
## Examples
2014-06-09 11:28:17 +08:00
#### Gobot with Arduino
2013-11-10 02:51:30 +08:00
```go
package main
2013-11-14 12:50:22 +08:00
2013-11-10 02:51:30 +08:00
import (
2014-07-11 08:02:00 +08:00
"time"
2016-12-08 20:24:03 +08:00
"gobot.io/x/gobot"
"gobot.io/x/gobot/drivers/gpio"
"gobot.io/x/gobot/platforms/firmata"
2013-11-10 02:51:30 +08:00
)
func main() {
2016-09-26 03:22:25 +08:00
firmataAdaptor := firmata.NewAdaptor("/dev/ttyACM0")
led := gpio.NewLedDriver(firmataAdaptor, "13")
2013-11-10 02:51:30 +08:00
2014-07-11 08:02:00 +08:00
work := func() {
gobot.Every(1*time.Second, func() {
led.Toggle()
})
}
2013-11-14 12:50:22 +08:00
2014-07-11 08:02:00 +08:00
robot := gobot.NewRobot("bot",
[]gobot.Connection{firmataAdaptor},
[]gobot.Device{led},
work,
)
2013-11-10 02:51:30 +08:00
2016-10-19 01:16:27 +08:00
robot.Start()
2013-11-10 02:51:30 +08:00
}
```
2014-06-09 11:28:17 +08:00
#### Gobot with Sphero
2013-11-25 07:59:36 +08:00
2013-12-06 06:40:29 +08:00
```go
package main
2013-11-25 07:59:36 +08:00
2013-12-06 06:40:29 +08:00
import (
2014-07-11 08:02:00 +08:00
"fmt"
"time"
2016-12-08 20:24:03 +08:00
"gobot.io/x/gobot"
"gobot.io/x/gobot/platforms/sphero"
2013-12-06 06:40:29 +08:00
)
2013-11-25 07:59:36 +08:00
2013-12-06 06:40:29 +08:00
func main() {
2016-09-26 03:22:25 +08:00
adaptor := sphero.NewAdaptor("/dev/rfcomm0")
driver := sphero.NewSpheroDriver(adaptor)
2013-12-06 06:40:29 +08:00
2014-07-11 08:02:00 +08:00
work := func() {
gobot.Every(3*time.Second, func() {
driver.Roll(30, uint16(gobot.Rand(360)))
})
}
2014-02-05 06:27:16 +08:00
2014-07-11 08:02:00 +08:00
robot := gobot.NewRobot("sphero",
[]gobot.Connection{adaptor},
[]gobot.Device{driver},
work,
)
2014-02-05 06:27:16 +08:00
2016-10-19 01:16:27 +08:00
robot.Start()
2013-12-06 06:40:29 +08:00
}
2013-11-25 07:59:36 +08:00
```
2013-11-10 02:51:30 +08:00
2016-09-13 03:29:53 +08:00
#### "Metal" Gobot
You can use the entire Gobot framework as shown in the examples above ("Classic" Gobot), or you can pick and choose from the various Gobot packages to control hardware with nothing but pure idiomatic Golang code ("Metal" Gobot). For example:
```go
package main
import (
2016-12-08 20:24:03 +08:00
"gobot.io/x/gobot/drivers/gpio"
"gobot.io/x/gobot/platforms/intel-iot/edison"
2016-09-13 03:29:53 +08:00
"time"
)
func main() {
2016-09-26 03:22:25 +08:00
e := edison.NewAdaptor()
2016-09-13 03:29:53 +08:00
e.Connect()
2016-09-26 03:22:25 +08:00
led := gpio.NewLedDriver(e, "13")
2016-09-13 03:29:53 +08:00
led.Start()
for {
led.Toggle()
time.Sleep(1000 * time.Millisecond)
}
}
```
2016-10-19 01:16:27 +08:00
#### "Master" Gobot
2016-10-19 01:32:11 +08:00
You can also use the full capabilities of the framework aka "Master Gobot" to control swarms of robots or other features such as the built-in API server. For example:
2016-10-19 01:16:27 +08:00
```go
package main
import (
"fmt"
"time"
2016-12-08 20:24:03 +08:00
"gobot.io/x/gobot"
"gobot.io/x/gobot/api"
"gobot.io/x/gobot/platforms/sphero"
2016-10-19 01:16:27 +08:00
)
2016-10-19 01:32:11 +08:00
func NewSwarmBot(port string) *gobot.Robot {
spheroAdaptor := sphero.NewAdaptor(port)
spheroDriver := sphero.NewSpheroDriver(spheroAdaptor)
spheroDriver.SetName("Sphero" + port)
work := func() {
spheroDriver.Stop()
spheroDriver.On(sphero.Collision, func(data interface{}) {
fmt.Println("Collision Detected!")
})
gobot.Every(1*time.Second, func() {
spheroDriver.Roll(100, uint16(gobot.Rand(360)))
})
gobot.Every(3*time.Second, func() {
spheroDriver.SetRGB(uint8(gobot.Rand(255)),
uint8(gobot.Rand(255)),
uint8(gobot.Rand(255)),
)
})
}
robot := gobot.NewRobot("sphero",
[]gobot.Connection{spheroAdaptor},
[]gobot.Device{spheroDriver},
work,
)
return robot
}
2016-10-19 01:16:27 +08:00
func main() {
master := gobot.NewMaster()
2016-10-19 01:37:53 +08:00
api.NewAPI(master).Start()
2016-10-19 01:16:27 +08:00
spheros := []string{
"/dev/rfcomm0",
"/dev/rfcomm1",
"/dev/rfcomm2",
"/dev/rfcomm3",
}
for _, port := range spheros {
2016-10-19 01:32:11 +08:00
master.AddRobot(NewSwarmBot(port))
2016-10-19 01:16:27 +08:00
}
master.Start()
}
```
2013-11-10 02:51:30 +08:00
## Hardware Support
Gobot has a extensible system for connecting to hardware devices. The following robotics and physical computing platforms are currently supported:
2014-11-04 09:38:20 +08:00
2016-12-08 21:07:43 +08:00
- [Arduino ](http://www.arduino.cc/ ) < => [Package ](https://github.com/hybridgroup/gobot/tree/master/platforms/firmata )
- Audio < => [Package ](https://github.com/hybridgroup/gobot/tree/master/platforms/audio )
- [Beaglebone Black ](http://beagleboard.org/Products/BeagleBone+Black/ ) < => [Package ](https://github.com/hybridgroup/gobot/tree/master/platforms/beaglebone )
- [Bluetooth LE ](https://www.bluetooth.com/what-is-bluetooth-technology/bluetooth-technology-basics/low-energy ) < => [Package ](https://github.com/hybridgroup/gobot/tree/master/platforms/ble )
- [C.H.I.P ](http://www.nextthing.co/pages/chip ) < => [Package ](https://github.com/hybridgroup/gobot/tree/master/platforms/chip )
2017-04-27 19:03:40 +08:00
- [C.H.I.P Pro ](https://docs.getchip.com/chip_pro.html ) < => [Package ](https://github.com/hybridgroup/gobot/tree/master/platforms/chip )
2016-12-08 21:07:43 +08:00
- [Digispark ](http://digistump.com/products/1 ) < => [Package ](https://github.com/hybridgroup/gobot/tree/master/platforms/digispark )
2017-02-24 15:19:20 +08:00
- [DragonBoard ](https://developer.qualcomm.com/hardware/dragonboard-410c ) < => [Package ](https://github.com/hybridgroup/gobot/tree/master/platforms/dragonboard )
2017-01-03 18:23:25 +08:00
- [ESP8266 ](http://esp8266.net/ ) < => [Package ](https://github.com/hybridgroup/gobot/tree/master/platforms/firmata )
2017-12-07 14:40:46 +08:00
- [GoPiGo 3 ](https://www.dexterindustries.com/gopigo3/ ) < => [Package ](https://github.com/hybridgroup/gobot/tree/master/platforms/dexter/gopigo3 )
2017-06-15 14:38:21 +08:00
- [Intel Curie ](https://www.intel.com/content/www/us/en/products/boards-kits/curie.html ) < => [Package ](https://github.com/hybridgroup/gobot/tree/master/platforms/intel-iot/curie )
2016-12-08 21:07:43 +08:00
- [Intel Edison ](http://www.intel.com/content/www/us/en/do-it-yourself/edison.html ) < => [Package ](https://github.com/hybridgroup/gobot/tree/master/platforms/intel-iot/edison )
- [Intel Joule ](http://intel.com/joule/getstarted ) < => [Package ](https://github.com/hybridgroup/gobot/tree/master/platforms/intel-iot/joule )
- [Joystick ](http://en.wikipedia.org/wiki/Joystick ) < => [Package ](https://github.com/hybridgroup/gobot/tree/master/platforms/joystick )
- [Keyboard ](https://en.wikipedia.org/wiki/Computer_keyboard ) < => [Package ](https://github.com/hybridgroup/gobot/tree/master/platforms/keyboard )
- [Leap Motion ](https://www.leapmotion.com/ ) < => [Package ](https://github.com/hybridgroup/gobot/tree/master/platforms/leapmotion )
- [MavLink ](http://qgroundcontrol.org/mavlink/start ) < => [Package ](https://github.com/hybridgroup/gobot/tree/master/platforms/mavlink )
- [MegaPi ](http://www.makeblock.com/megapi ) < => [Package ](https://github.com/hybridgroup/gobot/tree/master/platforms/megapi )
2017-03-19 00:25:17 +08:00
- [Microbit ](http://microbit.org/ ) < => [Package ](https://github.com/hybridgroup/gobot/tree/master/platforms/microbit )
2016-12-08 21:07:43 +08:00
- [MQTT ](http://mqtt.org/ ) < => [Package ](https://github.com/hybridgroup/gobot/tree/master/platforms/mqtt )
- [NATS ](http://nats.io/ ) < => [Package ](https://github.com/hybridgroup/gobot/tree/master/platforms/nats )
- [Neurosky ](http://neurosky.com/products-markets/eeg-biosensors/hardware/ ) < => [Package ](https://github.com/hybridgroup/gobot/tree/master/platforms/neurosky )
- [OpenCV ](http://opencv.org/ ) < => [Package ](https://github.com/hybridgroup/gobot/tree/master/platforms/opencv )
- [Particle ](https://www.particle.io/ ) < => [Package ](https://github.com/hybridgroup/gobot/tree/master/platforms/particle )
- [Parrot ARDrone 2.0 ](http://ardrone2.parrot.com/ ) < => [Package ](https://github.com/hybridgroup/gobot/tree/master/platforms/parrot/ardrone )
- [Parrot Bebop ](http://www.parrot.com/usa/products/bebop-drone/ ) < => [Package ](https://github.com/hybridgroup/gobot/tree/master/platforms/parrot/bebop )
- [Parrot Minidrone ](https://www.parrot.com/us/minidrones ) < => [Package ](https://github.com/hybridgroup/gobot/tree/master/platforms/parrot/minidrone )
- [Pebble ](https://www.getpebble.com/ ) < => [Package ](https://github.com/hybridgroup/gobot/tree/master/platforms/pebble )
- [Raspberry Pi ](http://www.raspberrypi.org/ ) < => [Package ](https://github.com/hybridgroup/gobot/tree/master/platforms/raspi )
- [Sphero ](http://www.sphero.com/ ) < => [Package ](https://github.com/hybridgroup/gobot/tree/master/platforms/sphero )
2016-12-19 23:21:47 +08:00
- [Sphero BB-8 ](http://www.sphero.com/bb8 ) < => [Package ](https://github.com/hybridgroup/gobot/tree/master/platforms/sphero/bb8 )
2017-10-31 22:15:55 +08:00
- [Sphero Ollie ](http://www.sphero.com/ollie ) < => [Package ](https://github.com/hybridgroup/gobot/tree/master/platforms/sphero/ollie )
- [Sphero SPRK+ ](http://www.sphero.com/sprk-plus ) < => [Package ](https://github.com/hybridgroup/gobot/tree/master/platforms/sphero/sprkplus )
2017-04-27 19:03:40 +08:00
- [Tinker Board ](https://www.asus.com/us/Single-Board-Computer/Tinker-Board/ ) < => [Package ](https://github.com/hybridgroup/gobot/tree/master/platforms/tinkerboard )
2017-12-13 16:55:16 +08:00
- [UP2 ](http://www.up-board.org/upsquared/ ) < => [Package ](https://github.com/hybridgroup/gobot/tree/master/platforms/upboard/up2 )
2013-12-14 00:54:30 +08:00
Support for many devices that use General Purpose Input/Output (GPIO) have
2016-09-26 03:22:25 +08:00
a shared set of drivers provided using the `gobot/drivers/gpio` package:
2013-12-14 00:54:30 +08:00
2016-12-08 21:07:43 +08:00
- [GPIO ](https://en.wikipedia.org/wiki/General_Purpose_Input/Output ) < => [Drivers ](https://github.com/hybridgroup/gobot/tree/master/drivers/gpio )
2015-10-23 08:45:08 +08:00
- Button
2016-05-14 06:24:11 +08:00
- Buzzer
2015-10-23 08:45:08 +08:00
- Direct Pin
- Grove Button
- Grove Buzzer
- Grove LED
2016-10-31 05:41:21 +08:00
- Grove Magnetic Switch
2015-10-23 08:45:08 +08:00
- Grove Relay
- Grove Touch Sensor
- LED
- Makey Button
- Motor
2016-10-22 21:17:49 +08:00
- Proximity Infra Red (PIR) Motion Sensor
2016-05-14 06:24:11 +08:00
- Relay
- RGB LED
2015-10-23 08:45:08 +08:00
- Servo
2017-12-07 14:40:46 +08:00
- Stepper Motor
2013-11-10 02:51:30 +08:00
2016-12-20 20:37:51 +08:00
Support for many devices that use Analog Input/Output (AIO) have
a shared set of drivers provided using the `gobot/drivers/aio` package:
2016-12-20 20:47:41 +08:00
- [AIO ](https://en.wikipedia.org/wiki/Analog-to-digital_converter ) < => [Drivers ](https://github.com/hybridgroup/gobot/tree/master/drivers/aio )
2016-12-20 20:37:51 +08:00
- Analog Sensor
- Grove Light Sensor
- Grove Piezo Vibration Sensor
- Grove Rotary Dial
- Grove Sound Sensor
- Grove Temperature Sensor
2013-12-17 06:20:21 +08:00
Support for devices that use Inter-Integrated Circuit (I2C) have a shared set of
2016-09-26 03:22:25 +08:00
drivers provided using the `gobot/drivers/i2c` package:
2013-12-17 06:20:21 +08:00
2016-12-08 21:07:43 +08:00
- [I2C ](https://en.wikipedia.org/wiki/I%C2%B2C ) < => [Drivers ](https://github.com/hybridgroup/gobot/tree/master/drivers/i2c )
2016-10-31 05:41:21 +08:00
- Adafruit Motor Hat
2017-04-24 23:58:30 +08:00
- ADS1015 Analog to Digital Converter
2017-04-27 22:13:29 +08:00
- ADS1115 Analog to Digital Converter
2017-01-03 17:22:06 +08:00
- BlinkM LED
2017-04-01 05:12:38 +08:00
- BME280 Barometric Pressure/Temperature/Altitude/Humidity Sensor
2017-01-03 17:22:06 +08:00
- BMP180 Barometric Pressure/Temperature/Altitude Sensor
2017-04-01 05:12:38 +08:00
- BMP280 Barometric Pressure/Temperature/Altitude Sensor
2017-02-24 15:19:20 +08:00
- DRV2605L Haptic Controller
2015-10-23 08:45:08 +08:00
- Grove Digital Accelerometer
- Grove RGB LCD
2016-02-10 09:03:51 +08:00
- HMC6352 Compass
2017-05-05 15:27:08 +08:00
- INA3221 Voltage Monitor
2017-01-03 17:22:06 +08:00
- JHD1313M1 LCD Display w/RGB Backlight
- L3GD20H 3-Axis Gyroscope
2017-02-24 15:19:20 +08:00
- LIDAR-Lite
2016-02-10 09:03:51 +08:00
- MCP23017 Port Expander
- MMA7660 3-Axis Accelerometer
- MPL115A2 Barometer
- MPU6050 Accelerometer/Gyroscope
2017-06-24 02:18:02 +08:00
- PCA9685 16-channel 12-bit PWM/Servo Driver
2017-01-03 17:21:09 +08:00
- SHT3x-D Temperature/Humidity
2017-04-01 05:12:38 +08:00
- SSD1306 OLED Display Controller
2017-02-24 15:19:20 +08:00
- TSL2561 Digital Luminosity/Lux/Light Sensor
2015-10-23 08:45:08 +08:00
- Wii Nunchuck Controller
2013-12-17 06:20:21 +08:00
2013-11-10 02:51:30 +08:00
More platforms and drivers are coming soon...
2013-11-25 07:59:36 +08:00
## API:
Gobot includes a RESTful API to query the status of any robot running within a group, including the connection and device status, and execute device commands.
2016-12-08 21:07:43 +08:00
To activate the API, import the `gobot.io/x/gobot/api` package and instantiate the `API` like this:
2013-11-25 07:59:36 +08:00
2014-11-04 09:38:20 +08:00
```go
2016-10-16 02:02:54 +08:00
master := gobot.NewMaster()
api.NewAPI(master).Start()
2013-11-25 07:59:36 +08:00
```
2014-04-20 01:16:44 +08:00
You can also specify the api host and port, and turn on authentication:
2014-11-04 09:38:20 +08:00
```go
2016-10-16 02:02:54 +08:00
master := gobot.NewMaster()
server := api.NewAPI(master)
2014-06-09 11:28:17 +08:00
server.Port = "4000"
2016-01-11 09:35:30 +08:00
server.AddHandler(api.BasicAuth("gort", "klatuu"))
2014-06-09 11:28:17 +08:00
server.Start()
2013-11-25 07:59:36 +08:00
```
2013-11-10 02:51:30 +08:00
2016-12-08 21:07:43 +08:00
You may access the [robeaux ](https://github.com/hybridgroup/robeaux ) React.js interface with Gobot by navigating to `http://localhost:3000/index.html` .
2014-02-05 06:15:21 +08:00
2016-10-08 16:40:17 +08:00
## CLI
Gobot uses the Gort [http://gort.io ](http://gort.io ) Command Line Interface (CLI) so you can access important features right from the command line. We call it "RobotOps", aka "DevOps For Robotics". You can scan, connect, update device firmware, and more!
2016-12-19 20:43:32 +08:00
Gobot also has its own CLI to generate new platforms, adaptors, and drivers. You can check it out in the `/cli` directory.
2016-10-08 16:40:17 +08:00
2013-11-10 02:51:30 +08:00
## Documentation
2017-12-07 14:40:46 +08:00
We're always adding documentation to our web site at http://gobot.io/ please check there as we continue to work on Gobot
2013-11-10 02:51:30 +08:00
Thank you!
2015-01-15 18:52:07 +08:00
## Need help?
* Join our mailing list: https://groups.google.com/forum/#!forum/gobotio
2016-12-08 21:07:43 +08:00
* Issues: https://github.com/hybridgroup/gobot/issues
2015-01-17 01:57:10 +08:00
* twitter: [@gobotio ](https://twitter.com/gobotio )
2015-01-15 18:52:07 +08:00
2013-11-10 02:51:30 +08:00
## Contributing
2016-12-08 21:07:43 +08:00
For our contribution guidelines, please go to [https://github.com/hybridgroup/gobot/blob/master/CONTRIBUTING.md
](https://github.com/hybridgroup/gobot/blob/master/CONTRIBUTING.md
2015-06-23 09:13:07 +08:00
).
2013-11-10 02:51:30 +08:00
2017-02-27 02:43:06 +08:00
Gobot is released with a Contributor Code of Conduct. By participating in this project you agree to abide by its terms. [You can read about it here ](https://github.com/hybridgroup/gobot/tree/master/CODE_OF_CONDUCT.md ).
2013-11-10 02:51:30 +08:00
## License
2017-01-03 05:25:17 +08:00
Copyright (c) 2013-2017 The Hybrid Group. Licensed under the Apache 2.0 license.
2017-02-27 02:43:06 +08:00
The Contributor Covenant is released under the Creative Commons Attribution 4.0 International Public License, which requires that attribution be included.