Python+OpenCV:截取两张图片黄色圈并精准计算图片一相对图片二总偏移百分比
以下是一个使用 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 范围以及处理可能出现的异常情况。 ######[AI写代码神器 | 786点数解答 | 2024-08-10 10:56:07]
- Python程序模拟公安车牌识别预警:精准锁定嫌疑人车辆( | 458点数解答 | 2024-05-05 18:31:11)330
- Python 运行报错:urllib3 网络连接创建失败,原因及排查建议(字节豆包 | 161点数解答 | 2024-10-31 00:39:36)489
- Python 实战:学生信息列表转字典、遍历、深拷贝及数据修改全流程(GPT | 422点数解答 | 2024-10-29 15:43:54)442
- Python实战:学生成绩列表转字典,深拷贝与数据修改操作全解析(字节豆包 | 254点数解答 | 2024-10-29 16:01:39)435
- 数字化制图综合平台:助力企业转型,推动烟草物流图纸智能化设计 (字节豆包 | 490点数解答 | 2024-10-30 20:30:29)158
- 数字化制图综合平台:引领烟草物流及多领域设计革新 在企业数字化转型的时代浪潮中,数字化制图技术创新应用成为产业升级与提升竞争力的关键。企业对高效、精准、智能化设计解决方案需求迫切,构建集二维到三维正逆向工程快捷化、干涉检测可视化、设备明细数据提取自动化以及设备模块模型库于一体的综合平台意义重大。 此平台集成先进数字化制图工具与智能算法,可实现二维设计到三维建模的无缝转换,大大缩短设计周期。正逆向工程能快速切换,满足不同场景设计需求。内置干涉检测功能可实时监测设计潜在冲突,保障设计方案可行与安全。设备明细数据自动提取提高设计准确性与效率。设备模块模型库为设计师提供丰富资源,支持设计标准化与模块化,加速项目推进。 整体来看,该综合平台的应用极大促进了烟草物流行业及更广泛领域的技术创新与效率提升。在烟草物流方案图纸智能化设计中,它提升了图纸设计效率与质量,使设计工作更加高效、精准。对于企业而言,这一平台带来显著竞争优势,能帮助企业在数字化转型中脱颖而出,在激烈的市场竞争中占据有利地位,推动整个行业向更高效、更智能的方向发展。 (阿里通义 | 216点数解答 | 2024-10-30 20:30:51)188
- VBA 代码:双击特定单元格为数据区内容按条件标色及注意事项(字节豆包 | 942点数解答 | 2024-12-07 18:07:56)333
- 揭秘百分比常见缩写:“%”成各领域宠儿!(字节豆包 | 66点数解答 | 2025-07-30 13:26:19)93
- ECharts 饼图显示数字+百分比:代码示例与开发注意事项(字节豆包 | 533点数解答 | 2026-01-08 20:49:36)31
- OpenCV.js 轻松实现图片识别:详细步骤全解析 ( | 824点数解答 | 2024-03-22 16:22:16)204
- OpenCV.js 实战:轻松识别图片中电梯轮廓( | 1193点数解答 | 2024-03-22 16:23:32)219
- 用 C++ 和 OpenCV 生成带随机偏移的圆周上的点:代码剖析(字节豆包 | 29点数解答 | 2024-11-06 23:40:42)271