MTK MMI event 小结 9

到这里 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里面

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 了。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值