mirror of
https://github.com/jam422470459/EPD-nRF52-hema213.git
synced 2025-12-06 16:42:49 +08:00
send epd config on connect
This commit is contained in:
@@ -60,7 +60,7 @@ static void epd_config_load(epd_config_t *cfg)
|
||||
static void epd_config_save(epd_config_t *cfg)
|
||||
{
|
||||
nrf_nvmc_page_erase(BLE_EPD_CONFIG_ADDR);
|
||||
nrf_nvmc_write_words(BLE_EPD_CONFIG_ADDR, (uint32_t*)cfg, sizeof(epd_config_t) / sizeof(uint32_t));
|
||||
nrf_nvmc_write_bytes(BLE_EPD_CONFIG_ADDR, (uint8_t*)cfg, sizeof(epd_config_t) / sizeof(uint8_t));
|
||||
}
|
||||
|
||||
/**@brief Function for handling the @ref BLE_GAP_EVT_CONNECTED event from the S110 SoftDevice.
|
||||
@@ -178,6 +178,7 @@ static void on_write(ble_epd_t * p_epd, ble_evt_t * p_ble_evt)
|
||||
if (ble_srv_is_notification_enabled(p_evt_write->data))
|
||||
{
|
||||
p_epd->is_notification_enabled = true;
|
||||
ble_epd_string_send(p_epd, (uint8_t *)&p_epd->config, sizeof(epd_config_t));
|
||||
}
|
||||
else
|
||||
{
|
||||
|
||||
@@ -26,14 +26,14 @@
|
||||
/**< EPD Service Configs */
|
||||
typedef struct
|
||||
{
|
||||
uint32_t mosi_pin;
|
||||
uint32_t sclk_pin;
|
||||
uint32_t cs_pin;
|
||||
uint32_t dc_pin;
|
||||
uint32_t rst_pin;
|
||||
uint32_t busy_pin;
|
||||
uint32_t bs_pin;
|
||||
uint32_t driver_id;
|
||||
uint8_t mosi_pin;
|
||||
uint8_t sclk_pin;
|
||||
uint8_t cs_pin;
|
||||
uint8_t dc_pin;
|
||||
uint8_t rst_pin;
|
||||
uint8_t busy_pin;
|
||||
uint8_t bs_pin;
|
||||
uint8_t driver_id;
|
||||
} epd_config_t;
|
||||
|
||||
/**< EPD Service command IDs. */
|
||||
|
||||
@@ -27,12 +27,12 @@
|
||||
<div style="float: right;">
|
||||
驱动:
|
||||
<select id="epddriver">
|
||||
<option value="01" selected="selected">EPD_4in2</option>
|
||||
<option value="01">EPD_4in2</option>
|
||||
<option value="02">EPD_4in2_V2</option>
|
||||
<option value="03">EPD_4in2b_V2</option>
|
||||
</select>
|
||||
引脚:
|
||||
<input id="epdpins" type="text" value="0508090A0B0C0D">
|
||||
<input id="epdpins" type="text" value="">
|
||||
<button id="setDriverbutton" type="button" onclick="setDriver();">确认</button>
|
||||
</div>
|
||||
<button id="connectbutton" type="button" onclick="preConnect();">连接</button>
|
||||
|
||||
@@ -1,7 +1,7 @@
|
||||
let bleDevice;
|
||||
let gattServer;
|
||||
let Theservice;
|
||||
let writeCharacteristic;
|
||||
let epdService;
|
||||
let epdCharacteristic;
|
||||
let reconnectTrys = 0;
|
||||
|
||||
let canvas;
|
||||
@@ -10,29 +10,29 @@ let chunkSize = 38;
|
||||
|
||||
function resetVariables() {
|
||||
gattServer = null;
|
||||
Theservice = null;
|
||||
writeCharacteristic = null;
|
||||
epdService = null;
|
||||
epdCharacteristic = null;
|
||||
document.getElementById("log").value = '';
|
||||
}
|
||||
|
||||
function handleError(error) {
|
||||
async function handleError(error) {
|
||||
console.log(error);
|
||||
resetVariables();
|
||||
if (bleDevice == null)
|
||||
return;
|
||||
if (reconnectTrys <= 5) {
|
||||
reconnectTrys++;
|
||||
connect();
|
||||
await connect();
|
||||
}
|
||||
else {
|
||||
addLog("Was not able to connect, aborting");
|
||||
addLog("连接失败!");
|
||||
reconnectTrys = 0;
|
||||
}
|
||||
}
|
||||
|
||||
async function sendCommand(cmd) {
|
||||
if (writeCharacteristic) {
|
||||
await writeCharacteristic.writeValue(cmd);
|
||||
if (epdCharacteristic) {
|
||||
await epdCharacteristic.writeValue(cmd);
|
||||
} else {
|
||||
addLog("服务不可用,请检查蓝牙连接");
|
||||
}
|
||||
@@ -40,7 +40,7 @@ async function sendCommand(cmd) {
|
||||
|
||||
async function sendcmd(cmdTXT) {
|
||||
let cmd = hexToBytes(cmdTXT);
|
||||
addLog('Send CMD: ' + cmdTXT);
|
||||
addLog(`发送命令: ${cmdTXT}`);
|
||||
await sendCommand(cmd);
|
||||
}
|
||||
|
||||
@@ -67,10 +67,9 @@ async function sendIMGArray(imgArray, type = 'bw'){
|
||||
for (let i = 0; i < imgArray.length; i += chunkSize) {
|
||||
let currentTime = (new Date().getTime() - startTime) / 1000.0;
|
||||
let chunk = imgArray.substring(i, i + chunkSize);
|
||||
setStatus('正在发送' + (type === 'bwr' ? "红色" : '黑白') + '块: '
|
||||
+ (chunkIdx+1) + "/" + (count+1) + ", 用时: " + currentTime + "s");
|
||||
addLog('Sending chunk: ' + chunk);
|
||||
await sendCommand(hexToBytes("04" + chunk))
|
||||
setStatus(`发送${type === 'bwr' ? "红色" : '黑白'}块: ${chunkIdx+1}/${count+1}, 用时: ${currentTime}s`);
|
||||
addLog(`发送块: ${chunk}`);
|
||||
await sendCommand(hexToBytes(`04${chunk}`))
|
||||
chunkIdx++;
|
||||
}
|
||||
}
|
||||
@@ -93,8 +92,8 @@ async function sendimg(cmdIMG) {
|
||||
await sendcmd("05");
|
||||
|
||||
let sendTime = (new Date().getTime() - startTime) / 1000.0;
|
||||
addLog("Done! Time used: " + sendTime + "s");
|
||||
setStatus("发送完成!耗时: " + sendTime + "s");
|
||||
addLog(`发送完成!耗时: ${sendTime}s`);
|
||||
setStatus(`发送完成!耗时: ${sendTime}s`);
|
||||
|
||||
await sendcmd("06");
|
||||
}
|
||||
@@ -110,55 +109,62 @@ function updateButtonStatus() {
|
||||
|
||||
function disconnect() {
|
||||
resetVariables();
|
||||
addLog('Disconnected.');
|
||||
addLog('已断开连接.');
|
||||
document.getElementById("connectbutton").innerHTML = '连接';
|
||||
updateButtonStatus();
|
||||
}
|
||||
|
||||
function preConnect() {
|
||||
async function preConnect() {
|
||||
if (gattServer != null && gattServer.connected) {
|
||||
if (bleDevice != null && bleDevice.gatt.connected)
|
||||
bleDevice.gatt.disconnect();
|
||||
}
|
||||
else {
|
||||
connectTrys = 0;
|
||||
navigator.bluetooth.requestDevice({
|
||||
bleDevice = await navigator.bluetooth.requestDevice({
|
||||
optionalServices: ['62750001-d828-918d-fb46-b6c11c675aec'],
|
||||
acceptAllDevices: true
|
||||
}).then(device => {
|
||||
device.addEventListener('gattserverdisconnected', disconnect);
|
||||
bleDevice = device;
|
||||
connect();
|
||||
}).catch(handleError);
|
||||
});
|
||||
await bleDevice.addEventListener('gattserverdisconnected', disconnect);
|
||||
try {
|
||||
await connect();
|
||||
} catch (e) {
|
||||
await handleError(e);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
function reConnect() {
|
||||
async function reConnect() {
|
||||
connectTrys = 0;
|
||||
if (bleDevice != null && bleDevice.gatt.connected)
|
||||
bleDevice.gatt.disconnect();
|
||||
resetVariables();
|
||||
addLog("Reconnect");
|
||||
setTimeout(function () { connect(); }, 300);
|
||||
addLog("正在重连");
|
||||
setTimeout(async function () { await connect(); }, 300);
|
||||
}
|
||||
|
||||
function connect() {
|
||||
if (writeCharacteristic == null) {
|
||||
addLog("Connecting to: " + bleDevice.name);
|
||||
bleDevice.gatt.connect().then(server => {
|
||||
addLog('> Found GATT Server');
|
||||
gattServer = server;
|
||||
return gattServer.getPrimaryService('62750001-d828-918d-fb46-b6c11c675aec');
|
||||
}).then(service => {
|
||||
addLog('> Found Service');
|
||||
Theservice = service;
|
||||
return Theservice.getCharacteristic('62750002-d828-918d-fb46-b6c11c675aec');
|
||||
}).then(characteristic => {
|
||||
addLog('> Found Characteristic');
|
||||
document.getElementById("connectbutton").innerHTML = '断开';
|
||||
updateButtonStatus();
|
||||
writeCharacteristic = characteristic;
|
||||
}).catch(handleError);
|
||||
async function connect() {
|
||||
if (epdCharacteristic == null) {
|
||||
addLog("正在连接: " + bleDevice.name);
|
||||
|
||||
gattServer = await bleDevice.gatt.connect();
|
||||
addLog('> 找到 GATT Server');
|
||||
|
||||
epdService = await gattServer.getPrimaryService('62750001-d828-918d-fb46-b6c11c675aec');
|
||||
addLog('> 找到 EPD Service');
|
||||
|
||||
epdCharacteristic = await epdService.getCharacteristic('62750002-d828-918d-fb46-b6c11c675aec');
|
||||
addLog('> 找到 Characteristic');
|
||||
|
||||
await epdCharacteristic.startNotifications();
|
||||
epdCharacteristic.addEventListener('characteristicvaluechanged', (event) => {
|
||||
addLog(`> 收到配置:${bytesToHex(event.target.value.buffer.slice(0,8))}`);
|
||||
document.getElementById("epdpins").value = bytesToHex(event.target.value.buffer.slice(0, 7));
|
||||
document.getElementById("epddriver").value = bytesToHex(event.target.value.buffer.slice(7, 8));
|
||||
});
|
||||
|
||||
document.getElementById("connectbutton").innerHTML = '断开';
|
||||
updateButtonStatus();
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user