使用OpenCV计算滑块缺口

news/2024/10/25 8:17:45/

1.参考文章:https://blog.csdn.net/qq_27371025/article/details/133072065
2.实现过程:接口中传入base64 图片,base64转化为image ,通过图片获取缺口信息
实现步骤:
2.1 安装:cv2
opencv-python 是 OpenCV(Open Source Computer Vision Library)的 Python 绑定。OpenCV 是一个开源的计算机视觉和机器学习库,包含了大量的图像处理函数和计算机视觉算法。通过 opencv-python,Python 开发者能够方便地使用这些功能和算法来处理图像和视频数据。

pip install opencv-python
pip install opencv-contrib-python
def show(name):'''展示圈出来的位置'''cv2.imshow('Show', name)cv2.waitKey(0)cv2.destroyAllWindows()def _tran_canny(image):"""消除噪声"""image = cv2.GaussianBlur(image, (3, 3), 0)return cv2.Canny(image, 50, 150)def detect_displacement(img_slider_path, image_background_path):"""detect displacement"""# # 参数0是灰度模式image = cv2.imread(img_slider_path, 0)template = cv2.imread(image_background_path, 0)# 寻找最佳匹配res = cv2.matchTemplate(_tran_canny(image), _tran_canny(template), cv2.TM_CCOEFF_NORMED)# 最小值,最大值,并得到最小值, 最大值的索引min_val, max_val, min_loc, max_loc = cv2.minMaxLoc(res)top_left = min_loc[0]  # 横坐标# 展示圈出来的区域x, y = min_loc  # 获取x,y位置坐标w, h = image.shape[::-1]  # 宽高cv2.rectangle(template, (x, y), (x+w, y+h), (0, 0, 255), 2) #左上 右下 边框颜色,线条厚度# show(template)top_left = x+wreturn top_leftdef base64_change_image(base64_str,type):# 移除base64字符串中的前缀(例如 'data:image/jpeg;base64,')base64_img_bytes = base64_str.split(',')[1]# 解码base64字符串为字节img_bytes = base64.b64decode(base64_img_bytes)# 将字节转换为numpy数组nparr = np.frombuffer(img_bytes, np.uint8)# 将numpy数组转换为OpenCV图像img = cv2.imdecode(nparr, cv2.IMREAD_COLOR)# 检查图像是否正确加载if img is None:print("Error: 图像未正确加载")else:if type == "left":cv2.imwrite('img/left.jpg', img)return "img/left.jpg"elif type == "back":cv2.imwrite('img/back.jpg', img)return "img/back.jpg"else:cv2.imwrite('img/icon.jpg', img)return "img/icon.jpg"def get_click_points(image_path):# 读取图片image = cv2.imread(image_path)# 转换为灰度图gray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)# 二值化处理_, thresh = cv2.threshold(gray, 127, 255, cv2.THRESH_BINARY_INV)# 查找轮廓contours, _ = cv2.findContours(thresh, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE)# 遍历轮廓,寻找点points = []for contour in contours:# 获取轮廓的边界框x, y, w, h = cv2.boundingRect(contour)# 可以根据实际情况过滤小轮廓if w > 5 and h > 5:# 标记轮廓cv2.rectangle(image, (x-10, y), (x + w-10, y + h), (0, 255, 0), 2)# 保存点击位置points.append((x + w // 2, y + h // 2))# 显示图片cv2.imshow('Image with points', image)cv2.waitKey(0)cv2.destroyAllWindows()return points@app.route('/SlidingBlock')
def sliding_block():start_now = datetime.now()start_now_time = start_now.strftime("%Y-%m-%d %H:%M:%S")print("开始时间:", start_now_time)date = request.get_json()left_image_str = date['left_image']left_image = base64_change_image(left_image_str, "left")back_image_str = date['back_image']back_image = base64_change_image(back_image_str, "back")skewing = detect_displacement(left_image, back_image)print(f"偏移:{skewing}")data = {'skewing': skewing}last_now = datetime.now()last_now_time = last_now.strftime("%Y-%m-%d %H:%M:%S")print("结束时间:", last_now_time)return jsonify(data)

http://www.ppmy.cn/news/1431775.html

相关文章

Java 网络编程之TCP(一):基于BIO

环境: jdk 17 IntelliJ IDEA 2023.1.1 (Ultimate Edition) Windows 10 专业版 22H2 TCP:面向连接的,可靠的数据传送协议 Java中的TCP网络编程,其实就是基于常用的BIO和NIO来实现的,本文先讨论BIO; BIO…

uniapp微信小程序分包

一、创建分包文件夹subPack 二、将页面文件放入分包文件夹中 启动页面和导航tabBar页面不要放入分包文件夹中 三、配置pages.json 四、效果

1.微服务介绍

完整的微服务架构图 注册中心 配置中心 服务集群 服务网关 分布式缓存 分布式搜索 数据库集群 消息队列 分布式日志服务 系统监控链路追踪 Jenkins docker k8s 技术栈 微服务治理: 注册发现、远程调用、负载均衡、配置管理、网关路由、系统保护、流量…

python借助elasticsearch实现标签匹配计数

给定一组标签 [{“tag_id”: “1”, “value”: “西瓜”}, {“tag_id”: “1”, “value”: “苹果”}],我想精准匹配到现有的标签库中存在的标签并记录匹配成功的数量。 标签id(tag_id)标签名(tag_name)标签值(tag_name )1水果西瓜1水果苹果1水果橙子2动物老虎 …

Vue 3 + TypeScript + Vite 2024年4月最新管理系统基建

Vue 3 TypeScript Vite 2024年4月最新管理系统基建 相关依赖 vue: ^3.4.21vite: ^5.2.0typescript: ^5.2.2eslint: ^9.0.0 1. 初始化项目 1.1 node版本要求 node: v18.17.1 1.2. 创建项目 使用 PNPM: # 创建项目 pnpm create vite vue3-element-template --template …

【C++风云录】粒子魔法大全:打造惊艳视觉效果的工具和引擎

从闪光到爆炸:深入了解粒子系统和特效工具 前言 本文将介绍多种用于创建粒子系统和特效的软件开发工具和引擎。这些工具涵盖了从基础到高级的应用,有助于开发人员实现各种视觉效果。 欢迎订阅专栏:C风云录 文章目录 从闪光到爆炸&#xff…

Mac和VScode配置fortran

最近更换了mac电脑,其中需要重新配置各类软件平台和运行环境,最近把matlab、gmt、VScode、Endnote等软件全部进行了安装和配置。但是不得不说,mac系统对于经常编程的人来说还是非常友好的! 由于需要对地震位错的程序进行编译运行…

数据结构——栈(C++实现)

数据结构——栈 什么是栈栈的实现顺序栈的实现链栈的实现 今天我们来看一个新的数据结构——栈。 什么是栈 栈是一种基础且重要的数据结构,它在计算机科学和编程中扮演着核心角色。栈的名称源于现实生活中的概念,如一叠书或一摞盘子,新添加…