This module provides an interface to the Altbeacon library for Android. It was modified from the Liferay module that used the RadiusNetwork iBeacon library for Android.
To access this module from JavaScript, you would do the following:
var Altbeacon = require("com.drtech.altbeacon");
Check if Bluetooth LE is supported by this Android device. Doesn't matter if it's enabled or disabled.
Check if Bluetooth LE is supported by this Android device, and if so, make sure it is enabled.
Binds the Android application context to the BeaconService provided by the library. If a custom BeaconParser is required, make sure the parser is added BEFORE calling this method.
Unbinds the BeaconService binded with Altbeacon.bindBeaconService()
. See description of bindBeaconService for more details.
Checks the beacon service is binded to the current application context. See description of bindBeaconService for more details.
Throttles down Altbeacon library when app placed in background. By default the library starts up with backgroundmode false
. It's possible to change this onPause
and onResume
in the currentActivity
.
Turns on auto ranging. When auto ranging is on, upon entering a region, this module will automatically begin ranging for beacons within that region, and stop ranging for beacons when the region is exited. Note ranging requires more battery power so care should be taken with this setting.
Turns off auto ranging. See description of enableAutoRanging for more details.
Turns auto ranging on or off. See description of enableAutoRanging for more details.
Set this property to true
if the module is used inside a Service. If this value is false
, it's unbinding the BeaconService
on exiting the root activity automatically. If this value equals to true
, it's not unbinding onDestroy
, but you have to unBind the service manually ontaskremoved
.
Returns the value sets earlier at the Altbeacon.setRunInService()
method. Default: false
.
Set the exit region period in milliseconds
Set the scan periods for the bluetooth scanner.
Structure of scanPeriods:
{
foregroundScanPeriod: MILLISECONDS,
foregroundBetweenScanPeriod: MILLISECONDS,
backgroundScanPeriod: MILLISECONDS,
backgroundBetweenScanPeriod: MILLISECONDS
}
If this method is not called, the following are the defaults:
{
foregroundScanPeriod: 1200,
foregroundBetweenScanPeriod: 2300,
backgroundScanPeriod: 10000,
backgroundBetweenScanPeriod: 60000
}
Start monitoring a region. Will trigger events 'enteredRegion', 'exitedRegion', and 'determinedRegionState'.
Structure of a region:
{
identifier: 'Some arbitrary ID',
uuid: '00000000-0000-0000-0000-000000000000',
major: INT or null,
minor: INT or null
}
Compatibility method for popular iOS FOSS iBeacon library. See startRangingForRegion for further details.
Start ranging a region. You can only range regions into which you have entered. Will fire the event 'beaconProximity' for each scan. See startMonitoringForRegion for the structure of a region.
Stop monitoring everything.
Stop ranging everything.
Add BeaconParser described by layout to the manager. This method MUST be called before calling bindBeaconService or it will fail.
Remove BeaconParser described by layout from the manager. This method MUST be called before calling bindBeaconService or it will fail.
Allows the user to customize the proximity bounds. These bounds are used for approximate distances from a beacon.
Data structure:
{
far: METERS,
near: METERS,
immediate: METERS
}
Starts broadcasting as a Beacon. The parameters required are described below. This method is completely untested.
Data structure:
{
uuid: 00000000-0000-0000-000000000000,
major: INT,
minor: INT,
mfrid: INT,
txpower: INT,
data: [INT, INT, ...] or NULL,
layout: BeaconParserLayout
}
Stops Beacon advertising - as with startBeaconAdvertisement, this method is also completely untested.
var TiBeacons = null;
if (Ti.Platform.name == "android") {
TiBeacons = require('com.drtech.altbeacon');
TiBeacons.addBeaconLayout("m:2-3=0215,i:4-19,i:20-21,i:22-23,p:24-24");
TiBeacons.bindBeaconService();
label.text = "module is => " + TiBeacons + "and checkAvailability says: " + TiBeacons.checkAvailability();
} else {
label.text = "com.drtech.altbeacon not supported on " + Ti.Platform.name;
}
David Kopczyk dwk5123@gmail.com
Licensed under the Apache 2.0 license. Modifications Copyright 2015 David Kopczyk.