当前位置: 首页 > article >正文

用Python+OpenCV给斗地主做个‘外挂’:手把手教你写个桌面记牌器(附源码)

PythonOpenCV实战打造智能斗地主记牌工具记得去年宿舍通宵打牌时室友总抱怨记不住出过的牌。作为计算机系学生我琢磨着能否用课堂学的OpenCV做个记牌工具。三周后当这个能自动识别桌面上扑克牌的小程序成功运行时那种将理论知识转化为实际应用的成就感至今难忘。下面就把这个结合图像处理与界面开发的完整项目经验分享给大家。1. 开发环境与工具链搭建工欲善其事必先利其器。这个项目需要多个Python库的协同工作建议使用Anaconda创建独立环境conda create -n poker_ai python3.8 conda activate poker_ai pip install opencv-python numpy pyqt5 pillow pywin32核心工具链构成工具版本用途OpenCV4.5图像采集与处理核心库PyQt55.15构建用户界面NumPy1.20数值计算支持Pillow8.0图像格式转换pywin32300Windows系统API调用提示避免混用pip和conda安装可能导致依赖冲突。建议全部使用pip在虚拟环境中安装。常见环境问题解决方案出现DLL加载错误安装VC 2015-2019运行库摄像头无法调用检查权限并更新驱动程序PyQt5样式异常安装Qt官方运行时库2. 屏幕图像采集与预处理精准获取游戏窗口是第一步。我们采用Windows API获取指定窗口的像素数据import win32gui import win32ui from ctypes import windll def capture_window(hwnd): left, top, right, bottom win32gui.GetWindowRect(hwnd) w right - left h bottom - top hwndDC win32gui.GetWindowDC(hwnd) mfcDC win32ui.CreateDCFromHandle(hwndDC) saveDC mfcDC.CreateCompatibleDC() saveBitMap win32ui.CreateBitmap() saveBitMap.CreateCompatibleBitmap(mfcDC, w, h) saveDC.SelectObject(saveBitMap) windll.user32.PrintWindow(hwnd, saveDC.GetSafeHdc(), 2) bmpinfo saveBitMap.GetInfo() bmpstr saveBitMap.GetBitmapBits(True) img np.frombuffer(bmpstr, dtypeuint8).reshape((h, w, 4)) # 释放资源 win32gui.DeleteObject(saveBitMap.GetHandle()) saveDC.DeleteDC() mfcDC.DeleteDC() win32gui.ReleaseDC(hwnd, hwndDC) return cv2.cvtColor(img, cv2.COLOR_BGRA2BGR)关键预处理步骤色彩空间转换BGR→HSV便于颜色阈值处理高斯模糊3×3内核消除噪声边缘检测Canny算法提取牌面轮廓形态学操作闭运算填充内部空隙def preprocess_image(img): hsv cv2.cvtColor(img, cv2.COLOR_BGR2HSV) blur cv2.GaussianBlur(hsv, (3,3), 0) edges cv2.Canny(blur, 50, 150) kernel cv2.getStructuringElement(cv2.MORPH_RECT, (5,5)) closed cv2.morphologyEx(edges, cv2.MORPH_CLOSE, kernel) return closed3. 扑克牌识别核心技术3.1 牌面区域定位通过轮廓分析找到所有可能的扑克牌区域def find_card_contours(processed_img): contours, _ cv2.findContours( processed_img, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE ) cards [] for cnt in contours: peri cv2.arcLength(cnt, True) approx cv2.approxPolyDP(cnt, 0.02*peri, True) if len(approx) 4 and cv2.contourArea(cnt) 1000: x,y,w,h cv2.boundingRect(approx) aspect_ratio w / float(h) if 0.6 aspect_ratio 0.8: cards.append((x,y,w,h)) return sorted(cards, keylambda c: c[0]) # 按x坐标排序3.2 牌面字符识别采用模板匹配与OCR结合的方式花色识别模板匹配def detect_suit(card_img): suits [hearts, diamonds, clubs, spades] best_match None max_val 0 for suit in suits: template cv2.imread(ftemplates/{suit}.png, 0) res cv2.matchTemplate(card_gray, template, cv2.TM_CCOEFF_NORMED) _, val, _, _ cv2.minMaxLoc(res) if val max_val: max_val val best_match suit return best_match if max_val 0.7 else None数字/字母识别OCR预处理流程提取ROI区域二值化处理字符分割使用预训练CNN模型识别4. PyQt5界面设计与功能集成创建带记忆功能的用户界面from PyQt5.QtWidgets import (QApplication, QMainWindow, QLabel, QPushButton, QVBoxLayout, QWidget) class PokerTracker(QMainWindow): def __init__(self): super().__init__() self.setWindowTitle(斗地主智能记牌器) self.setGeometry(100, 100, 400, 600) self.central_widget QWidget() self.layout QVBoxLayout() self.status_label QLabel(等待游戏开始...) self.start_btn QPushButton(开始监控) self.start_btn.clicked.connect(self.start_tracking) self.layout.addWidget(self.status_label) self.layout.addWidget(self.start_btn) self.central_widget.setLayout(self.layout) self.setCentralWidget(self.central_widget) self.played_cards set() self.current_hand [] def start_tracking(self): self.status_label.setText(监控中...) # 启动定时截图线程界面功能亮点实时牌面显示可视化已出牌和剩余牌概率计算根据已出牌计算各玩家持牌概率历史记录保存多局比赛数据热键支持AltS快速截图5. 实战中的坑与解决方案5.1 特效干扰问题当玩家出顺子或炸弹时游戏会显示特效动画导致截图失真。解决方案检测动画帧通过颜色直方图突变延迟100ms后重新截图添加异常重试机制5.2 多分辨率适配不同显示器分辨率导致牌面位置变化。我们采用动态检测窗口尺寸比例计算关键坐标自适应模板缩放def adapt_resolution(window_size): base_w, base_h 1920, 1080 # 基准分辨率 curr_w, curr_h window_size scale_x curr_w / base_w scale_y curr_h / base_h return { card_width: int(80 * scale_x), card_height: int(120 * scale_y), margin_x: int(30 * scale_x), margin_y: int(50 * scale_y) }5.3 性能优化技巧使用ROI减少处理区域缓存模板匹配结果多线程处理UI线程与图像处理线程分离定时器替代循环检测这个项目让我深刻体会到课堂上的图像处理算法真正应用到实际问题时需要考虑的边界条件远超想象。比如最初没想到游戏特效会影响识别直到实战测试才发现这个问题。现在回看这些踩坑经历反而成了最宝贵的收获。

相关文章:

用Python+OpenCV给斗地主做个‘外挂’:手把手教你写个桌面记牌器(附源码)

PythonOpenCV实战:打造智能斗地主记牌工具 记得去年宿舍通宵打牌时,室友总抱怨记不住出过的牌。作为计算机系学生,我琢磨着能否用课堂学的OpenCV做个记牌工具。三周后,当这个能自动识别桌面上扑克牌的小程序成功运行时&#xff0c…...

使用ComfyUI可视化工作流构建NLP-StructBERT语义搜索应用

使用ComfyUI可视化工作流构建NLP-StructBERT语义搜索应用 你是不是觉得,要搭建一个能理解你说话、能精准搜索内容的AI应用,得写一堆复杂的代码,还得懂各种框架?其实,现在有更简单的方法了。今天,我就带你用…...

Rustup离线安装完整指南:在没有网络的环境中搭建Rust开发平台

Rustup离线安装完整指南:在没有网络的环境中搭建Rust开发平台 【免费下载链接】rustup The Rust toolchain installer 项目地址: https://gitcode.com/gh_mirrors/ru/rustup 你是否曾经需要在完全隔离的网络环境中安装Rust开发工具链?&#x1f91…...

Windows安全中心总提示驱动不兼容?手把手教你清理老旧驱动,为内存完整性扫清障碍

Windows驱动深度清理指南:彻底解决内存完整性兼容性问题 每次打开Windows安全中心,那个刺眼的"驱动不兼容"提示总让人心烦?这不仅仅是烦人的弹窗问题,更是系统安全与性能的潜在威胁。作为长期使用Windows的资深用户&…...

技术探索:硬件信息伪装的内核级实现方案

技术探索:硬件信息伪装的内核级实现方案 【免费下载链接】EASY-HWID-SPOOFER 基于内核模式的硬件信息欺骗工具 项目地址: https://gitcode.com/gh_mirrors/ea/EASY-HWID-SPOOFER 如何通过驱动级操作实现系统硬件标识的深度修改? 技术解析&#x…...

炸裂实锤!随手乱按挖出编译器「乱码隐藏保留字」编译报错直接封神

文章目录封面文案一、专栏开篇回顾二、初见疑点:反复刷屏的神秘乱码片段三、三层硬核现场取证,逐层锁死真相1. IDE标识实锤:专属K图标 关键字同款高亮2. 编译现场终极定罪:报错和普通未定义变量完全不同对比区分,一眼…...

【java --mybatis-flex】

基本信息 https://mybatis-flex.com/zh/others/codegen.html 基于mybatis,支持 Entity 的增删改查、以及分页查询的同时,MyBatis-Flex 提供了 Db Row^灵活 工具,可以无需实体类对数据库进行增删改查以及分页查询。 与此同时,MyBa…...

国产隔离器信号孤岛保卫战

国产隔离器正以绝缘屏障铸就信号孤岛——当8kV静电在光伏接线盒上炸出刺目蓝光,当10V/m射频噪声如潮水般淹没地铁信号回波,这条工业设备的生死线上,我们以GB/T 17626标准为矛,以-40℃~85℃环境适应性为盾,在电磁风暴与…...

为什么事故复盘总是写到很晚?

这两天和几个做运维/后端的朋友聊了下事故复盘,发现一个很真实的情况: 👉 大家都知道复盘很重要 👉 但几乎没人愿意写 我问了一个问题: “为什么一份复盘总是要写那么久?” 总结下来基本都是这几个原因&…...

如何彻底掌控Windows Defender:终极禁用与启用指南

如何彻底掌控Windows Defender:终极禁用与启用指南 【免费下载链接】defender-control An open-source windows defender manager. Now you can disable windows defender permanently. 项目地址: https://gitcode.com/gh_mirrors/de/defender-control 你是…...

NRBO - Transformer - BiLSTM回归:Matlab实现的数据预测魔法

NRBO-Transformer-BiLSTM回归 Matlab代码 基于牛顿拉夫逊优化算法优化Transformer结合双向长短期记忆神经网络(BiLSTM)的数据回归预测(可以更换为分类/单、多变量时序预测/回归,前私我),Matlab代码,可直接运行,适合小白新手 程序已…...

Z-Image-Turbo LoRA Web服务GPU优化:显存碎片整理与长期运行稳定性保障

Z-Image-Turbo LoRA Web服务GPU优化:显存碎片整理与长期运行稳定性保障 1. 项目概述与核心价值 今天要跟大家分享的是一个基于Z-Image-Turbo模型的图片生成Web服务,重点解决了GPU显存管理和长期稳定运行的关键问题。这个服务不仅支持高质量的图片生成&…...

Openclaw 股票分析助手,自定义选股+情绪预警实时推送

最近我越来越觉得,炒股这件事,难的不是完全看不懂,而是你根本没那么多时间,把该看的东西全都看一遍。平时工作忙一点,白天不是在开会,就是在处理各种事情。别说一直盯着盘面了,有时候连行情软件…...

CG迷李辰全面掌握ComfyUI系统教程2025年结课(超清画质带大部分素材)

全面掌握 ComfyUI:AI 设计变现新技能,经济收益深度解析在生成式人工智能(AIGC)从“尝鲜玩具”向“生产力工具”转型的2025-2026年,设计行业的经济逻辑正在经历一场剧烈的重构。当简单的文本生成图像(Text-t…...

PP-DocLayoutV3产业应用效果:金融票据与医疗报告的结构化

PP-DocLayoutV3产业应用效果:金融票据与医疗报告的结构化 每次看到财务同事抱着一沓厚厚的银行流水单手动录入数据,或者医生在成堆的化验单里翻找关键指标,我就在想,这事儿能不能让机器来干?过去,文档智能…...

技能组合艺术:OpenClaw串联QwQ-32B实现复杂工作流

技能组合艺术:OpenClaw串联QwQ-32B实现复杂工作流 1. 为什么需要工作流串联 当我第一次接触OpenClaw时,最让我兴奋的不是它能完成某个单一任务,而是它能够将多个技能像乐高积木一样组合起来。这种能力让我想到了现实工作中的场景——很少有…...

基于北方苍鹰优化算法优化径向基函数神经网络(NGO - RBF)的时间序列预测

基于北方苍鹰优化算法优化径向基函数神经网络(NGO-RBF)的时间序列预测 NGO-RBF时间序列 优化参数为扩散速度,采用交叉验证防止过拟合 matlab代码注:暂无Matlab版本要求 -- 推荐 2018B 版本及以上在时间序列预测领域,寻找高效准确的模型一直是…...

MongoDB从零基础搭建到实战

MongoDB从零基础搭建到实战 MongoDB作为当下最流行的开源文档型NoSQL数据库,凭借灵活的文档结构、高扩展性和易用性,成为前后端开发、大数据存储、云原生项目的首选数据库之一。相比传统关系型数据库,它无需严格预定义表结构,适配…...

医用擦拭纸选购指南:看懂这五大认证,避开医疗耗材采购“隐形坑

# 医用擦拭纸选购指南:看懂这五大认证,避开医疗耗材采购“隐形坑”> 在医疗领域,每一片看似普通的擦拭纸,都直接关系到诊疗安全、院感控制和患者健康。对于医疗器械经销商、医院后勤管理者而言,选择供应商时最核心的…...

Vivado综合策略的‘隐藏菜单’:手把手教你用TCL定制专属策略,榨干UltraScale+性能

Vivado综合策略的‘隐藏菜单’:手把手教你用TCL定制专属策略,榨干UltraScale性能 当你在Vivado中点击"Run Synthesis"时,是否曾好奇那些预设策略背后究竟发生了什么?对于大多数FPGA设计,Vivado提供的预设策略…...

Verilog新手避坑指南:从HDLBits的Getting Started到Vectors,我踩过的那些坑

Verilog新手避坑指南:从HDLBits的Getting Started到Vectors,我踩过的那些坑 第一次接触Verilog时,我像大多数初学者一样,被它既像C语言又不像C语言的语法搞得晕头转向。HDLBits这个在线练习平台确实是个好帮手,但当我从…...

2026 GitHub 高星项目全景指南

一、GitHub 全球 Star 最高项目(2026年3月 实时数据) GitHub 无官方总 Star 榜单,以下为综合第三方统计与实时检索的全球高星项目 Top10,数据动态更新,以仓库主页为准: 排名 项目名称 Star 数 核心定位 1 build-your-own-x ⭐47.4万+ 从零实现各类技术的教程合集 2 awes…...

openclaw喂饭教程!在 Linux 环境下快速完成安装、初始化与 Web UI 配置

基础示例:单工作表 Excel 转 TXT 以下是将一个 Excel 文件中的第一个工作表转换为 TXT 的完整步骤: 1. 加载并读取Excel文件 from spire.xls import * from spire.xls.common import * workbook Workbook() workbook.LoadFromFile("示例.xlsx"…...

松江少儿英语口碑好的?

松江少儿英语口碑好的 环球乐学少儿英语,指出幼儿英语学习三大痛点: 1. 兴趣不足易抵触:教学形式枯燥,多以机械记单词、跟读为主,不符合幼儿认知特点,易产生厌学情绪。 2. 缺语境不会运用&#xff1a…...

DTII(A) 9.12.2、带调节挡板漏斗

示意图主视图侧视图C向法兰口Z向:操纵杆安装位置【说明】【表9-48】带调节挡板漏斗相关参数参数说明其它参数同 “普通漏斗”;【L5】调节挡板底座 与 漏斗壁 距离。【260】调节挡板底座长度。【注意】...

FastAdmin框架旧版本踩坑记:手把手教你修复那个能读任意文件的CVE-2024-7928漏洞

FastAdmin框架安全实战:深度解析CVE-2024-7928漏洞修复与防御策略 当安全扫描报告突然标红显示"FastAdmin框架存在任意文件读取漏洞(CVE-2024-7928)"时,作为项目负责人的你可能会瞬间心跳加速。这个看似简单的漏洞编号背…...

掌握Agentic RAG:动态智能代理,提升大模型学习与实战效率,CSDN小白程序员必收藏!

掌握Agentic RAG:动态智能代理,提升大模型学习与实战效率,CSDN小白程序员必收藏! Agentic RAG技术通过引入自主AI代理,解决了传统RAG系统依赖静态数据的局限性,实现实时检索最新数据,灵活调整策…...

AgentScope Java:阿里开源的多智能体框架,让AI应用开发变得简单

为什么我们需要Agent框架? 如果你开发过AI应用,一定遇到过这些问题: LLM只能生成文本,无法查询数据库、调用API、执行计算多轮对话需要管理上下文,但手动维护消息历史太繁琐复杂的任务需要多步推理,简单的…...

掌握4大核心策略,让你的暗黑3效率提升200%:D3KeyHelper自动化配置全指南

掌握4大核心策略,让你的暗黑3效率提升200%:D3KeyHelper自动化配置全指南 【免费下载链接】D3keyHelper D3KeyHelper是一个有图形界面,可自定义配置的暗黑3鼠标宏工具。 项目地址: https://gitcode.com/gh_mirrors/d3/D3keyHelper D3Ke…...

解锁炉石传说终极体验:HsMod插件效率革命全指南

解锁炉石传说终极体验:HsMod插件效率革命全指南 【免费下载链接】HsMod Hearthstone Modify Based on BepInEx 项目地址: https://gitcode.com/GitHub_Trending/hs/HsMod 你是否曾因炉石传说漫长的动画等待而失去耐心?是否希望自定义游戏界面却苦…...