Вэб-старонка браўзера з адкрытым зыходным кодам і глыбокае пашырэнне паслядоўнага порта экрана T5L DWIN (тэхналогія Node-RED)

——З форуму распрацоўшчыкаў DWIN

У гэтым выпуску мы прадставім вам узнагароджаны прыклад з адкрытым зыходным кодам Форума распрацоўшчыкаў Devin для прымянення Divin Screen у новай галіне - вэб-старонка браўзера і глыбокае пашырэнне паслядоўнага порта T5L Divin Screen (тэхналогія Node-RED) .Інжынеры выкарыстоўваюць смарт-экраны T5L для перадачы Node- Тэхналогія RED патрабуе толькі паслядоўнага порта для падлучэння да Інтэрнэту і рэалізацыі ўзаемадзеяння дадзеных паміж экранам Diwen і вэб-старонкай браўзера.Гэта рашэнне рэалізуе такія функцыі, як адпраўка і атрыманне даных, узаемадзеянне з дыяграмамі і адлюстраванне асноўнай інфармацыі паміж разумным экранам і вэб-старонкай.

1. Адлюстраванне эфекту запуску вэб-старонкі Node-RED

(1) З выкарыстаннем тэхналогіі Node-RED браўзер выкарыстоўваецца ў якасці ўваходу для ўзаемадзеяння, так што браўзер і экран узаемадзейнічаюць праз паслядоўны порт для рэалізацыі адпаведнай функцыі адлюстравання.

асва (1)
асва (2)

Старонка ўкладкі адпраўкі і атрымання даных

Старонка інтэрактыўнай укладкі значкоў

асва (3)

Асноўная інфармацыя Эфект старонкі ўкладкі

(2) Асноўныя даведачныя коды для вэб-кліента Node-RED наступныя:

{

"ідэнтыфікатар": "fbb314a16ea00889",

"тып": "паслядоўны ўваход",

"z": "09e0777eaff7fdea",

"g": "c1661722c7db00f9",

"name": "Паслядоўны порт прымае дадзеныя",

"серыйны": "83fb45b5f4b51d61",

"x": 390,

"y": 140,

"правады": [

[

"685a2fb2c2dc8fba"

]

]

},

{

"ідэнтыфікатар": "1ba3c6e812e03e27",

"тып": "паслядоўны выхад",

"z": "09e0777eaff7fdea",

"g": "c1661722c7db00f9",

"name": "Адпраўка паслядоўнага порта",

"серыйны": "83fb45b5f4b51d61",

"x": 860,

"y": 260,

"правады": []

},

{

"ідэнтыфікатар": "5fb7f1d3d7425133",

"тып": "стан",

"z": "09e0777eaff7fdea",

"g": "c1661722c7db00f9",

"name": "Сачыць за станам паслядоўнага порта",

"абсяг": [

"fbb314a16ea00889"

],

"x": 390,

"y": 200,

"правады": [

[

"3f18d1fdea398d35"

]

]

},

{

"ідэнтыфікатар": "3f18d1fdea398d35",

"тып": "функцыя",

"z": "09e0777eaff7fdea",

"g": "c1661722c7db00f9",

"name": "Выняць статус паслядоўнага порта",

"func": "let sta = msg.status.text;\nlet color = 'red';\nif (sta.indexOf('not-connected') >= 0) \n sta = 'Unconnected';\nelse if (sta.indexOf('connected') >= 0)\n{\n sta = 'злучэнне ўдалося';\n color = 'зялёны';\n}else\n sta = 'адбылася памылка';\nmsg[' карысная нагрузка'] = sta;\nmsg['color'] = колер;\n\nвярнуць паведамленне;",

"выхады": 1,

"тайм-аўт": 0,

"noerr": 0,

"ініцыялізаваць": "",

"завяршыць": "",

"libs": [],

"x": 620,

"y": 200,

"правады": [

[

"2ec78ff0b0b9a56f"

]

]

},

{

"ідэнтыфікатар": "2ec78ff0b0b9a56f",

"тып": "ui_template",

"z": "09e0777eaff7fdea",

"g": "c1661722c7db00f9",

"група": "4e4db779a7b91019",

"name": "Паказаць статус паслядоўнага порта",

"парадак": 1,

"шырыня": 0,

"вышыня": 0,

"фармат": "\n Стан паслядоўнага порта:

2.ДГУСIінтэрфейсDэзайн

асва (4)

1. Інжынерны дызайн C51

Рашэнне выкарыстоўвае паслядоўны порт 2 разумнага экрана T5L для сувязі з вэб-старонкай Node-RED.Некаторыя даведачныя коды наступныя:

#include "sys.h"

#include "uart2.h"

#уключыць

#уключыць

u8 бафф [200];

пустата асноўны (пустата)

{

u16num;

u16val;

u16стары;

u8i;

sys_init();

uart2_init(115200);

стары = 0;

пакуль (1)

{

калі (is_recv_complete)

{

uart2_buf[recv_len++]= 0;

uart2_buf[recv_len++]= 0;

if(strstr((char*)uart2_buf,"cmd"))

{

num= uart2_buf[3]-'0';

калі (нум<3)

{

для (i=0;i<3;i++)

{

значэнне = (нум == я);

sys_write_vp(0x2300+i,(u8*)&val, 1);

}

}elseif(нум<5)

{

значэнне= (нум==3);

sys_write_vp(0x2200,(u8*)&val, 1);

}

} інакш

{

sys_write_vp(0x2000,uart2_buf, recv_len/2+2);

}

recv_len= 0;

is_recv_complete= 0;

}

sys_read_vp(0x1000,(u8*)&val, 1);

калі (значэнне==1)

{

sys_read_vp(0x2100,бафф, 50);

для (i=0;i<100;i++)

{

калі (бафф==0xff)

{

бафф = 0x00;

бафф[i+1]= 0x00;

ламаць;

}

}

u2_send_bytes(баф,strlen(баф));

значэнне = 0;

sys_write_vp(0x1000,(u8*)&val, 1);

}

sys_read_vp(0x2400,(u8*)&val, 1);

калі (вал!=стары)

{

sprintf(buff,"%d", val);

u2_send_bytes(баф,strlen(баф));

стары = вал;

}

}

}


Час публікацыі: 28 снежня 2023 г