象棋棋谱之棋子识别(二)

简介: 象棋棋谱之棋子识别(二)
  • 先来张效果图


网络异常,图片无法展示
|


  • 处理的方式


图像灰度化->二值化处理->形态学(膨胀)->轮廓提取->得到矩形边框->数据过滤->图像提取->图像匹配
复制代码


  • 得到轮廓矩形边框


#根据轮廓获取最小矩形边框
x, y, w, h = cv.boundingRect(cnts[i])
复制代码


网络异常,图片无法展示
|


  • 数据过滤


#轮廓获取得到的是上面图,下面的会有一些干扰项#通过拿到边框的坐标,然后根据宽高的比例进行过滤,我这里根据宽高的差 
x, y, w, h = cv.boundingRect(cnts[i])
   print(x,y,w,h)
   if(abs(w-h)>20):
     continue
复制代码


  • 数据识别


#识别之前要做的是边框排序,根据上面拿到的轮廓数据#这里按照Y,X递增的方式进行
questionCnts2 = sorted(questionCnts.copy(), key=lambda x: (x[1],x[0]))
#排序我这里遇到了问题,因为每行棋子识别的时候,坐标有些高低差导致排序结果可能跟棋盘显示有些出入#其实识别之后可以根据上一篇文章得到的棋盘表格一步一步的得到棋子,我这里没做#我用了个笨办法处理的 就是每行的Y轴根据个大致范围固定了 
if abs(y - 19) < 20:
   y = 19
 if abs(y - 88) < 20:
   y = 88  
#拿到了边框后我们可以根据边框截取抠图了  
x, y, w, h = questionCnts2[i]    
# print(x, y, w, h)  
im = img[y:y + h, x:x + w]    
#抠图后然后根据模板匹配算法得到最匹配的模板   
result = cv.matchTemplate(cv.resize(old_img,None,fx=0.8, fy=0.8, interpolation = cv.INTER_CUBIC),tempImg,cv.TM_CCOEFF)   
(_, score, _, _) = cv.minMaxLoc(result)   
if check_score == 0 or score > check_score:
   #最大得分项
   check_score = score
   #最大得分项的文件名,然后根据字典获取棋子名称      
   check_img = fileName
复制代码


  • 最终效果图
    这里可以再完善下通过上一篇获取的棋盘信息进行棋盘保存


网络异常,图片无法展示
|

相关文章
象棋棋谱之棋子识别(三)
象棋棋谱之棋子识别(三)
752 1
|
1月前
|
算法
互动游戏解决遇到问题之基于射线投射寻路算法的问题如何解决
互动游戏解决遇到问题之基于射线投射寻路算法的问题如何解决
|
3月前
|
人工智能 BI
技术心得:国王游戏&保护花朵
技术心得:国王游戏&保护花朵
17 0
两句话,ChatGPT帮我写一个打飞机的游戏
两句话,ChatGPT帮我写一个打飞机的游戏
最原始的扫雷,最适合休闲时乐一乐。
最原始的扫雷,最适合休闲时乐一乐。
|
机器学习/深度学习 人工智能 算法
【DouZero】 强化学习+self play达到人类玩家斗地主水平。
【DouZero】 强化学习+self play达到人类玩家斗地主水平。
384 0
|
小程序
做个经典宝石方块游戏
在做了一个月的进阶课程之后,终于又可以回来做游戏了。不得不说,对于我来讲做课程要比做游戏的难的多。做出来是一回事儿,讲出来又是另一回事儿了。尤其是还希望能讲的明白,讲的浅显易懂,感觉还是很难的。不过还好,做课程这件事情也是可以练习的,比如说我现在面对镜头讲一个东西的时候,就比一年前要好很多了。
126 0
|
索引
消除游戏中宝石下落的原理和实现
在消除游戏中,发生消除之后,会留下空白位置。此时,如果上方有其它的宝石,那这些宝石就会下落填充空白位置。今天我们就来了解一下宝石下落的方法以及实现。
151 0
在游戏中实现一场下雨效果
嗨!大家好,我是小蚂蚁。 不知道你喜不喜欢下雨天,我还是蛮喜欢的,尤其是在无所事事或者昏昏欲睡的时候,下雨天和午睡非常的搭。昏暗的天空,噼里啪啦的雨声,加上一张舒适的床,可以睡上一整个下午。 下雨天除了适合睡觉外,还有一种特别的作用,那就是让人安静和放松。可能是因为白噪声的缘故,安静的倾听下雨的声音能够让人戒骄戒躁,恢复内心的平静。
92 0
|
Java C++ Python
受伤的皇后——21年模拟赛
受伤的皇后——21年模拟赛
66 0