FindStrFastEx 快速找字Ex
🎯功能
在指定范围内快速查找指定颜色的文字, 返回找到的所有序号和坐标
📜语法
结果 = dm.FindStrFastEx(x1, y1, x2, y2, 文字, 颜色, 相似度)
📥参数
参数 | 数据类型 | 解释 |
---|---|---|
x1 | 整型数 | 区域的左上角横坐标 |
y1 | 整型数 | 区域的左上角纵坐标 |
x2 | 整型数 | 区域的右下角横坐标 |
y2 | 整型数 | 区域的右下角纵坐标 |
文字 | 字符串 | 要查找的文字内容, 可以是多个文字, 例如"紫猫|编程|学园" , 多个文字用"|" 隔开 |
颜色 | 字符串 | 大漠综合工具制作字库时使用的颜色, 支持RGB和HSV和灰度, 可以包含换行符, 语法是"," 后面加分割字符串, 详见示例 |
相似度 | 双精度浮点数 | 取值范围0.1 到1.0 , 越大越相似 |
📤返回
字符串
, 返回所有找到的坐标集合,格式如下:"id,x0,y0|id,x1,y1|......|id,xn,yn"
, 比如"0,100,20|2,30,40"
表示找到了两个,第一个,对应的是序号为0的字符串,坐标是(100,20),第二个是序号为2的字符串,坐标(30,40)
💡示例
dm_ret = dm.FindStrFastEx(0,0,2000,2000,"长安|洛阳","9f2e3f-000000",0.9)
If len(dm_ret) > 0 Then
ss = split(dm_ret,"|")
index = 0
count = UBound(ss) + 1
Do While index < count
TracePrint ss(index)
sss = split(ss(index),",")
id = int(sss(0))
x = int(sss(1))
y = int(sss(2))
dm.MoveTo x,y
Delay 1000
index = index+1
Loop
End If
📘备注
此函数比FindStrEx
要快很多,尤其是在字库很大时,或者模糊识别时,效果非常明显。推荐使用此函数。
另外由于此函数是只识别待查找的字符,所以可能会有如下情况出现问题。
比如 字库中有"张和三" 一共3个字符数据,然后待识别区域里是"张和三",如果用FindStrEx
查找"张三"肯定是找不到的,但是用FindStrFastEx
却可以找到,因为"和"这个字符没有列入查找计划中. 所以,在使用此函数时,也要特别注意这一点。