python使用opcv截取两张图片中间黄色圈然后对比计算出图片一比图片二总偏移百分比


以下是一个使用 OpenCV 库来解决此问题的示例代码框架,不过这个示例只是一个基本的指导,实际应用中可能需要根据图片的具体情况进行更多的调整和优化: ```python import cv2 def calculate_offset_percentage(image1, image2): # 将图像转换为 HSV 颜色空间 hsv_image1 = cv2.cvtColor(image1, cv2.COLOR_BGR2HSV) hsv_image2 = cv2.cvtColor(image2, cv2.COLOR_BGR2HSV) # 定义黄色的 HSV 范围 lower_yellow = np.array([20, 100, 100]) upper_yellow = np.array([40, 255, 255]) # 提取黄色区域的掩码 mask1 = cv2.inRange(hsv_image1, lower_yellow, upper_yellow) mask2 = cv2.inRange(hsv_image2, lower_yellow, upper_yellow) # 找到黄色区域的轮廓 contours1, _ = cv2.findContours(mask1, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE) contours2, _ = cv2.findContours(mask2, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE) if len(contours1) > 0 and len(contours2) > 0: # 假设只处理最大的轮廓 contour1 = max(contours1, key=cv2.contourArea) contour2 = max(contours2, key=cv2.contourArea) # 计算轮廓的质心 M1 = cv2.moments(contour1) cx1, cy1 = int(M1['m10'] / M1['m00']), int(M1['m01'] / M1['m00']) M2 = cv2.moments(contour2) cx2, cy2 = int(M2['m10'] / M2['m00']), int(M2['m01'] / M2['m00']) # 计算偏移量 offset_x = cx2 - cx1 offset_y = cy2 - cy1 # 计算图像的宽度和高度 height, width = image1.shape[:2] # 计算总偏移百分比 total_offset = np.sqrt(offset_x 2 + offset_y 2) total_pixels = width * height offset_percentage = (total_offset / total_pixels) * 100 return offset_percentage else: return None # 读取两张图片 image1 = cv2.imread('image1.jpg') image2 = cv2.imread('image2.jpg') offset_percentage = calculate_offset_percentage(image1, image2) if offset_percentage is not None: print(f"总偏移百分比: {offset_percentage}%") else: print("未检测到黄色区域") ``` 在上述代码中,我们首先将图像转换为 HSV 颜色空间以更好地检测黄色区域。然后,通过掩码提取黄色区域,找到其轮廓,并计算轮廓的质心。根据质心的偏移量计算总偏移百分比。 您需要根据实际情况调整黄色的 HSV 范围以及处理可能出现的异常情况。 [2024-08-10 10:56:07 | AI写代码神器 | 786点数解答]
- 编写一个嫌疑人车辆预警的程序。 公安系统在追捕嫌疑人时,嫌疑人驾车逃跑,据目击群众描述,由于天色较暗,只能确定部分信息: ● 嫌疑人a车辆牌照信息:绿色,鲁,车牌最后三位是111 ● 嫌疑人b车辆牌照信息:黄色,苏,车牌前三是苏fc 公安系统中有一个车牌识别预警系统,可以根据车牌信息进行识别预警。我们要设计一个程序模拟这个车牌识别预警系统,为了模拟程序需要输入车牌颜色和车牌号,输出预警提示信息: ● 疑似嫌疑人a车辆 ● 疑似嫌疑人b车辆 ● 无嫌疑车辆 【相关信息】 车牌颜色只有三种,用三个单词代表: ● 绿色:green ● 蓝色:blue ● 黄色:yellow(458点数解答 | 2024-05-05 18:31:11)223
- c:\python\venv\zzz\scripts\python.exe c:\python\main.py traceback (most recent call last): file "c:\users\意\appdata\local\programs\python\python311\lib\site-packages\urllib3\connection.py", line 199, in _new_conn sock = connection.create_connection( ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ file "c:\users\意\appdata\local\programs\python\python311\lib\site-packages\urllib3\util\connection.py", line 85, in create_connection raise err file "c:\users\意\appdata\local\programs\python\pyt(161点数解答 | 2024-10-31 00:39:36)244
- 商品展示模块 前端页面:productlist.jsp、productdetail.jsp 后端逻辑:productservlet 处理获取商品列表与详情请求 实现商品分页显示、按类别或关键词搜索功能 前端页面渲染与交互 使用 jsp、el、jstl 渲染商品数据 使用 css 优化页面样式,确保用户界面美观统一 使用 javascript 实现简单的前端交互,如商品图片切换、下拉菜单 搜索与过滤功能 在 productlist.jsp 实现搜索栏,允许用户输入关键词进行搜索 后端根据搜索条件查询数据库,返回符合条件的商品列表 使用 jstl 循环输出商品数据,并实现价格或类别过滤选项(19点数解答 | 2024-12-13 15:00:43)194
- 百分比 缩写(66点数解答 | 2025-07-30 13:26:19)35
- student = [张三,李四,王五,周六,赵七] score =[ ["会计学", "c语言", "java"], ["python", "程序设计", "java"], ["数据结构", "c语言", "java"], ["python", "c语言", "大学计算机基础"], ["python", "会计学", "信息管理"] ] 1.将两个列表转换为一个字典,名为dict2 2.遍历字典dict2 3.将dict2深拷贝 4.在拷贝后的文件上做如下操作: 1)删除周六的信息 2)添加键值对:“钱一”:["管理科学与工程", "大学计算机基础", "大学数学"] 3)修改“张三”的三个课程为"大学数学", "c语言", "python"(422点数解答 | 2024-10-29 15:43:54)223
- student = [张三,李四,王五,周六,赵七] score =[ ["会计学", "c语言", "java"], ["python", "程序设计", "java"], ["数据结构", "c语言", "java"], ["python", "c语言", "大学计算机基础"], ["python", "会计学", "信息管理"] ] 1.将两个列表转换为一个字典,名为dict2 2.遍历字典dict2 3.将dict2深拷贝 4.在拷贝后的文件上做如下操作: 1)删除周六的信息 2)添加键值对:“钱一”:["管理科学与工程", "大学计算机基础", "大学数学"] 3)修改“张三”的三个课程为"大学数学", "c语言", "python"(254点数解答 | 2024-10-29 16:01:39)222
- 1至10,10个号码每个号码对应单元格颜色为 1= rgb(255, 255, 0) ' 黄色 2= rgb(0, 102, 204) ' 海蓝色 3= rgb(0, 0, 0) ' 黑色 4= rgb(255, 128, 0) ' 橘红色 5= rgb(0, 255, 255) ' 青绿色 6= rgb(0, 0, 255) ' 蓝色 7= rgb(128, 128, 128) ' 灰色 8= rgb(255, 0, 0) ' 红色 9= rgb(128, 0, 0) ' 深红色 10= rgb(128, 128, 0) ' 橄榄色。 双击c3单元格,则数据区c5至l30000内的内容,大于等于6的为大,且按照每个号码的颜色进行标色。 双击d3单元格,则数据区c5至l30000内的内容,小于等于5的为小,且按照每个号码的颜色进行标色。 双击e3单元格,则数据区c5至l30000内的内容,等于单数的为单,且按照每个号码的颜色进行标色。 双击f3单元格,则数据区c5至l30000内的内容,等于偶数的为双,且按照每个号码的颜色进行标色。 双击g3单元格,则数据区c5至l30000内的内容,(942点数解答 | 2024-12-07 18:07:56)211
- 题目:按照以下步骤在 pycharm 中进行自动化测试脚本编写,并执行脚本。 步骤: (1)从 selenium 中引入 webdriver; (2)使用 selenium 模块的 webdriver 打开谷歌浏览器; (3)在谷歌浏览器中通过 get 方法发送网址eshop测试平台登录页面; (4)增加智能时间等待 5 秒; (5)查看登录页面中的用户名输入框元素,通过 css_selector 属性定位用户名输入框,并输入用户名(用自己注册的用户); (6)查看登录页面中的密码输入框元素,通过 xpath 属性定位密码输入框,并输入密码(用自己注册的用户对应密码) ; (7)查看登录页面中的登录按钮元素,通过 class_name 方法定位登录按钮,使用 click()方法点击登录按钮进入eshop测试平台首页; (8)在eshop测试平台首页通过 link_text 方法对“我的订单”按钮进行定位,使用 click()方法点击“我的订单”(304点数解答 | 2024-11-06 15:38:30)269
- 题目描述 给出一颗二叉树,请把它左右翻转。超级简单吧,max howell竟然不会写,然后被google直接拒掉。(然后,然后...自己上网查吧) 比如下面的树这样翻转,然后输出翻转后先序遍历顺序。 4 / \ 2 6 / \ / \ 1 3 5 7 (转换前先序遍历顺序为 4 2 1 3 6 5 7) 4 / \ 6 2 / \ / \ 7 5 3 1 (转换后先序遍历顺序为 4 6 7 5 2 3 1) 输入 第一行一个整数t(<=10),表示有t组测试数据。 对于每组测试数据: 第一行两个整数n(<=8191)和d(1<=d<=13),表示这棵树有n个结点(结点标号为1~n),树有d层。 接下来d行: 第i行有2^(i-1)个整数,其中i行第j个a[i][j]的左儿子结点为a[i+1][j*2-1]右儿子为a[i+1][j*2](-1表示不存在该结点) 输出 对于每组数据输出一行为这颗树翻转后的先序遍历顺序。整数之间用空格隔开,最后一个整数后面没有空格。 样例输入 2 4 3 1(452点数解答 | 2024-12-02 09:49:52)153
- 题目描述 给出一颗二叉树,请把它左右翻转。超级简单吧,max howell竟然不会写,然后被google直接拒掉。(然后,然后...自己上网查吧) 比如下面的树这样翻转,然后输出翻转后先序遍历顺序。 4 / \ 2 6 / \ / \ 1 3 5 7 (转换前先序遍历顺序为 4 2 1 3 6 5 7) 4 / \ 6 2 / \ / \ 7 5 3 1 (转换后先序遍历顺序为 4 6 7 5 2 3 1) 输入 第一行一个整数t(<=10),表示有t组测试数据。 对于每组测试数据: 第一行两个整数n(<=8191)和d(1<=d<=13),表示这棵树有n个结点(结点标号为1~n),树有d层。 接下来d行: 第i行有2^(i-1)个整数,其中i行第j个a[i][j]的左儿子结点为a[i+1][j*2-1]右儿子为a[i+1][j*2](-1表示不存在该结点) 输出 对于每组数据输出一行为这颗树翻转后的先序遍历顺序。整数之间用空格隔开,最后一个整数后面没有空格。 样例输入 2 4 3 1(613点数解答 | 2024-12-02 09:50:35)191
- 使用c语言代码 题目描述 给出一颗二叉树,请把它左右翻转。超级简单吧,max howell竟然不会写,然后被google直接拒掉。(然后,然后...自己上网查吧) 比如下面的树这样翻转,然后输出翻转后先序遍历顺序。 4 / \ 2 6 / \ / \ 1 3 5 7 (转换前先序遍历顺序为 4 2 1 3 6 5 7) 4 / \ 6 2 / \ / \ 7 5 3 1 (转换后先序遍历顺序为 4 6 7 5 2 3 1) 输入 第一行一个整数t(<=10),表示有t组测试数据。 对于每组测试数据: 第一行两个整数n(<=8191)和d(1<=d<=13),表示这棵树有n个结点(结点标号为1~n),树有d层。 接下来d行: 第i行有2^(i-1)个整数,其中i行第j个a[i][j]的左儿子结点为a[i+1][j*2-1]右儿子为a[i+1][j*2](-1表示不存在该结点) 输出 对于每组数据输出一行为这颗树翻转后的先序遍历顺序。整数之间用空格隔开,最后一个整数后面没有空格。 样例输入(1053点数解答 | 2024-12-02 09:51:45)139
- 使用 python 实现将当前目录中的文件名字输入到"url.txt"文件(每行一个文件名),语言方向:Python(127点数解答 | 2024-12-25 11:19:25)131