Espruino:Справочник по API/Класс NRF/connect(): различия между версиями
Нет описания правки |
Нет описания правки |
||
Строка 7: | Строка 7: | ||
==Синтаксис== | ==Синтаксис== | ||
<syntaxhighlight lang="javascript | <syntaxhighlight lang="javascript"> | ||
NRF.connect(mac, options) | NRF.connect(mac, options) | ||
</syntaxhighlight> | </syntaxhighlight> | ||
Строка 24: | Строка 24: | ||
Подключается к BLE-устройству по MAC-адресу. Возвращает промис, аргументом которого будет соединение типа [https://www.espruino.com/Reference#BluetoothRemoteGATTServer BluetoothRemoteGATTServer]. | Подключается к BLE-устройству по MAC-адресу. Возвращает промис, аргументом которого будет соединение типа [https://www.espruino.com/Reference#BluetoothRemoteGATTServer BluetoothRemoteGATTServer]. | ||
<syntaxhighlight lang="javascript | <syntaxhighlight lang="javascript"> | ||
NRF.connect("aa:bb:cc:dd:ee").then(function(server) { | NRF.connect("aa:bb:cc:dd:ee").then(function(server) { | ||
// ... | // ... | ||
Строка 34: | Строка 34: | ||
Вы можете использовать ее как показано в примере ниже. В нем вы подключаетесь к другому Puck и включаете его [[светодиод]]: | Вы можете использовать ее как показано в примере ниже. В нем вы подключаетесь к другому Puck и включаете его [[светодиод]]: | ||
<syntaxhighlight lang="javascript | <syntaxhighlight lang="javascript"> | ||
var gatt; | var gatt; | ||
NRF.connect("aa:bb:cc:dd:ee random").then(function(g) { | NRF.connect("aa:bb:cc:dd:ee random").then(function(g) { |
Версия от 19:59, 23 мая 2023
Функция NRF.connect()[1]
Синтаксис
NRF.connect(mac, options)
Параметры
- mac – MAC-адрес, к которому надо подключиться
- options – объект с настройками подключения (специфичный для Espruino). Более подробно читайте в описании функции BluetoothRemoteGATTServer.connect()
Возвращаемое значение
Промис (Promise) с состоянием «выполнено успешно» (или «выполнено с ошибкой») после попытки соединения.
Описание
Подключается к BLE-устройству по MAC-адресу. Возвращает промис, аргументом которого будет соединение типа BluetoothRemoteGATTServer.
NRF.connect("aa:bb:cc:dd:ee").then(function(server) {
// ...
});
Эта функция имеет тот же эффект, что и вызов BluetoothDevice.gatt.connect на BluetoothDevice, запрошенном при помощи NRF.requestDevice(). Эта функция лишь позволяет вам задать адрес напрямую (без сканирования).
Вы можете использовать ее как показано в примере ниже. В нем вы подключаетесь к другому Puck и включаете его светодиод:
var gatt;
NRF.connect("aa:bb:cc:dd:ee random").then(function(g) {
gatt = g;
return gatt.getPrimaryService("6e400001-b5a3-f393-e0a9-e50e24dcca9e");
}).then(function(service) {
return service.getCharacteristic("6e400002-b5a3-f393-e0a9-e50e24dcca9e");
}).then(function(characteristic) {
return characteristic.writeValue("LED1.set()\n");
}).then(function() {
gatt.disconnect();
console.log("Готово!");
});
Примечание: Bluetooth-устройства Espruino используют «случайный статический» тип BLE-адреса (который отличается от «публичного» адреса). Чтобы подключиться к Espruino, вам нужно будет воспользоваться адресной строкой в формате "aa:bb:cc:dd:ee random", а не просто "aa:bb:cc:dd:ee". Если вы просканируете устройства при помощи NRF.findDevices() или NRF.setScan(), то адреса будут сразу возвращены в корректном формате.
Примечание: Эта функция доступна только для NRF52-устройств (вроде Puck.js, Pixl.js, Bangle.js и MDBT42Q) и ESP32-плат.
Примеры
См.также
Внешние ссылки