Skip to content

Latest commit

 

History

History
157 lines (103 loc) · 4.69 KB

README.md

File metadata and controls

157 lines (103 loc) · 4.69 KB

NOTICE: This plugin is not being maintained anymore. Please use the new plugin that's updated for Gimbal v2 SDK and compatible with both iOS and Android. The new plugin is located at https://github.com/happydenn/cordova-plugin-gimbal2

Cordova Gimbal Plugin

A Cordova plugin for scanning and interacting with Qualcomm Gimbal beacons.

Supported Platforms

  • iOS (7.1 and above)

Supported SDK Features

  • Proximity service
  • Sightings scanning

Requirements

  • Gimbal Manager account
  • Gimbal SDK (The latest version can be obtained from Gimbal Manager web app)

Installation

Plugin Setup

cordova plugin add io.hpd.cordova.gimbal

Or, alternatively you can install the bleeding edge version from Github:

cordova plugin add https://github.com/happydenn/cordova-plugin-gimbal.git

Gimbal SDK Setup

From the Gimbal SDK, drag and drop the following frameworks from the Frameworks folder to the Frameworks group inside the Xcode project. Be sure to copy the files when asked by Xcode.

Common.embeddedframework
ContextCore.embeddedframework
ContextLocation.embeddedframework
FYX.framework
NetworkServices.embeddedframework

Add the following to your project's Info.plist to enable using Bluetooth beacons in background mode.

<key>UIBackgroundModes</key>
<array>
    <string>bluetooth-central</string>
</array>

Finally for iOS 8 and later, you need to add a new entry to your Xcode project's Info.plist to properly request for permission to use the location service which is required by Gimbal SDK.

<key>NSLocationAlwaysUsageDescription</key>
<string>Specifies the reason for accessing the user's location information.</string>

Usage

The plugin's API is contained inside the Gimbal object, which is not available until after the deviceready event.

To be able to use the Gimbal SDK, first you need to start the service. Call the following function with your App ID, App Secret and Callback URL to start the service. (You can get the credentials by creating a new app in Gimbal Manager.)

// Gimbal is not available until deviceready
document.addEventListener('deviceready', function() {
	Gimbal.startService('appId', 'appSecret', 'callback://url', function() {
		// service started
		// ...
	}, function() {
		// service not started
		// ...
	});
}, false);

After the service has started, you then need to add the callback that will be called every time a Gimbal is sighted. You should register the callback before you call startScanSightings.

Finally, after you have registered the callback, simply call startScanSightings to start monitoring Gimbal beacons!

Below is a complete example that will start scanning for beacons right after deviceready event.

// Gimbal is not available until deviceready
document.addEventListener('deviceready', function() {
	Gimbal.startService('appId', 'appSecret', 'callback://url', function() {
		// register callback before starting
		Gimbal.didReceiveSighting(function(result) {
			console.log(result); // log the result
		});

		// start scanning
		Gimbal.startScanSightings();
	});
}, false);

TODO

Plugin API

Gimbal.startService(appId, appSecret, callbackUrl, success[, failed])

Start Gimbal service with specified credentials.

  • appId: Application ID
  • appSecret: Application secret
  • callbackUrl: Callback URL
  • success: Callback function that runs after the service has started
  • failed: Callback function that runs after the service has failed to start

Gimbal.stopService()

Stop Gimbal service.

Gimbal.startScanSightings([smoothWindow])

Start scanning for beacon sightings. (Must be called after the service has started.)

Gimbal.didReceiveSighting(callback)

Register a callback function that is called every time a beacon is sighted.

  • callback: Callback function to be called. Takes one result argument that contains the sighting result.

Sighting result object

  • transmitter: An object containing information about the sighted beacon.
    • identifier
    • name
    • ownerId
    • iconUrl
    • battery
    • temperature
  • time: Time when the sighting occured.
  • RSSI: Signal strength of the sighting.

Gimbal.stopScanSightings()

Stop scanning for beacon sightings.