——DWIN विकासकर्ता फोरमबाट
यस अंकमा, हामी तपाईंलाई DWIN विकासकर्ता फोरम - स्मार्ट खेती कोठाको पुरस्कार-विजेता खुला स्रोत केस परिचय गराउँछौं।इन्जिनियरहरूले मोडबस प्रोटोकल मार्फत तताउने र फ्यानको तापक्रम नियन्त्रण कार्यहरू नियन्त्रण गर्न T5L स्मार्ट स्क्रिन लागू गरे।बिजुली आपूर्ति पनि प्रकाश प्रकार्य अनुकरण गर्न समायोजित गर्न सकिन्छ।प्रणाली स्वचालित रूपमा स्क्रिनमा सेट प्यारामिटरहरू अनुसार चल्न सक्छ र त्रुटि इतिहास रेकर्डहरू बचत गर्न सक्छ।
1.UI सामग्री प्रदर्शन
2.UI डिजाइन
1.C51 डिजाइन
मुख्य इन्टरफेसमा तापक्रम, आर्द्रता, र उचाइ जस्ता डेटा प्राप्त गर्ने र अद्यावधिक गर्ने मुख्य कोडहरू, र तापमान नियन्त्रण मोड्युलहरू, मोटरहरू, अलार्म पत्ता लगाउने, र अन्य दास मेसिनहरू नियन्त्रण गर्न मोडबस आरटीयू प्रयोग गर्ने मुख्य कोडहरू निम्नानुसार छन्।
मुख्य इन्टरफेस कोड सन्दर्भ:
# "main_win.h" समावेश गर्नुहोस्
# "modbus.h" समावेश गर्नुहोस्
# "sys_params.h" समावेश गर्नुहोस्
# "func_handler.h" समावेश गर्नुहोस्
# "uart2.h" समावेश गर्नुहोस्
#समावेश गर्नुहोस्
#समावेश गर्नुहोस्
#TEMP_HUM_SLAVE_ADDR 2 परिभाषित गर्नुहोस्
# 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)
टाइपडेफ संरचना{
चार मिति [१७];
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_LEN];
u16 alert_num = 0;
बिट is_main_win = 0;
void 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);
}
void main_win_process_alert()
{
u8 i;
(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));
}
void main_win_disp_alert()
{
u16 i;
u16 val;
u16 लेन = 0;
common_buf[0] = 0;
(i=0; i) को लागी
{
val = 0;
यदि म
{
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);
}
void main_win_init()
{
फ्लोट fixed_val;
u8 i;
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);
}
void main_win_click_handler(u16 btn_val)
{
u8 सूचकांक;
यदि(btn_val==0x0B)
{
main_win_disp_alert();
फर्किनु;
}
index = btn_val-1;
btn_sta[सूचकांक] = !btn_sta[सूचकांक];
यदि((सूचकांक==3)||(सूचकांक==7))
btn_sta[सूचकांक] = 1;
modbus_write_bit(btn_addr[index], btn_sta[index]?0xFF00:0x0000);
btn_val = btn_sta[सूचकांक];
sys_write_vp(MAIN_WIN_BTN_STA_START_VP+MAIN_WIN_BTN_STA_OFFSET*सूचकांक, (u8*)&btn_val, 1);
यदि (सूचकांक==9)
is_main_win = 0;
अन्यथा यदि((सूचकांक==3)||(सूचकांक==7))
{
जबकि(sys_get_touch_sta());
modbus_write_bit(btn_addr[index], 0x0000);
}
}
void 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 i;
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();
}अन्यथा यदि((f_code==MODBUS_FUNC_CODE_01)&&(data_len==ALERT_BYTE_NUM))
{
अफसेट = MODBUS_RESPOND_POS_DATA;
(i=0; i) को लागी
{
alert_val = msg[अफसेट];
अफसेट ++;
}
main_win_process_alert();
}अन्यथा यदि((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();
}अन्यथा यदि((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();
}
}
void 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;//उल्टाउनुहोस्
}
void 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.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 150 परिभाषित गर्नुहोस्
#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 *बाइट्स,u16 len)
{
UART_SEND_BYTES(बाइट्स, लेन);
}
void modbus_recv_byte(u8 बाइट)
{
यदि (is_modbus_recv_complete)
फर्किनु;
यदि(modbus_recv_len
modbus_recv_buff[modbus_recv_len++] = बाइट;
}
void modbus_check_recv_timeout()
{
यदि (modbus_recv_timeout)
{
modbus_recv_timeout--;
यदि (modbus_recv_timeout==0)
{
is_modbus_recv_complete = 1;
}
}
}
u8 modbus_send_packet(u8 *प्याकेट)
{
u16 लेन;
u16 crc;
u8 func_code = प्याकेट[1];
जबकि (modbus_send_interval);
यदि(func_code==MODBUS_FUNC_CODE_10)
{
((MODBUS_10_PACKET*) प्याकेट)->byte_num = ((MODBUS_10_PACKET*) प्याकेट)->word_num*2;
len = 9+((MODBUS_10_PACKET*) प्याकेट)->byte_num;
}अन्य यदि(func_code==MODBUS_FUNC_CODE_0F)
{
len = ((MODBUS_0F_PACKET*) प्याकेट)->bit_num;
((MODBUS_0F_PACKET*) प्याकेट)->byte_num = len/8+(len%8?1:0);
len = 9+((MODBUS_0F_PACKET*) प्याकेट)->byte_num;
}अन्य
{
लेन = साइजको (MODBUS_PACKET);
}
crc = crc16 (प्याकेट, लेन-2);
प्याकेट [len-2] = (u8)(crc>>8);
प्याकेट [len-1] = (u8) crc;
modbus_send_bytes (प्याकेट, लेन);
modbus_send_interval = MODBUS_SEND_INTERVAL;
फिर्ता ०;//सफल
}
extern void 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];
if(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);
फिर्ता लेन;
}
पोस्ट समय: जनवरी-12-2024