迪文屏开发保姆级教程6----触摸实现界面切换

2023-12-25 20:52

本文主要是介绍迪文屏开发保姆级教程6----触摸实现界面切换,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 这篇文章要讲啥事呢?

 本篇文章主要介绍了在DGBUS平台上触摸实现界面切换的方法。

文哥悄悄话:

官方开发指南PDF:(不方便下载的私聊我发给你)

https://download.csdn.net/download/qq_21370051/88647174?spm=1001.2014.3001.5503https://download.csdn.net/download/qq_21370051/88647174?spm=1001.2014.3001.5503

文哥家目录小秘

 这篇文章要讲啥事呢?

文哥悄悄话:

文哥家目录小秘

一、前言

开发环境

二、详细步骤

1.添加按键返回控件

2.设置控件属性

3.屏幕接收处理代码

4.识别到按键点击,并切换另一个界面。

代码:

5.保存、导出、验证。

三、容易踩得坑


一、前言

在DGBUS平台上使用按键返回控件实现界面切换的功能。

开发环境

迪文屏型号DMG80480T070_09WTC
DGUS版本DGUS_V7646
单片机        GD32F407

二、详细步骤

1.添加按键返回控件

2.设置控件属性

这样设置后,实际运行的时候,当我们点击到这个按键控件,单片机串口会收到:

3.屏幕接收处理代码

/************************************************************************************
函数名称:	Screen_CmdCheck()
功能描述:	从屏幕收到的数据处理包括,按键  上报的输入变量等。
************************************************************************************/uint16_t  Class_LcdUart::Screen_CmdCheck(uint8_t *buffer,uint16_t *DateLen)
{uint16_t index = 0;uint16_t lu16_temp = 0;    uint16_t lu16_RecLen = (uint16_t)(*DateLen);uint16_t lu16_CMDLen = 0;    memset(&ms_LcdCMD,0,sizeof(ms_LcdCMD));//for(;index<len;index++){ms_LcdCMD.cmd_head      = (uint8_t) *(buffer+index);ms_LcdCMD.cmd_head01    = (uint8_t) *(buffer+index+1);    if( ( DIWEN_HEAD_0 == ms_LcdCMD.cmd_head)  && ( DIWEN_HEAD_1 == ms_LcdCMD.cmd_head01)  ){lu16_CMDLen = (uint8_t)(*(buffer+index + M_OFFSET_DW_LEN_POS) );}else{// continue;return 0;}if(lu16_RecLen >= ( lu16_CMDLen + M_DW_HEADER_LEN )){#if(CRC16_ENABLE)if(!CheckCRC16(buffer+M_OFFSET_DW_CMD_POS,lu16_CMDLen - M_CRC_LEN))                      //CRC校验return 0;        #endif     // if(index>0)// {//     memmove(buffer,(buffer+index),sizeof(lu16_CMDLen));// }lu16_temp = (uint16_t)*(buffer+M_OFFSET_DW_CTL_ID);ms_LcdCMD.control_id = ( lu16_temp << 8) + (*(buffer+M_OFFSET_DW_CTL_ID+1)) ;switch (ms_LcdCMD.control_id){//迪文屏内部当前页面ID寄存器地址case DIWEN_PIC_NOW_REG_ADDR:ms_LcdCMD.control_type = M_DW_READ_REG;//第7 8 字节为返回的当前页面IDlu16_temp = (uint16_t)*(buffer+M_OFFSET_DW_CTL_VAL);                ms_LcdCMD.u16val =   ( lu16_temp << 8) + (*(buffer+M_OFFSET_DW_CTL_VAL+1));  ms_LcdCMD.screen_id = ms_LcdCMD.u16val;break;case M_P0_BUTTON_ADDR:           case M_P1_BUTTON_ADDR:    case M_P2_BUTTON_ADDR:   case M_P3_BUTTON_ADDR:    case M_P4_BUTTON_ADDR:    case M_P5_BUTTON_ADDR:    case M_P6_BUTTON_ADDR:    case M_P7_BUTTON_ADDR:                                                                                                               case M_BUTTON_ADDR_END:ms_LcdCMD.control_type = M_BUTTON;//取控件ID的低字节为界面IDms_LcdCMD.screen_id = (uint8_t)(ms_LcdCMD.control_id & 0X00FF);//装载键值//loadup keyvaluelu16_temp = (uint16_t)*(buffer+M_OFFSET_DW_CTL_VAL);                ms_LcdCMD.u16val =   ( lu16_temp << 8) + (*(buffer+M_OFFSET_DW_CTL_VAL+1))   ;return lu16_CMDLen;break;                default:   break;}return  lu16_CMDLen;          }  //endof if(lu16_RecLen >= ( lu16_CMDLen + M_DW_HEADER_LEN ))else{return 0;}}
}/************************************************************************************
函数名称:	App_Screen_Recv()
功能描述:	从屏幕收到的数据处理包括,按键  上报的输入变量等。************************************************************************************/
uint16_t	Class_LcdUart::App_Screen_Recv(void)
{uint16_t    RecvLenth = 0;uint16_t    lu16_Res = 0;// if((TRUE == m_u8_idSendFlag)&&(FALSE == m_u8_idRecvFlag))// {// 	return;// }memset(&ms_LcdCMD,0,sizeof(ms_LcdCMD));lu16_Res = Dat_deUnFixQueueNode(*(ComLcdDiwenObj.pRxQueue),(uint8_t*)&m_u8_RecvBuff[0],&RecvLenth);if( E_QUEUE_NULL == lu16_Res){return 0;}if(0 == RecvLenth){return 0;}    lu16_Res = Screen_CmdCheck((uint8_t*)&m_u8_RecvBuff[0],&RecvLenth );return lu16_Res;
}

代码解析: 

 上面框框里的,是我从迪文屏串口接收队列里面取数据。

整个程序流程是这样的,串口DMA接收中断,收到数据后存进 接收队列里面。

然后再程序的另一个地方进行循环的取队列,然后分析处理。

串口接收入队列部分代码:

//ICCARD  20231109 ADDBYLZW
//Com6Obj 改为 ComIcCardObj
ComPortLinkDef ComIcCardObj		=ComlinkOp[COM2];
//ICCARD  20231109 ADDBYLZW//LCDLCD 20231204 ADDBYLZW
ComPortLinkDef ComLcdDiwenObj	=ComlinkOp[COM4];UnFixQueueDef *qHandleCom3Tx;
UnFixQueueDef *qHandleCom3Rx;
UnFixQueueDef *qHandleCom4Tx;
UnFixQueueDef *qHandleCom4Rx;const ComPortLinkDef ComlinkOp[] =
{// {&qHandleCom2Tx, &qHandleCom2Rx,	&BSP_Com2FramePost},{&qHandleCom3Tx, &qHandleCom3Rx,	&BSP_Com3FramePost},	{&qHandleCom4Tx, &qHandleCom4Rx,	&BSP_Com4FramePost},		
};/*===========================================================================*
*uint8_t    BSP_Com4FramePost(void)*==========================================================================*/
uint8_t    BSP_Com4FramePost(void)
{int16_t ret;	uint16_t DataLen;ret = Dat_GetUnFixQueueFlag(qHandleCom4Tx);if (ret == E_QUEUE_NULL|| ret == ERR_POINTER_NULL){return USART_DATA_ERR;}if (FALSE == usart4_busy){usart4_busy = TRUE;BSP_Com4_CloseTxInt();ret = Dat_deUnFixQueueNode(qHandleCom4Tx,urt4_tx_buf,&DataLen);if(DataLen>UART4_DMA_TX_BUFLEN){return USART_OVERFLOW;}if (E_QUEUE_NORMAL == ret){//errorBSP_Com4_OpenTxInt(DataLen);}else{usart4_busy = FALSE;}}else{return USART_SEND_BUSY;		}return USART_SEND_OK;  
}//20231204 ADDBYLZW LCDLCD OVER

4.识别到按键点击,并切换另一个界面。

 串口切换界面功能实现:

通过向屏幕发送如下数据实现切换屏幕。

注意:

切换的界面ID要和DGUS里面的界面ID对应起来。

代码:

/************************************************************************************
函数名称:	Gui_MeterWindows()
功能描述:	
************************************************************************************/
WinGuiID_TypeDef	Class_LcdUart::Gui_MeterWindows(void)
{static uint16_t ls_u16_cnt;char cbuf[50];    /*判断是否需要  切换界面*///如果 ms_Win.RunSta = 0 说明第一次进入,需要切换串口屏页面if( WIN_STA_FIRSTIN == ms_Win.RunSta)  {ls_u16_cnt = 0;if(IS_WINID_GROUP(ms_Win.Gui_Id)){this->m_NowGunNum = GUN_NULL;  SwitchPage(ms_Win.Gui_Id);            ComLcdDiwenObj.pSendFunc();delay_ms(10); GetPICNow();ComLcdDiwenObj.pSendFunc();delay_ms(10); App_Screen_Recv();     if(ms_LcdCMD.screen_id == ms_Win.Gui_Id ){ms_Win.RunSta = WIN_STA_OVER;   memset(&cbuf,0,sizeof(cbuf));sprintf(cbuf,"          ");DisplayString(TXT_GUN01_STA1_ADDR,cbuf);	//                      DisplayString(TXT_GUN01_STA1_ADDR,cbuf);	//             DisplayString(TXT_GUN01_STA2_ADDR,cbuf);	//    DisplayString(TXT_GUN01_STA3_ADDR,cbuf);	//    DisplayString(TXT_GUN01_STA4_ADDR,cbuf);	//    DisplayString(TXT_GUN01_STA5_ADDR,cbuf);	//    DisplayString(TXT_GUN01_STA6_ADDR,cbuf);	//   DisplayString(TXT_GUN02_STA1_ADDR,cbuf);	//             DisplayString(TXT_GUN02_STA2_ADDR,cbuf);	//    DisplayString(TXT_GUN02_STA3_ADDR,cbuf);	//    DisplayString(TXT_GUN02_STA4_ADDR,cbuf);	//    DisplayString(TXT_GUN02_STA5_ADDR,cbuf);	//    DisplayString(TXT_GUN02_STA6_ADDR,cbuf);	//   mu16F_Refresh =  1;}//读出来的当前页面ID和程序中  ms_Win.Gui_Id 的不一致 报错     else{//#ERROR ERRORreturn ms_Win.Gui_Id;}}// endof if(IS_WINID_GROUP(ms_Win.Gui_Id))else{//ERROR #ERROR/* code */}   } //endof if( ms_Win.Gui_Id != ms_LastWin.Gui_Id)App_Screen_Recv();if( M_BUTTON != ms_LcdCMD.control_type){return ms_Win.Gui_Id;}switch (ms_LcdCMD.u16val){case Key_Exit:ms_Win.Gui_Id = WinID_Gui_StandBy;ms_Win.RunSta = WIN_STA_FIRSTIN;   return     ms_Win.Gui_Id;    break;case Key_Gun2_Icon_Click:break;default:break;}return ms_Win.Gui_Id;
}
uint8_t GetPICNow(void)
{uint8_t lu8_res = 0;uint8_t DiwenSendBuf[10]={0x5A,0xA5,0x04,0x83,0x00,0x14,0x01};	lu8_res = DIWEN_FOR_putn((uint8_t *)DiwenSendBuf,7);		return 	lu8_res;
//    HAL_UART_Transmit(&huart5,(uint8_t *)DiwenSendBuf,10,0xFF);
}uint8_t SwitchPage(unsigned short  int pagenumber)
{uint8_t lu8_res = 0;#if( CORE_T5L ==DIWEN_CORE_TYPE )uint8_t DiwenSendBuf[10]={0x5A,0xA5,0x07,0x82,0x00,0x84,0x5A,0x01,0x00,0x00};	DiwenSendBuf[8]=(uint8_t)(pagenumber>>8);DiwenSendBuf[9]=(uint8_t)(pagenumber);		lu8_res = DIWEN_FOR_putn((uint8_t *)DiwenSendBuf,10);	#elseuint8_t DiwenSendBuf[10]={0x5A,0xA5,0x04,0x80,0x03,0x00,0x01};	DiwenSendBuf[5]=(uint8_t)(pagenumber>>8);DiwenSendBuf[6]=(uint8_t)(pagenumber);		DIWEN_FOR_putn((uint8_t *)DiwenSendBuf,7);	#endifreturn  lu8_res;		
//    HAL_UART_Transmit(&huart5,(uint8_t *)DiwenSendBuf,10,0xFF);
}


 

5.保存、导出、验证。

老规矩,养成好习惯,三连走一波,保存、生成、导出。 

​​​​

然后就大功告成了~~   用SD卡拷贝 DWIN_SET文件夹到SD卡根目录,去烧写屏幕程序验证。

GOOD LUCK~

三、容易踩得坑

注意 SwitchPage  函数切换的界面ID要和DGUS里面的界面ID对应起来。


作为一名头秃并且经常眼干的程序猿,要时刻铭记保护好眼睛啊!!   文哥我是疼粉的,

还是老规矩,文末来个福利图养养眼,放松一下  ~~

这篇关于迪文屏开发保姆级教程6----触摸实现界面切换的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/536904

相关文章

使用Java解析JSON数据并提取特定字段的实现步骤(以提取mailNo为例)

《使用Java解析JSON数据并提取特定字段的实现步骤(以提取mailNo为例)》在现代软件开发中,处理JSON数据是一项非常常见的任务,无论是从API接口获取数据,还是将数据存储为JSON格式,解析... 目录1. 背景介绍1.1 jsON简介1.2 实际案例2. 准备工作2.1 环境搭建2.1.1 添加

Java实现任务管理器性能网络监控数据的方法详解

《Java实现任务管理器性能网络监控数据的方法详解》在现代操作系统中,任务管理器是一个非常重要的工具,用于监控和管理计算机的运行状态,包括CPU使用率、内存占用等,对于开发者和系统管理员来说,了解这些... 目录引言一、背景知识二、准备工作1. Maven依赖2. Gradle依赖三、代码实现四、代码详解五

java如何分布式锁实现和选型

《java如何分布式锁实现和选型》文章介绍了分布式锁的重要性以及在分布式系统中常见的问题和需求,它详细阐述了如何使用分布式锁来确保数据的一致性和系统的高可用性,文章还提供了基于数据库、Redis和Zo... 目录引言:分布式锁的重要性与分布式系统中的常见问题和需求分布式锁的重要性分布式系统中常见的问题和需求

SpringBoot基于MyBatis-Plus实现Lambda Query查询的示例代码

《SpringBoot基于MyBatis-Plus实现LambdaQuery查询的示例代码》MyBatis-Plus是MyBatis的增强工具,简化了数据库操作,并提高了开发效率,它提供了多种查询方... 目录引言基础环境配置依赖配置(Maven)application.yml 配置表结构设计demo_st

python使用watchdog实现文件资源监控

《python使用watchdog实现文件资源监控》watchdog支持跨平台文件资源监控,可以检测指定文件夹下文件及文件夹变动,下面我们来看看Python如何使用watchdog实现文件资源监控吧... python文件监控库watchdogs简介随着Python在各种应用领域中的广泛使用,其生态环境也

el-select下拉选择缓存的实现

《el-select下拉选择缓存的实现》本文主要介绍了在使用el-select实现下拉选择缓存时遇到的问题及解决方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录项目场景:问题描述解决方案:项目场景:从左侧列表中选取字段填入右侧下拉多选框,用户可以对右侧

Python中构建终端应用界面利器Blessed模块的使用

《Python中构建终端应用界面利器Blessed模块的使用》Blessed库作为一个轻量级且功能强大的解决方案,开始在开发者中赢得口碑,今天,我们就一起来探索一下它是如何让终端UI开发变得轻松而高... 目录一、安装与配置:简单、快速、无障碍二、基本功能:从彩色文本到动态交互1. 显示基本内容2. 创建链

基于Qt开发一个简单的OFD阅读器

《基于Qt开发一个简单的OFD阅读器》这篇文章主要为大家详细介绍了如何使用Qt框架开发一个功能强大且性能优异的OFD阅读器,文中的示例代码讲解详细,有需要的小伙伴可以参考一下... 目录摘要引言一、OFD文件格式解析二、文档结构解析三、页面渲染四、用户交互五、性能优化六、示例代码七、未来发展方向八、结论摘要

使用Nginx来共享文件的详细教程

《使用Nginx来共享文件的详细教程》有时我们想共享电脑上的某些文件,一个比较方便的做法是,开一个HTTP服务,指向文件所在的目录,这次我们用nginx来实现这个需求,本文将通过代码示例一步步教你使用... 在本教程中,我们将向您展示如何使用开源 Web 服务器 Nginx 设置文件共享服务器步骤 0 —

Golang使用minio替代文件系统的实战教程

《Golang使用minio替代文件系统的实战教程》本文讨论项目开发中直接文件系统的限制或不足,接着介绍Minio对象存储的优势,同时给出Golang的实际示例代码,包括初始化客户端、读取minio对... 目录文件系统 vs Minio文件系统不足:对象存储:miniogolang连接Minio配置Min