函数简介:
查找指定区域内的图片,位图必须是24位色格式,支持透明色,当图像上下左右4个顶点的颜色一样时,则这个颜色将作为透明色处理.
这个函数可以查找多个图片,只返回第一个匹配的X Y坐标.
函数原型:
long FindPicSim(x1, y1, x2, y2, pic_name, delta_color,sim,dir,intX, intY)
参数定义:
x1 整形数:区域的左上X坐标
y1 整形数:区域的左上Y坐标
x2 整形数:区域的右下X坐标
y2 整形数:区域的右下Y坐标
pic_name 字符串:图片名,可以是多个图片,比如"test.bmp|test2.bmp|test3.bmp"
delta_color 字符串:颜色色偏
比如"203040" 表示RGB的色偏分别是20 30 40 (这里是16进制表示).
如果这里的色偏是2位,表示使用灰度找图. 比如"20"
sim 整形数:最小百分比相似率. 表示匹配的颜色占总颜色数的百分比. 其中透明色也算作匹配色. 取值为0到100. 100表示必须完全匹配. 0表示任意颜色都匹配. 只有大于sim的相似率的才会被匹配
dir 整形数:查找方向 0: 从左到右,从上到下 1: 从左到右,从下到上 2: 从右到左,从上到下 3: 从右到左, 从下到上
intX 变参指针:返回图片左上角的X坐标
intY 变参指针:返回图片左上角的Y坐标
返回值:
整形数:
返回找到的图片的序号,从0开始索引.如果没找到返回-1
示例:
dm_ret =
dm.FindPicSim(0,0,2000,2000,"1.bmp|2.bmp|3.bmp","000000",80,0,intX,intY)
If intX >= 0 and intY >= 0 Then
MessageBox "找到"
End If
注:此接口和FindPic类似. 只不过FindPicSim是以颜色百分比来进行匹配. 如果待查找区域内有杂色,只要颜色百分比达到要求,也一样可以匹配.
这个接口是FindPic的进阶版本. 当sim为100时,那么FindPicSim就退化为FindPic
此接口速度很慢,因为需要搜索任何一种可能. 所以尽可能把搜索范围要小一些. 以免耗时太长.