[ប្រភពបើកចំហ] បន្ទប់បណ្តុះបណ្តាលឆ្លាតវៃ

—— ពីវេទិកាអ្នកអភិវឌ្ឍន៍ DWIN

នៅក្នុងបញ្ហានេះ យើងណែនាំអ្នកអំពីករណីប្រភពបើកចំហដែលទទួលបានពានរង្វាន់នៃវេទិកាអ្នកអភិវឌ្ឍន៍ DWIN - បន្ទប់ដាំដុះឆ្លាតវៃ។វិស្វករបានអនុវត្តអេក្រង់ឆ្លាតវៃ T5L ដើម្បីគ្រប់គ្រងមុខងារគ្រប់គ្រងកំដៅ និងសីតុណ្ហភាពកង្ហារតាមរយៈពិធីការ Modbus ។ការផ្គត់ផ្គង់ថាមពលក៏អាចត្រូវបានកែតម្រូវផងដែរ ដើម្បីក្លែងធ្វើមុខងារបំភ្លឺ។ប្រព័ន្ធអាចដំណើរការដោយស្វ័យប្រវត្តិតាមប៉ារ៉ាម៉ែត្រដែលបានកំណត់នៅលើអេក្រង់ និងរក្សាទុកកំណត់ត្រាប្រវត្តិកំហុស។

1.UI ការបង្ហាញសម្ភារៈ

asvdfb (2)
asvdfb (1)

2. ការរចនា UI

asvdfb (3)

1.C51 ការរចនា

លេខកូដសំខាន់ៗសម្រាប់ការទទួលបាន និងធ្វើបច្ចុប្បន្នភាពទិន្នន័យដូចជា សីតុណ្ហភាព សំណើម និងកម្ពស់នៅលើចំណុចប្រទាក់មេ និងការប្រើប្រាស់ modbus rtu ដើម្បីគ្រប់គ្រងម៉ូឌុលត្រួតពិនិត្យសីតុណ្ហភាព ម៉ូទ័រ ការរកឃើញសំឡេងរោទិ៍ និងម៉ាស៊ីនបម្រើផ្សេងទៀតមានដូចខាងក្រោម។

សេចក្តីយោងកូដចំណុចប្រទាក់ចម្បង៖

# រួមបញ្ចូល "main_win.h"

# រួមបញ្ចូល "modbus.h"

# រួមបញ្ចូល "sys_params.h"

#រួមបញ្ចូល "func_handler.h"

#រួមបញ្ចូល "uart2.h"

# រួមបញ្ចូល

# រួមបញ្ចូល

#កំណត់ TEMP_HUM_SLAVE_ADDR ២

#កំណត់ TEMP_HUM_VAL_MAX_NUM 2

#កំណត់ ALERT_BIT_MAX_NUM 30

#កំណត់ ALERT_BYTE_NUM (ALERT_BIT_MAX_NUM/8+((ALERT_BIT_MAX_NUM%8)!=0))

#កំណត់ GET_ALERT_BIT(val, pos) ((val[pos/8]>>(pos%8))&0x01)

typedef struct{

កាលបរិច្ឆេទ char[17];

u8 desc;

}ជូនដំណឹង;

#កំណត់ ALERT_TABLE_LEN 20

ឋិតិវន្ត u8 btn_sta[MAIN_WIN_BTN_MAX_NUM] = {0};

ឋិតិវន្ត u8 btn_addr[MAIN_WIN_BTN_MAX_NUM] = {50, 51, 52, 69, 53, 54, 55, 70, 56, 57, 58, 59};

u16 main_win_val[MAIN_WIN_VAL_MAX_NUM];

u16 temp_hum_val[TEMP_HUM_VAL_MAX_NUM] = {0};

u16 date_val[MAIN_WIN_DATE_MAX_NUM] = {0};

u8 alert_val[ALERT_BYTE_NUM] = {0};

u8 old_alert_val[ALERT_BYTE_NUM] = {0};

ALERT alert_table[ALERT_TABLE_LEN];

u16 alert_num = 0;

bit is_main_win = 0;

មោឃៈ main_win_update()

{

}

ទុកជាមោឃៈ main_win_disp_date()

{

u8 លេន;

len = sprintf(common_buf, "%u:%u", (u16)date_val[3], (u16)date_val[4]);

common_buf[len+1] = 0;

sys_write_vp(MAIN_WIN_DATE_VP, common_buf, len/2+2);

}

មោឃៈ main_win_process_alert()

{

u8 ខ្ញុំ;

សម្រាប់(i=0;i

{

ប្រសិនបើ(GET_ALERT_BIT(old_alert_val, i))

បន្ត;

ប្រសិនបើ(GET_ALERT_BIT(alert_val, i))

{

ប្រសិនបើ(alert_num>=ALERT_TABLE_LEN)

alert_num = ALERT_TABLE_LEN-1;

alert_table[alert_num].desc = i+1;

sprintf(alert_table[alert_num].date, "%u/%u/%u %u:%u",

date_val[0], date_val[1], date_val[2], date_val[3], date_val[4]

);

alert_num ++;

}

}

memcpy(old_alert_val, alert_val, sizeof(alert_val));

}

មោឃៈ main_win_disp_alert()

{

u16 ខ្ញុំ;

u16 វ៉ាល់;

u16 លេន = 0;

common_buf[0] = 0;

សម្រាប់(i=0;i

{

val = 0;

ប្រសិនបើ (i

{

val = alert_table.desc;

len += sprintf(common_buf+len, "%s\r\n", alert_table.date);

}

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

}

common_buf[len+1] = 0;

sys_write_vp(ALERT_WIN_DATE_VP, common_buf, len/2+2);

}

មោឃៈ main_win_init()

{

អណ្តែតថេរ_val;

u8 ខ្ញុំ;

is_main_win = 1;

 

main_win_val[5] = (u16)(temp_hum_val[0]/10.0+0.5f);

main_win_val[6] = (u16)(temp_hum_val[1]/10.0+0.5f);

សម្រាប់(i=0;i

{

ប្រសិនបើ (i==0)

បន្ត;

sys_write_vp(MAIN_WIN_WIND_SPEED_VP+MAIN_WIN_VAL_OFFSET*i, (u8*)&main_win_val, 1);

}

fixed_val = main_win_val[0]/WIND_SPEED_SCALE+FLOAT_FIX_VAL;

sys_write_vp(MAIN_WIN_WIND_SPEED_VP, (u8*)&fixed_val, 2);

}

ទុកជាមោឃៈ main_win_click_handler(u16 btn_val)

{

សន្ទស្សន៍ u8;

ប្រសិនបើ(btn_val==0x0B)

{

main_win_disp_alert();

ត្រឡប់មកវិញ;

}

លិបិក្រម = btn_val-1;

btn_sta[index] = !btn_sta[index];

ប្រសិនបើ((index==3)||(index==7))

btn_sta[index] = 1;

modbus_write_bit(btn_addr[index], btn_sta[index]?0xFF00:0x0000);

btn_val = btn_sta[index];

sys_write_vp(MAIN_WIN_BTN_STA_START_VP+MAIN_WIN_BTN_STA_OFFSET*index, (u8*)&btn_val, 1);

ប្រសិនបើ (index==9)

is_main_win = 0;

ផ្សេងទៀតប្រសិនបើ((សន្ទស្សន៍==3)||(សន្ទស្សន៍==7))

{

while(sys_get_touch_sta());

modbus_write_bit(btn_addr[index], 0x0000);

}

}

ទុកជាមោឃៈ main_win_msg_handler(u8 *msg,u16 msg_len)

{

u8 f_code = msg[MODBUS_RESPOND_POS_FUNC_CODE];

u8 data_len = msg[MODBUS_RESPOND_POS_DATA_LEN];

u8 ខ្ញុំ;

u8 អុហ្វសិត;

msg_len = msg_len;

ប្រសិនបើ (!is_main_win)

ត្រឡប់មកវិញ;

ប្រសិនបើ((f_code==MODBUS_FUNC_CODE_03)&&(data_len==MAIN_WIN_VAL_MAX_NUM*2))

{

អុហ្វសិត = MODBUS_RESPOND_POS_DATA;

សម្រាប់(i=0;i

{

main_win_val = SYS_GET_U16(msg[offset], msg[offset+1]);

អុហ្វសិត += 2;

}

main_win_update();

}else if((f_code==MODBUS_FUNC_CODE_01)&&(data_len==ALERT_BYTE_NUM))

{

អុហ្វសិត = MODBUS_RESPOND_POS_DATA;

សម្រាប់(i=0;i

{

alert_val = msg[offset];

អុហ្វសិត ++;

}

main_win_process_alert();

}else if((f_code==MODBUS_FUNC_CODE_03)&&(data_len==TEMP_HUM_VAL_MAX_NUM*2))

{

អុហ្វសិត = MODBUS_RESPOND_POS_DATA;

សម្រាប់(i=0;i

{

temp_hum_val = SYS_GET_U16(msg[offset], msg[offset+1]);

អុហ្វសិត += 2;

modbus_write_word(5+i, temp_hum_val);

}

main_win_update();

}else if((f_code==MODBUS_FUNC_CODE_03)&&(data_len==MAIN_WIN_DATE_MAX_NUM*2))

{

អុហ្វសិត = MODBUS_RESPOND_POS_DATA;

សម្រាប់(i=0;i

{

date_val = SYS_GET_U16(msg[offset], msg[offset+1]);

អុហ្វសិត += 2;

}

main_win_disp_date();

}

}

មោឃៈ main_win_read_temp_hum()

{

u8 old_slave_addr = SLAVE_ADDR;

        

sys_params.user_config[5] = TEMP_HUM_SLAVE_ADDR;

modbus_read_words(0, TEMP_HUM_VAL_MAX_NUM);

sys_params.user_config[5] = old_slave_addr;// ត្រឡប់

}

ទុកជាមោឃៈ main_win_handler()

{

ទង់ជាតិ u8 = 0;

ប្រសិនបើ (is_main_win)

{

ប្រសិនបើ (alert_read_period==ALERT_READ_PERIOD)

{

alert_read_period = 0;

modbus_read_bits(510, ALERT_BIT_MAX_NUM);

ត្រឡប់មកវិញ;

}

ប្រសិនបើ (date_update_period==DATE_UPDATE_PERIOD)

{

date_update_period = 0;

modbus_read_words(180, MAIN_WIN_DATE_MAX_NUM);

ត្រឡប់មកវិញ;

}

ទង់ជាតិ = !ទង់;

ប្រសិនបើ (ទង់)

modbus_read_words(0, MAIN_WIN_VAL_MAX_NUM);

ផ្សេងទៀត។

main_win_read_temp_hum();

}

}

សេចក្តីយោងកូដ modbus rtu៖

# រួមបញ្ចូល "modbus.h"

#រួមបញ្ចូល "crc16.h"

# រួមបញ្ចូល "sys_params.h"

#កំណត់ UART_INCLUDE "uart2.h"

#កំណត់ UART_INIT uart2_init

#កំណត់ UART_SEND_BYTES uart2_send_bytes

#កំណត់ UART_BAUD 9600

#កំណត់ MODBUS_RECV_TIMEOUT (u8)(35000.0f/UART_BAUD+2)

#កំណត់ MODBUS_SEND_INTERVAL ១៥០

# រួមបញ្ចូល UART_INCLUDE

ប៊ីតឋិតិវន្ត is_modbus_recv_complete = 0;

ឋិតិវន្ត u8 modbus_recv_buff[270];

ឋិតិវន្ត u16 modbus_recv_len = 0;//ប្រវែងសរុបនៃបៃបានទទួលយក

ឋិតិវន្ត u8 modbus_recv_timeout = 0;// ទទួលយកពេលវេលាលើស

ប្រែប្រួលឋិតិវន្ត u16 modbus_send_interval = 0;

កញ្ចប់ MODBUS_PACKET;

void modbus_init()

{

UART_INIT(UART_BAUD);

}

void modbus_send_bytes(u8 *bytes,u16 len)

{

UART_SEND_BYTES (បៃ, លេន);

}

ចាត់ទុកជាមោឃៈ modbus_recv_byte (u8 បៃ)

{

ប្រសិនបើ (is_modbus_recv_complete)

ត្រឡប់មកវិញ;

ប្រសិនបើ (modbus_recv_len

modbus_recv_buff[modbus_recv_len++] = បៃ;

}

មោឃៈ modbus_check_recv_timeout()

{

ប្រសិនបើ (modbus_recv_អស់ពេល)

{

modbus_recv_timeout--;

ប្រសិនបើ (modbus_recv_timeout==0)

{

is_modbus_recv_complete = 1;

}

}

}

u8 modbus_send_packet(u8 * packet)

{

u16 លេន;

u16 crc;

u8 func_code = packet[1];

while(modbus_send_interval);

ប្រសិនបើ(func_code==MODBUS_FUNC_CODE_10)

{

((MODBUS_10_PACKET*)packet)->byte_num = ((MODBUS_10_PACKET*)packet)->word_num*2;

len = 9+((MODBUS_10_PACKET*) packet)->byte_num;

}else if(func_code==MODBUS_FUNC_CODE_0F)

{

len = ((MODBUS_0F_PACKET*)packet)->bit_num;

((MODBUS_0F_PACKET*)packet)->byte_num = len/8+(len%8?1:0);

len = 9+((MODBUS_0F_PACKET*)packet)->byte_num;

}ផ្សេងទៀត។

{

len = sizeof(MODBUS_PACKET);

}

crc = crc16(packet,len-2);

កញ្ចប់ព័ត៌មាន[len-2] = (u8)(crc>>8);

កញ្ចប់ព័ត៌មាន[len-1] = (u8)crc;

modbus_send_bytes(packet,len);

modbus_send_interval = MODBUS_SEND_INTERVAL;

ត្រឡប់ 0; // ជោគជ័យ

}

ខាងក្រៅ modbus_msg_handler(u8 *msg,u16 msg_len);

void modbus_handler()

{

u16 crc;

ប្រសិនបើ (!is_modbus_recv_complete)

ត្រឡប់មកវិញ;

// ពិនិត្យតម្លៃ crc

crc = ((u16)modbus_recv_buff[modbus_recv_len-2]<<8)+modbus_recv_buff[modbus_recv_len-1];

ប្រសិនបើ(crc16(modbus_recv_buff,modbus_recv_len-2)==crc)

{

modbus_msg_handler (modbus_recv_buff, modbus_recv_len);

}

modbus_recv_len = 0;

is_modbus_recv_complete = 0;

}

u8 modbus_send_fcode(u8 fcode, u16 addr, u16 len)

{

packet.slave_addr = SLAVE_ADDR;

packet.func_code = fcode; // កូដមុខងារ

packet.start_addr = addr;//អាសយដ្ឋាន

packet.data_len = len;//តម្លៃ​ដែល​បាន​សរសេរ

len = modbus_send_packet((u8*)&packet);

ត្រឡប់ len;

}


ពេលវេលាផ្សាយ៖ មករា-១២-២០២៤