SwiftyZorb
iOS development kit for integrating with the Somatic Zorb Engine
About
SwiftyZorb allows developers to build iOS applications that communicate with devices powered by Somatic Labs’ Zorb Engine, enabling new user experiences that allow communication entirely through your sense of touch.
This library is made to be used in conjuction with our embedded Javascript SDK. To get started developing your own haptic animations, check out our Zorb Design Studio.
Animations and programs created in the design studio can be ran on ZorbEngine powered devices using this library, either by sending a embedding the Javascript directly in your application or by storing your scripts somewhere with a publicly accessible URL (such as in a Github gist) that can be referenced from within your application.
For a quick reference to the SwiftyZorb documents, please refer to this guide.
Requirements
- iOS 9.0+
- Xcode 8.1+
- Swift 4.0+
Troubleshooting & Contributions
- If you need help, send us an email.
- If you’d like to ask a general question, send us an email.
- If you found a bug, open an issue.
- If you have a feature request, open an issue.
- If you want to contribute, submit a pull request.
Installation
Carthage
Carthage is a decentralized dependency manager that builds your dependencies and provides you with binary frameworks.
You can install Carthage with Homebrew using the following command:
$ brew update
$ brew install carthage
To integrate SwiftyZorb into your Xcode project using Carthage, specify it in your Cartfile
:
github "SomaticLabs/SwiftyZorb" ~> 3.0
Run carthage update
to build the framework and drag the built SwiftyZorb.framework
into your Xcode project.
You must also drag the built dependencies Alamofire.framework
, SwiftyBluetooth.framework
, SwiftyJSON.framework
, and SwiftProtobuf.framework
into your project.
Single Device Usage
There are two ways to use this libary. If you intend to connect and reconnect to one Zorb peripheral device, use the following methods.
Connecting
Before being able to communicate with a Zorb peripheral device, you must establish a Bluetooth LE connection with your device.
The withVersion
parameter is used to specify which version of Zorb hardware you are using. If you are unsure which hardware you have, please contact us.
import SwiftyZorb
SwiftyZorb.connect(withVersion: .V2) { result in
switch result {
case .success:
// Connected succeeded
case .failure(let error):
// An error occurred during connection
}
}
If you would like to trigger a manual disconnect, you can do so like this:
SwiftyZorb.disconnect()
After connecting to a device for the first time, the SwiftyZorb saves a reference to that device for quicker reconnection in the future. If you would like to connect to a new device, you must forget the old connection.
SwiftyZorb.forget()
Note that simply disconnecting from the device will not forget a stored connection and, likewise, forgetting a connection will not force a disconnect.
Sending Protocol Buffers
You can send a haptic timeline to the device as a protocol buffer.
To send a protocol buffer:
// Create Zorb_Timeline and Zorb_Vibration objects using the generated types provided by zorb.pb.swift.
var timeline = Zorb_Timeline()
var vibration = Zorb_Vibration()
// Populate data in the Zorb_Vibration object.
vibration.channels = 0x01
vibration.delay = 1000
vibration.duration = 2000
vibration.position = 0
vibration.start = 0
vibration.end = 100
vibration.easing = 2
// Append the Zorb_Vibration to the Zorb_Timeline.
timeline.vibrations.append(vibration)
// Write the bytecode to the UART RX characteristic.
SwiftyZorb.writeTimeline(timeline) { result in
switch result {
case .success:
// Write succeeded
case .failure(let error):
// An error occurred during write
}
}
Sending Javascript
There are two ways to send Javascript to be executed on the device—by embedding it as a String
in your application, or by passing a URL
to a hosted file such as a Github Gist that contains your code.
To send Javascript from a String
in your application:
let javascript = "new Zorb.Vibration(" +
"0," +
"new Zorb.Effect(0,100,11,250)," +
"213" +
").start();"
SwiftyZorb.writeJavascript(javascript) { result in
switch result {
case .success:
// Write succeeded
case .failure(let error):
// An error occurred during write
}
}
To send Javascript from a script saved in file hosted online:
let url = URL(string: "https://gist.githubusercontent.com/jakerockland/17cb9cbfda0e09fa8251fc7666e2c4dc/raw")!
SwiftyZorb.writeJavascript(at url) { result in
switch result {
case .success:
// Write succeeded
case .failure(let error):
// An error occurred during write
}
}
Using the two above methods will always require an HTTP request to the ZorbSDK Javascript compiler, which produces the Javascript bytecode that is executed on the Zorb device’s internal virtual machine. If you would like to avoid this HTTP request, you can send pre-compiled bytecode instead.
To send pre-compiled Javascript bytecode as a base64 encoded String
in your application:
let bytecode = "BgAAAFAAAAAsAAAAAQAAAAQAAQABAAUAAAEDBAYAAQACAAYAOwABKQIDxEYBAAAABAABACEAAwABAgMDAAAGAAgAOwECt8gARgAAAAAAAAAFAAAAAAAAAAIAb24JAHRpbWVydGljawABAHQABgBNb21lbnQGAHVwdGltZQ=="
SwiftyZorb.writeBytecode(bytecode) { result in
switch result {
case .success:
// Write succeeded
case .failure(let error):
// An error occurred during write
}
}
To reset the Zorb device’s Javascript virtual machine:
SwiftyZorb.reset { result in
switch result {
case .success:
// Reset succeeded
case .failure(let error):
// An error occurred during reset
}
}
Multiple Device Usage
If you would like to manage connections with multiple Zorb peripheral devices, you may do so by first retrieving a list of the available devices:
// Retrieves a list all available devices as an array of `ZorbDevice` objects.
SwiftyZorb.retrieveAvailableDevices(withVersion: .V2) { result in
switch result {
case .success(let devices):
// Retrieval succeeded
for device in devices {
// Do something with devices
}
case .failure(let error):
// An error occurred during retrieval
}
}
After filtering for the devices of interest, a given device can be connected to and intereacted with using commands similar to those used in the single-device usage.
For example, to connect and send a pattern at a given url:
// Create a `ZorbDevice` object for a given Bluetooth peripheral (or this object may have
// already been created as in the case of using `retrieveAvailableDevices` method of SDK
let device = ZorbDevice(with: peripheral)
// Attempts connection to an advertising device
device.connect { result in
switch result {
case .success:
// Connect succeeded
// Write Javascript from url to device
let url = URL(string: "https://gist.githubusercontent.com/jakerockland/17cb9cbfda0e09fa8251fc7666e2c4dc/raw")!
device.writeJavascript(at url) { result in
switch result {
case .success:
// Write succeeded
case .failure(let error):
// An error occurred during write
}
}
case .failure(let error):
// An error occurred during connection
}
}
Style Guide
Contributions to this project should conform to the Swift API Design Guidelines and this style guide.
Documentation
To learn about code documentation for Swift, check out this guide
We build our documentation pages with Jazzy, to create docs from your well commented code, just run jazzy
License
The SwiftyZorb is released under the GPL license.
Contact us for a commercial license if the GPL does not work well for your use cases.