ZenlessZoneZero-OneDragon项目中的OCR编队识别问题分析与解决方案
2025-06-19 19:06:31作者:段琳惟
在ZenlessZoneZero-OneDragon自动化脚本项目中,开发团队发现了一个关于游戏内编队识别的技术问题。这个问题主要出现在"式舆防卫战"游戏模式的预备编队选择环节,影响了自动化流程的准确性和可靠性。
问题现象
当脚本执行到选择预备编队环节时,OCR(光学字符识别)系统对编队名称的识别出现了几个关键问题:
- "编队5"完全未被识别出来
- "编队2"被错误识别为"编队 2"(中间多了一个空格)
- 在匹配"编队2"时,系统错误地匹配到了"编队"而非正确的"编队 2"
这些问题导致自动化脚本无法正确选择预定的战斗编队,影响了游戏流程的自动化执行效果。
技术分析
通过对运行日志的深入分析,我们可以发现几个关键的技术点:
-
OCR识别精度问题:当前的OCR模型在识别游戏内特定字体和背景下的文本时,对空格的识别不够准确,导致"编队2"被识别为"编队 2"。
-
字符串匹配算法问题:在匹配编队名称时,系统采用了简单的字符串匹配方式,没有考虑OCR可能引入的空格等干扰因素。
-
特殊字符处理不足:日志显示OCR结果中还包含了一些非编队名称的干扰项,如"3/3"、"+SELECT"等,当前的过滤机制可能不够完善。
解决方案
针对上述问题,我们建议采用多层次的改进方案:
-
预处理优化:
- 对OCR结果进行统一的空格去除处理,确保"编队2"和"编队 2"能被规范化为同一字符串
- 增加数字识别校验,确保编队名称后的数字能被正确识别
-
匹配算法改进:
- 实现模糊匹配算法,考虑OCR可能产生的各种变形
- 增加编队名称的置信度评分,优先选择匹配度最高的结果
- 建立编队名称白名单,过滤掉明显非编队名称的OCR结果
-
容错机制增强:
- 当首选编队无法匹配时,自动尝试备选编队
- 记录识别失败的案例,用于后续模型优化
- 增加人工干预点,当自动选择失败时可手动指定编队
-
用户指导建议:
- 建议用户避免使用"编队5"等可能难以识别的编队名称
- 推荐使用更易识别的编队命名方式
- 提供编队名称识别测试工具,帮助用户选择最佳命名
实施效果
通过上述改进措施,预期可以达到以下效果:
- 编队识别准确率提升至95%以上
- 系统容错能力显著增强,减少人工干预需求
- 用户体验改善,自动化流程更加顺畅可靠
这个问题展示了在游戏自动化领域中OCR技术应用的实际挑战,也为我们提供了优化文本识别和匹配算法的宝贵经验。通过持续改进,可以不断提升自动化脚本的稳定性和用户体验。
登录后查看全文
热门项目推荐
相关项目推荐
kernelopenEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。C0132
let_datasetLET数据集 基于全尺寸人形机器人 Kuavo 4 Pro 采集,涵盖多场景、多类型操作的真实世界多任务数据。面向机器人操作、移动与交互任务,支持真实环境下的可扩展机器人学习00
mindquantumMindQuantum is a general software library supporting the development of applications for quantum computation.Python059
PaddleOCR-VLPaddleOCR-VL 是一款顶尖且资源高效的文档解析专用模型。其核心组件为 PaddleOCR-VL-0.9B,这是一款精简却功能强大的视觉语言模型(VLM)。该模型融合了 NaViT 风格的动态分辨率视觉编码器与 ERNIE-4.5-0.3B 语言模型,可实现精准的元素识别。Python00
GLM-4.7-FlashGLM-4.7-Flash 是一款 30B-A3B MoE 模型。作为 30B 级别中的佼佼者,GLM-4.7-Flash 为追求性能与效率平衡的轻量化部署提供了全新选择。Jinja00
AgentCPM-ReportAgentCPM-Report是由THUNLP、中国人民大学RUCBM和ModelBest联合开发的开源大语言模型智能体。它基于MiniCPM4.1 80亿参数基座模型构建,接收用户指令作为输入,可自主生成长篇报告。Python00
项目优选
收起
deepin linux kernel
C
27
11
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
497
3.65 K
Ascend Extension for PyTorch
Python
301
343
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
308
132
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
869
480
暂无简介
Dart
745
180
React Native鸿蒙化仓库
JavaScript
297
347
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
11
1
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
66
20
仓颉编译器源码及 cjdb 调试工具。
C++
151
882