漫谈WinCE的手写识别技术(一)
//========================================================================
本文引用地址:https://www.eepw.com.cn/article/201609/304832.htm//TITLE:
// 漫谈WinCE的手写识别技术(一)
//AUTHOR:
// norains
//DATE:
// Wednesday 24-January -2007
//Environment:
// EVC4.0 + Standard SDK
//========================================================================
WinCE从4.0开始,集成了手写识别输入法,可以识别繁体中文,日文和韩文.因此如果在WinCE下采用相应的API函数重写上述三种语言的手写识别输入似乎显得多此一举.但多余并不代表没有了解的价值,今天,就让我们抽丝剥茧来探究WinCE下的手写识别吧!
大体上来说,调用WinCE自带的识别引擎进行文字识别需要经过如下十个步骤:
1.调用HwxConfig ()函数初始化识别引擎.在每个应用程序中,该初始化只需要调用一次.
2.调用HwxCreate()创建识别引擎句柄.
函数原型为:HRC HwxCreate(HRC hrc).该函数有个形参hrc,保存的是已存在的识别引擎句柄.如果传入该形参,则可以根据已存在的引擎的设置来创建新的识别引擎.当然通常情况下我们仅仅是创建一个新的引擎,所以该函数更多情况下是不使用形参:
3.调用HwxSetGuide()函数来设置识别框的范围.
设置该识别框范围的重要性不言而喻,因为如果设置不恰当,则直接导致识别出错甚至无法识别.
该函数传入的形参是一个HWXGUIDE结构,该结构包含了识别框的一切信息:

typedef struct tagHWXGUIDE {

UINT cHorzBox;

UINT cVertBox;

INT xOrigin;

INT yOrigin;

UINT cxBox;

UINT cyBox;

UINT cxOffset;

UINT cyOffset;

UINT cxWriting;

UINT cyWriting;

UINT cyMid;

UINT cyBase;

UINT nDir;

} HWXGUIDE, *PHWXGUIDE;
如果用文字来描述各个形参的含义,我实在没这个能力让语言读起来不觉得乏味,所以最简单最直接最直观的方法,我还是用图片来标识出各个参数的含义,至少应该不会让脑袋觉得发晕:

xOriginy,Origin分别定义了识别框的起始坐标,而cxBox,cyBox则分别定义了识别框的长度和宽度.需要注意的是,这四个参数是以屏幕坐标为基准,如果我们获得的是应用程序窗口的坐标,在赋值之前,我们需要调用MapWindowPoints()进行转换.当然,相同的道理也同样运用于该结构的其它形参.
nDir定义了书写的顺序,我们一般使用HWX_HORIZONTAL,表明书写方式是水平书写.当然,如果有特殊要求,我们还可以设置HWX_BIDIRECTIONAL或HWX_VERTICAL.
4.调用HwxALCValid()和HwxALCPriority()定义识别的标准.
HwxALCValid()用来定义识别字符的范围,HwxALCPriority()则是定义返回字符的优先级.
根据帮助文档,可以识别的字符文字为:简体中文,繁体中文,日文,韩文和英文.但在实际使用中,却是无法正确识别简体中文,这不能不说是一个遗憾.在平时应用中,我们一般只需识别一种文字,此时我们可以只是简单地设置HwxALCValid()即可:
评论