Nyílt forráskódú böngésző weboldal és T5L DWIN képernyő soros port mély bővítése (Node-RED technológia)

——A DWIN fejlesztői fórumról

Ebben a számban a Devin Developer Forum díjnyertes nyílt forráskódú esetét mutatjuk be a Divin Screen új területen történő alkalmazásához - böngésző weboldal és T5L Divin Screen soros port mélyreható bővítése (Node-RED technológia) .A mérnökök a T5L intelligens képernyőket használják a Node-RED technológiának csak egy soros portra van szüksége az internethez való csatlakozáshoz, valamint a Diwen képernyő és a böngésző weboldala közötti adatkapcsolat megvalósításához.Ez a megoldás olyan funkciókat valósít meg, mint az adatküldés és -fogadás, a diagramok interakciója, valamint az alapvető információk megjelenítése az intelligens képernyő és a weboldal között.

1. Node-RED weboldal futó effektus megjelenítése

(1) A Node-RED technológiát használva a böngésző interakciós bejáratként szolgál, így a böngésző és a képernyő a soros porton keresztül interakcióba lép a megfelelő funkciómegjelenítés megvalósítása érdekében.

asva (1)
asva (2)

Adatküldés és -fogadás lap

Ikon interaktív lap oldal

asva (3)

Alapvető információk Lap effektus

(2) A Node-RED webes kliens fő hivatkozási kódjai a következők:

{

"id": "fbb314a16ea00889",

"type": "serial in",

"z": "09e0777eaff7fdea",

"g": "c1661722c7db00f9",

"name": "A soros port fogad adatokat",

"serial": "83fb45b5f4b51d61",

"x": 390,

"y": 140,

"vezetékek": [

[

"685a2fb2c2dc8fba"

]

]

},

{

"id": "1ba3c6e812e03e27",

"type": "soros kimenet",

"z": "09e0777eaff7fdea",

"g": "c1661722c7db00f9",

"name": "Soros port küldése",

"serial": "83fb45b5f4b51d61",

"x": 860,

"y": 260,

"vezetékek": []

},

{

"id": "5fb7f1d3d7425133",

"type": "státusz",

"z": "09e0777eaff7fdea",

"g": "c1661722c7db00f9",

"name": "A soros port állapotának figyelése",

"hatókör": [

"fbb314a16ea00889"

],

"x": 390,

"y": 200,

"vezetékek": [

[

"3f18d1fdea398d35"

]

]

},

{

"id": "3f18d1fdea398d35",

"type": "függvény",

"z": "09e0777eaff7fdea",

"g": "c1661722c7db00f9",

"name": "Soros port állapotának kibontása",

"func": "let sta = msg.status.text;\nlet color = 'piros';\nif (sta.indexOf('not-connected') >= 0) \n sta = 'Nincs kapcsolat';\nelse if (sta.indexOf('connected') >= 0)\n{\n sta = 'csatlakozás sikerült';\n color = 'zöld';\n}else\n sta = 'hiba történt';\nmsg[' payload'] = sta;\nmsg['color'] = szín;\n\nreturn msg;",

"kimenetek": 1,

"időtúllépés": 0,

"noerr": 0,

"inicializál": "",

"finalize": "",

"libs": [],

"x": 620,

"y": 200,

"vezetékek": [

[

"2ec78ff0b0b9a56f"

]

]

},

{

"id": "2ec78ff0b0b9a56f",

"type": "ui_template",

"z": "09e0777eaff7fdea",

"g": "c1661722c7db00f9",

"csoport": "4e4db779a7b91019",

"name": "Soros port állapotának megjelenítése",

"rendelés": 1,

"szélesség": 0,

"magasság": 0,

"formátum": "\n Soros port állapota:

2.DGUSIninterfaceDjelz

asva (4)

1. C51 Mérnöki tervezés

A megoldás a T5L intelligens képernyő 2-es soros portját használja a Node-RED weboldallal való kommunikációhoz.Néhány hivatkozási kód a következő:

#include "sys.h"

#include "uart2.h"

#beleértve

#beleértve

u8 buff[200];

void main(void)

{

u16num;

u16val;

u16old;

u8i;

sys_init();

uart2_init(115200);

régi= 0;

míg (1)

{

if(is_recv_complete)

{

uart2_buf[recv_len++]= 0;

uart2_buf[recv_len++]= 0;

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

{

szám= uart2_buf[3]-'0';

if(szám<3)

{

for(i=0;i<3;i++)

{

val= (szám==i);

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

}

}elseif(szám<5)

{

val= (szám==3);

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

}

}más

{

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

}

recv_len= 0;

is_recv_complete= 0;

}

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

if(érték==1)

{

sys_read_vp(0x2100,buff, 50);

for(i=0;i<100;i++)

{

if(buff==0xff)

{

buff= 0x00;

buff[i+1]= 0x00;

szünet;

}

}

u2_send_bytes(buff,strlen(buff));

val=0;

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

}

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

if(val!=régi)

{

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

u2_send_bytes(buff,strlen(buff));

old= val;

}

}

}


Feladás időpontja: 2023. december 28