2019-10-15 18:12发布
正点原子 发表于 2013-6-29 23:30 这几个定死 了的东西,得你自己去测试得出实际数据了,也就是获取4个顶点的X,Y,坐标物理值,然后记录下来 ...
最多设置5个标签!
---------------------------------
原子哥 我是这样弄的:屏是3.5寸的
#define GUI_TOUCH_AD_LEFT 0
#define GUI_TOUCH_AD_RIGHT 320
#define GUI_TOUCH_AD_TOP 0
#define GUI_TOUCH_AD_BOTTOM 480
#define GUI_TOUCH_SWAP_XY 0
#define GUI_TOUCH_MIRROR_X 0
#define GUI_TOUCH_MIRROR_Y 0
void GUI_TOUCH_X_ActivateX(void) {
}
void GUI_TOUCH_X_ActivateY(void) {
}
int GUI_TOUCH_X_MeasureY(void) {
tp_dev.scan(0);
return tp_dev.y;
}
int GUI_TOUCH_X_MeasureX(void) {
tp_dev.scan(0);
return tp_dev.x;
}
GUI_TOUCH_Exec()修改了,去除了他原来的状态机方法,因为X,Y直接是通过原子哥底层的触摸程序得到经过转换的逻辑坐标值,去除了GUI_TOUCH_Exec里的AD2X()和AD2Y() 直接返回XY就可以用了,很准,
GUI_TOUCH_Exec()修改如下:
void GUI_TOUCH_Exec(void) {
#ifndef WIN32
static U8 ReadState;
int x,y;
/* calculate Min / Max values */
if (xyMinMax[GUI_COORD_X].Min < xyMinMax[GUI_COORD_X].Max) {
xMin = xyMinMax[GUI_COORD_X].Min;
xMax = xyMinMax[GUI_COORD_X].Max;
} else {
xMax = xyMinMax[GUI_COORD_X].Min;
xMin = xyMinMax[GUI_COORD_X].Max;
}
if (xyMinMax[GUI_COORD_Y].Min < xyMinMax[GUI_COORD_Y].Max) {
yMin = xyMinMax[GUI_COORD_Y].Min;
yMax = xyMinMax[GUI_COORD_Y].Max;
} else {
yMax = xyMinMax[GUI_COORD_Y].Min;
yMin = xyMinMax[GUI_COORD_Y].Max;
}
/* Execute the state machine which reads the touch */
yPhys = TOUCH_X_MeasureY();
xPhys = TOUCH_X_MeasureX();
/* Convert values into logical values */
#if !GUI_TOUCH_SWAP_XY /* Is X/Y swapped ? */
x = xPhys;
y = yPhys;
#else
x = yPhys;
y = xPhys;
#endif
if ((x < xMin) || (x > xMax) || (y < yMin) || (y > yMax)) {
_StoreUnstable(-1, -1);
} else {
_StoreUnstable(x, y);
}
#endif /* WIN32 */
}
准是准但是向左滑有箭头的拖尾现象未解决
---------------------------------
可以把例子上传下吗?
回复【4楼】wan296555869:
---------------------------------
一次点击触摸屏的4个最顶端,得到的坐标,来设置这几个值了
---------------------------------
不明白啊?4个顶点各有X和Y2个参数 这里只要填4个参数 我是填X坐标的AD值还是Y坐标的AD值呢??
拖尾,是你读点的问题吧。
---------------------------------
搞了好久终于发现原子哥的读点函数中对6804ic读了3次,导致最后返回的颜 {MOD}是下一个点的颜 {MOD},出现拖尾,改了就好了
不可能量产也一个个测试记录吧?
ucgui内部没有自校准函数吗?
一周热门 更多>