MTK MMI event 小结 9
2010-08-12 17:41
435 查看
到这里 pen event 其实也就差不多了,说一下几个常用的函数:
mmi_pen_enable /mmi_pen_disable //打开/关闭 pen 事件
mmi_pen_set_calibration_data / mmi_pen_read_calibration_data //设置和读取校准数据,校准数据总共四个值 x = x*x_scale + x_offset, y = y*y_scale + y_offset
mmi_pen_start_calibration // 开始校准
mmi_pen_start_capture_strokes / mmi_pen_stop_capture_strokes //在设定区域里 开始和关闭 捕捉输入法轨迹(stroke)点。具体可以参见 EntryEmPenTest 里面用法,有机会在分析MTK手写输入法
mmi_pen_config_move_offset / mmi_pen_config_timeout_period / mmi_pen_config_sampling_period //几个配置函数,对于写一个好的触摸屏应用,还是很有必要的,相关介绍看 MTK MMI event 小结 7
mmi_pen_register_move(up down repeat …)_handler //注册pen 事件处理函数。
对于触摸屏校准,做一个简单的说明:
当调用 void mmi_pen_start_calibration(kal_uint16 num, const mmi_pen_point_struct *points) 函数时,就开始进入触摸屏校准状态,一旦调用这个函数,那么收到点将都是没有校准过的,直到校准完成。num 表示校准的个数,MTK是3个,points 分别就是理想点的位置(可能不好理解,就是屏幕上显示需要点击的3个点)
真正执行校准的是在 函数 touch_excute_cali里面
其实校准是否正确 还是主要看 touch_panel_check_cali 这个函数的结果。这个函数主要里有 3 个校准测试,只有都符合条件才符合。
stage 1 比例对比,也就是保证测试点1 和 点 2 倾斜一定的角度。不会与x 轴或者y轴平行
stage 2 保证第1 点 和 第 2 点 在 第3 点的 两端
stage 3 根据stage 1 和 stage 2 得出的slope 和 offset, 比较计算获得的第3点 和 希望获得第3点 误差小于 设定值。
这几个函数就是几个数学公式,自己研究研究 就Ok 了。
mmi_pen_enable /mmi_pen_disable //打开/关闭 pen 事件
mmi_pen_set_calibration_data / mmi_pen_read_calibration_data //设置和读取校准数据,校准数据总共四个值 x = x*x_scale + x_offset, y = y*y_scale + y_offset
mmi_pen_start_calibration // 开始校准
mmi_pen_start_capture_strokes / mmi_pen_stop_capture_strokes //在设定区域里 开始和关闭 捕捉输入法轨迹(stroke)点。具体可以参见 EntryEmPenTest 里面用法,有机会在分析MTK手写输入法
mmi_pen_config_move_offset / mmi_pen_config_timeout_period / mmi_pen_config_sampling_period //几个配置函数,对于写一个好的触摸屏应用,还是很有必要的,相关介绍看 MTK MMI event 小结 7
mmi_pen_register_move(up down repeat …)_handler //注册pen 事件处理函数。
对于触摸屏校准,做一个简单的说明:
当调用 void mmi_pen_start_calibration(kal_uint16 num, const mmi_pen_point_struct *points) 函数时,就开始进入触摸屏校准状态,一旦调用这个函数,那么收到点将都是没有校准过的,直到校准完成。num 表示校准的个数,MTK是3个,points 分别就是理想点的位置(可能不好理解,就是屏幕上显示需要点击的3个点)
真正执行校准的是在 函数 touch_excute_cali里面
void touch_excute_cali(kal_int16 x_adc, kal_int16 y_adc) { ilm_struct *tp_ilm; tp_cali_done_struct *local_para; kal_bool cali_result; module_type owner=0; // 校准是否被激活,调用 mmi_pen_start_calibration 后,就为true if(tp_cali_mode==KAL_FALSE) return; // 校准第一个点 if(tp_cali_cnt==0) { tp_cali_cnt++; // 记录获取的adc 点(实际物理点坐标) cali_point_adc[0].x=x_adc; cali_point_adc[0].y=y_adc; } // 第二个点 else if(tp_cali_cnt==1) { tp_cali_cnt++; cali_point_adc[1].x=x_adc; cali_point_adc[1].y=y_adc; } // 第三个点 else if(tp_cali_cnt==2) { cali_point_adc[2].x=x_adc; cali_point_adc[2].y=y_adc; tp_cali_mode=KAL_FALSE; tp_cali_cnt=0; // 对校准进行计算 cali_result=touch_panel_check_cali(); if(cali_result==KAL_TRUE) { // 校准ok ,分别计算 x 和 y 的 slope 和 offset touch_panel_tuning(cali_point[0].x, cali_point_adc[0].x, cali_point[1].x, cali_point_adc[1].x, &TPCali.x_slope, &TPCali.x_offset); touch_panel_tuning(cali_point[0].y, cali_point_adc[0].y, cali_point[1].y, cali_point_adc[1].y, &TPCali.y_slope, &TPCali.y_offset); } // 发送消息告诉MMI , 校准的结果. // 如果失败,MMI 需要重新校准 local_para = (tp_cali_done_struct *) construct_local_para(sizeof(tp_cali_done_struct),TD_UL); local_para->result=cali_result; owner=MOD_MMI; DRV_BuildPrimitive(tp_ilm, MOD_TP_TASK, owner, MSG_ID_TP_CALI_DONE, local_para); msg_send_ext_queue(tp_ilm); } }
其实校准是否正确 还是主要看 touch_panel_check_cali 这个函数的结果。这个函数主要里有 3 个校准测试,只有都符合条件才符合。
stage 1 比例对比,也就是保证测试点1 和 点 2 倾斜一定的角度。不会与x 轴或者y轴平行
stage 2 保证第1 点 和 第 2 点 在 第3 点的 两端
stage 3 根据stage 1 和 stage 2 得出的slope 和 offset, 比较计算获得的第3点 和 希望获得第3点 误差小于 设定值。
这几个函数就是几个数学公式,自己研究研究 就Ok 了。
相关文章推荐
- MTK MMI event 小结 2
- MTK MMI event 小结 4
- MTK MMI event 小结 6
- MTK MMI event 小结 9
- MTK MMI event 小结 8
- MTK MMI event 小结 8
- MTK MMI event 小结 7
- MTK MMI event 小结 6
- MTK MMI event 小结 7
- MTK MMI event 小结 5
- MTK MMI event 小结 4
- MTK MMI event 小结
- MTK MMI event 小结 3
- MTK MMI event 小结 3
- MTK MMI event 小结 1
- MTK MMI event 小结 5
- MTK MMI event
- MTK平台camera小结(一)
- MTK(3G)手机开发初学者必备资料(MMI)
- MTK 图层 MTK平台MMI窗口的绘制