跳到主要内容

FindStrEx 找字Ex

🎯功能

在指定范围内查找指定颜色的文字, 返回所有找到的坐标

📜语法

结果 = dm.FindStrEx(x1, y1, x2, y2, 文字, 颜色, 相似度)

📥参数

参数数据类型解释
x1整型数区域的左上角横坐标
y1整型数区域的左上角纵坐标
x2整型数区域的右下角横坐标
y2整型数区域的右下角纵坐标
文字字符串要查找的文字内容, 可以是多个文字, 例如"紫猫|编程|学园", 多个文字用"|"隔开
颜色字符串大漠综合工具制作字库时使用的颜色, 支持RGB和HSV和灰度, 可以包含换行符, 语法是","后面加分割字符串, 详见示例
相似度双精度浮点数取值范围0.11.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.FindStrEx(0,0,2000,2000,"长安|洛阳","9f2e3f-000000",1.0)
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

📘备注

此函数的原理是先Ocr识别,然后再查找。所以速度比FindStrExFast要慢,尤其是在字库很大,或者模糊度不为1.0时。

一般字库字符数量小于100左右,模糊度为1.0时,用FindStrEx要快一些,否则用FindStrFastEx.