时间:2021-05-20
更新
GitHub中所有类库的源码已经转换为C#版本。
准备
IDE:VisualStudio
Language:C#/VB.NET
GitHub:AutoJump.NET
本文将向你介绍一种通过图像识别实现“跳一跳”机器人的方法。
第一节 图像识别
文中提到的所有方法和步骤只涉及简单的向量计算。
需要用到哪些计算?
比较像素点的颜色
求向量集合的中心
计算颜色的相似度
一个RGB颜色可以看作一个三维向量
比较两个颜色的相似度可以计算它们的欧几里得距离
也可以直接比较它们的夹角:夹角越小,两个颜色越相似,反之亦然
求平面向量集合的中心位置
首先,将集合中所有的向量相加得到向量S
再将向量S除以集合元素的个数,结果即为它们的中心
图1-1 识别效果预览
第二节 识别落点
找出盒子落点的前提是发掘每个盒子都具有的共同特征。
盒子特征
目标落点有两种类型,菱形或圆形的盒子
只有部分盒子的顶面颜色是大面积的纯色
盒子下方的地面背景是纯色,但随着游戏进行颜色会发生变化
顶点特征
顶点的上侧为背景色
顶点的左侧(可能不适用于圆形)、右侧(可能不适用于圆形)均为背景色
识别方法
从上向下逐行扫描像素找出盒子的顶点A
继续向下找出与A颜色相似的所有像素点集合C
求出C像素集合的中心点,即为落点
图2-1 盒子落点识别
第三节 识别角色
角色的颜色相对特殊,很容易从游戏图像中区分出来。
人物特征
角色呈国际象棋棋子状
角色整体颜色较为一致,部分区域有高光
顶点特征
角色的顶点颜色较深,易于区分
识别方法
从上向下逐行扫描像素找出角色的顶点A
继续向下找出与A颜色相似的所有像素点集合C
求出C像素集合的中心点,并向下偏移固定数值
中心点偏移后的像素D的位置即为角色的底部
图3-1 角色底部识别
第四节 识别干扰
通常,简单的方法只适应于绝大部分情况,特定情形时仍会出错。
哪些情况会导致识别错误
盒子顶部的颜色不一致时
角色顶部的位置高于目标盒子时
角色站立的盒子和目标盒子的顶部颜色一致时
其他干扰因素的解决方案
加分提示的动画:延时解决
击中中心的动画:延时解决
音乐盒的乐符动画:不要在音乐盒上停留ヾ(✿゚▽゚)ノ
图4-1 魔方(正确)
图4-2 商店(偏离中心)
图4-3 音乐盒 (偏离中心)
第五节 实测数值
程序的部分参数需要通过实际测试得出。
识别区域
仅屏幕中间的三分之一区域需要进行图像识别
触压时间
触压屏幕的毫秒数正好是角色与落点距离数值的两倍
距离为500个像素点,那么就需要持续按下1000毫秒
该比例适用于1280*720分辨率的设备,不同设备可能需要适当调节
如何计算其他设备分辨率的比例
计算公式:比例=2560/设备屏幕高度
例如1980*1080分辨率的设备,比例为2560/1980=1.29
图5-1 识别区域(阴影部分)
附录
GitHub:AutoJump.NET
参考文章:.NET开发一个微信跳一跳辅助程序
参考书籍:《数学之美》[美]吴军 著人民邮电出版社
语言工具: Code Converter(如果你不了解Basic语法,这个工具将会非常有用)
更多内容大家可以参考专题《微信跳一跳》进行学习。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
之前做了一个淘宝客返利微信公众号,后来很多人提到过微信返利机器人,现在微信助手开发好了,可以通过微信助手接口功能实现微信返利机器人。流程如下:下面是c#实现返利
9月6日,瑞幸咖啡与腾讯签署战略合作协议,双方在线上流量赋能、智慧门店等方面达成合作。微信将线上流量赋能瑞幸,而双方也将共同探索图像识别、人脸支付、机器人配送等
本周微信发布了一个图像识别的SDK,并称图像识别的SDK之后会有更强大的功能。据了解,几个月以前微信发布了一个针对第三方的语音开放平台,加入了语音识别、语音转文
AI即人工智能,是计算机科学的一个分支,它企图了解智能的实质,并生产出一种新的能以人类智能相似的方式做出反应的智能机器,包括机器人、语言识别、图像识别、自然语言
AI技术它是研究、开发用于模拟、延伸和扩展人的智能的理论、方法、技术及应用系统的一门新的技术科学。该领域的研究包括机器人、语言识别、图像识别、自然语言处理和专家