Páxina web do navegador de código aberto e pantalla T5L DWIN Expansión profunda do porto serie (tecnoloxía Node-RED)

——Do DWIN Developer Forum

Neste número, presentarémosche un caso de código aberto premiado do Foro de Desenvolvedores Devin para a aplicación de Divin Screen no novo campo: páxina web do navegador e expansión en profundidade do porto serie T5L Divin Screen (tecnoloxía Node-RED) .Os enxeñeiros usan pantallas intelixentes T5L para pasar a tecnoloxía Node-RED só require un porto serie para conectarse a Internet e realizar a interacción de datos entre a pantalla de Diwen e a páxina web do navegador.Esta solución realiza funcións como o envío e recepción de datos, a interacción de gráficos e a visualización de información básica entre a pantalla intelixente e a páxina web.

1. Visualización do efecto de execución da páxina web Node-RED

(1) Usando a tecnoloxía Node-RED, o navegador úsase como entrada de interacción, de xeito que o navegador e a pantalla interactúan a través do porto serie para realizar a visualización da función correspondente.

asva (1)
asva (2)

Pestana de envío e recepción de datos

Páxina de pestanas interactivas de iconas

asva (3)

Información básica Efecto páxina pestana

(2) Os principais códigos de referencia para o cliente web Node-RED son os seguintes:

{

"id": "fbb314a16ea00889",

"type": "entrada en serie",

"z": "09e0777eaff7fdea",

"g": "c1661722c7db00f9",

"name": "O porto serie recibe datos",

"serie": "83fb45b5f4b51d61",

"x": 390,

"y": 140,

"fíos": [

[

"685a2fb2c2dc8fba"

]

]

},

{

"id": "1ba3c6e812e03e27",

"type": "saída de serie",

"z": "09e0777eaff7fdea",

"g": "c1661722c7db00f9",

"name": "Envío por porto serie",

"serie": "83fb45b5f4b51d61",

"x": 860,

"y": 260,

"fíos": []

},

{

"id": "5fb7f1d3d7425133",

"type": "estado",

"z": "09e0777eaff7fdea",

"g": "c1661722c7db00f9",

"name": "Monitorizar o estado do porto serie",

"ámbito": [

"fbb314a16ea00889"

],

"x": 390,

"y": 200,

"fíos": [

[

"3f18d1fdea398d35"

]

]

},

{

"id": "3f18d1fdea398d35",

"type": "función",

"z": "09e0777eaff7fdea",

"g": "c1661722c7db00f9",

"name": "Extraer o estado do porto serie",

"func": "let sta = msg.status.text;\nlet color = 'vermello';\nif (sta.indexOf('non-conectado') >= 0) \n sta = 'Desconectado';\nelse if (sta.indexOf('conectado') >= 0)\n{\n sta = 'conexión correcta';\n color = 'verde';\n}else\n sta = 'Produciuse un erro';\nmsg[' carga útil'] = sta;\nmsg['cor'] = cor;\n\nvolver mensaxe;",

"saídas": 1,

"tempo de espera": 0,

"noerr": 0,

"initialize": "",

"finalize": "",

"libs": [],

"x": 620,

"y": 200,

"fíos": [

[

"2ec78ff0b0b9a56f"

]

]

},

{

"id": "2ec78ff0b0b9a56f",

"type": "ui_template",

"z": "09e0777eaff7fdea",

"g": "c1661722c7db00f9",

"grupo": "4e4db779a7b91019",

"name": "Mostrar o estado do porto serie",

"orde": 1,

"ancho": 0,

"altura": 0,

"formato": "\n Estado do porto serie:

2.DGUSIninterfaceDesign

asva (4)

1. C51 Deseño de Enxeñaría

A solución usa o porto serie 2 da pantalla intelixente T5L para comunicarse coa páxina web de Node-RED.Algúns códigos de referencia son os seguintes:

#include "sys.h"

#include "uart2.h"

#incluír

#incluír

u8 buff[200];

void main(void)

{

número u16;

sub16val;

ata 16 anos;

u8i;

sys_init();

uart2_init(115200);

antigo = 0;

mentres (1)

{

se (está_recv_completo)

{

uart2_buf[recv_len++]= 0;

uart2_buf[recv_len++]= 0;

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

{

num= uart2_buf[3]-'0';

se (número <3)

{

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

{

val= (num==i);

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

}

}elseif(num<5)

{

val= (num==3);

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

}

}outra

{

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

}

recv_len= 0;

is_recv_complete= 0;

}

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

se (val==1)

{

sys_read_vp(0x2100,buff, 50);

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

{

if(buff==0xff)

{

buff= 0x00;

buff[i+1]= 0x00;

romper;

}

}

u2_send_bytes(buff,strlen(buff));

val= 0;

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

}

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

se (val!=antigo)

{

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

u2_send_bytes(buff,strlen(buff));

vello= val;

}

}

}


Hora de publicación: 28-12-2023