我是使用自己的板子(主控也是STM32F107ZET6)驱动正点原子4.3寸的电容屏,屏幕的驱动硬件大部分都是一样的,只有触摸屏的4个控制引脚不一样,所以我在程序中做了修改。例程里使用的是查询的方式获取触摸屏的坐标,但是我个人觉得查询的方式效率太低了,就再次修改了例程里的源代码,把查询改为中断方式获取触摸屏的坐标。修改后的代码,在触摸屏幕时,已经可以通过中断返回当前的坐标了(我用串口打印出来看了,触摸屏返回的坐标值的范围在800*480以内,5点同时触摸也没有问题),但是获取完坐标以后,我调用了ctp_test();这个函数(这个函数我也修改过,注释了LCD画线的语句,改为在屏幕上显示坐标),但是屏幕上却只能显示大概480*460的范围了,不知道卡在哪儿了。
PC5 --> CT_INT //程序中通过PC5的下降沿触发中断
PA7 --> CT_SDA
PA5 --> CT_SCL
PB1 --> CT_RST
[mw_shl_code=c,true]//??????????????????
void ctp_test(void)
{
u8 t=0;
u16 lastpos[5][2]; //×??ó??????????
for(t=0;t<CT_MAX_TOUCH;t++)
{
if((tp_dev.sta)&(1<<t))
{
if(tp_dev.x[t]<lcddev.width&&tp_dev.y[t]<lcddev.height)
{
if(lastpos[t][0]==0XFFFF)
{
lastpos[t][0] = tp_dev.x[t];
lastpos[t][1] = tp_dev.y[t];
}
// lcd_draw_bline(lastpos[t][0],lastpos[t][1],tp_dev.x[t],tp_dev.y[t],2,POINT_COLOR_TBL[t]);//????
printf("%dth position x:%d\ty:%d\r\n",t,tp_dev.x[t],tp_dev.y[t]); //?ò??×?±ê
LCD_ShowxNum(10,10,tp_dev.x[t],3,16,0);
LCD_ShowxNum(10,30,tp_dev.y[t],3,16,0);
if(tp_dev.x[t]>(lcddev.width-24)&&tp_dev.y[t]<16)
{
Load_Drow_Dialog();//????
}
}
}else lastpos[t][0]=0XFFFF;
}
} [/mw_shl_code]
|