函数简介:

查找指定区域内的图片,位图必须是24位色格式,支持透明色,当图像上下左右4个顶点的颜色一样时,则这个颜色将作为透明色处理.

这个函数可以查找多个图片, 只返回第一个匹配的X Y坐标.

易语言用不了FindPicSim可以用此接口来代替

函数原型:

string FindPicSimE(x1, y1, x2, y2, pic_name, delta_color,sim,dir)

参数定义:

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
整形数: 最小百分比相似率. 表示匹配的颜色占总颜色数的百分比. 其中透明色也算作匹配色. 取值为0100. 100表示必须完全匹配. 0表示任意颜色都匹配. 只有大于sim的相似率的才会被匹配
dir
整形数:查找方向 0: 从左到右,从上到下 1: 从左到右,从下到上 2: 从右到左,从上到下 3: 从右到左, 从下到上

返回值:

字符串:
返回找到的图片序号(0开始索引)以及XY坐标 形式如"index|x|y", 比如"3|100|200"

示例:


pos = dm.FindPicSimE(0,0,2000,2000,"1.bmp|2.bmp|3.bmp","000000",80,1)
pos = split(pos,"|")
If int(pos(1)) > 0 Then
    MessageBox "
找到"
End If
:此接口和FindPicE类似. 只不过FindPicSimE是以颜色百分比来进行匹配. 如果待查找区域内有杂色,只要颜色百分比达到要求,也一样可以匹配.
这个接口是FindPicE的进阶版本. sim100,那么FindPicSimE就退化为FindPicE
此接口速度很慢,因为需要搜索任何一种可能. 所以尽可能把搜索范围要小一些. 以免耗时太长.