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

k230 Pyhton三角形识别

本文介绍了一个基于K230 CanMV开发板的多颜色三角形识别程序,能够检测红、绿、蓝三种颜色的三角形。程序使用摄像头获取实时图像,通过LAB颜色阈值过滤识别特定颜色的色块,并判断是否为三角形(通过检测4个角点)。识别到的三角形会标注外接矩形、轮廓线、中心十字和颜色文字。程序支持LCD/HDMI/VIRT三种显示模式,具有完善的资源释放机制。该方案适用于K230 CanMV v1.2.2版本,可作为计算机视觉应用的开发参考。

# 立创·庐山派-K230-CanMV开发板 多颜色三角形识别(红/绿/蓝) # 适配K230 CanMV v1.2.2 import time, os, sys from media.sensor import * from media.display import * from media.media import * sensor_id = 2 sensor = None # 显示模式:LCD(开发板屏幕)/HDMI/VIRT(虚拟屏) DISPLAY_MODE = "LCD" # 显示分辨率配置 if DISPLAY_MODE == "VIRT": DISPLAY_WIDTH = ALIGN_UP(1920, 16) DISPLAY_HEIGHT = 1080 elif DISPLAY_MODE == "LCD": DISPLAY_WIDTH = 800 DISPLAY_HEIGHT = 480 elif DISPLAY_MODE == "HDMI": DISPLAY_WIDTH = 1920 DISPLAY_HEIGHT = 1080 else: raise ValueError("DISPLAY_MODE仅支持 'VIRT', 'LCD', 'HDMI'") # 红/绿/蓝 三色LAB阈值(全部启用,适配K230摄像头) # 格式:(L Min, L Max, A Min, A Max, B Min, B Max) color_thresholds = [ (46, 66, 14, 92, -29, 106), # 红色阈值(启用) (52, 88, -85, -6, -11, 91), # 绿色阈值 (47, 76, -35, 51, -83, -32) # 蓝色阈值 ] try: # 初始化摄像头(沿用稳定的初始化逻辑) sensor = Sensor(id=sensor_id) sensor.reset() sensor.set_framesize(width=DISPLAY_WIDTH, height=DISPLAY_HEIGHT, chn=CAM_CHN_ID_0) sensor.set_pixformat(Sensor.RGB565, chn=CAM_CHN_ID_0) # 初始化显示器 if DISPLAY_MODE == "VIRT": Display.init(Display.VIRT, width=DISPLAY_WIDTH, height=DISPLAY_HEIGHT, fps=60) elif DISPLAY_MODE == "LCD": Display.init(Display.ST7701, width=DISPLAY_WIDTH, height=DISPLAY_HEIGHT, to_ide=True) elif DISPLAY_MODE == "HDMI": Display.init(Display.LT9611, width=DISPLAY_WIDTH, height=DISPLAY_HEIGHT, to_ide=True) MediaManager.init() sensor.run() print("K230多颜色三角形识别程序启动(红/绿/蓝),按Ctrl+C退出") while True: os.exitpoint() # 获取摄像头实时帧 img = sensor.snapshot(chn=CAM_CHN_ID_0) # 查找色块(过滤小噪声,面积>2000像素) blobs = img.find_blobs(color_thresholds, area_threshold=2000) if blobs: for blob in blobs: # 获取色块角点,判断是否为三角形(角点数量=3) corners = blob.corners() if len(corners) == 4: # 根据颜色索引确定识别到的颜色 color_flag = blob[8] if color_flag & 0x01: color_name = "red" draw_color = (255, 0, 0) # 红色RGB elif color_flag & 0x02: color_name = "green" draw_color = (0, 255, 0) # 绿色RGB elif color_flag & 0x04: color_name = "blue" draw_color = (0, 0, 255) # 蓝色RGB else: color_name = "unknown" draw_color = (128, 128, 128) # 灰色 # 1. 绘制三角形外接矩形(白色框) img.draw_rectangle(blob[0:4], color=(255, 255, 255), thickness=3) # 2. 绘制三角形轮廓(对应颜色线条,循环3次) for i in range(3): x1, y1 = corners[i] x2, y2 = corners[(i + 1) % 3] img.draw_line(x1, y1, x2, y2, color=draw_color, thickness=3) # 3. 绘制中心十字(黄色) img.draw_cross(blob[5], blob[6], color=(255, 255, 0), size=10) # 4. 标注三角形+颜色文字 img.draw_string(blob[0], blob[1]-20, f"Triangle: {color_name}", color=draw_color, scale=2, mono_space=False) # 5. 串口打印识别结果 print(f"识别到【{color_name}】三角形 - 中心坐标:X={blob[5]}, Y={blob[6]}") # 显示处理后的图像到屏幕 Display.show_image(img) except KeyboardInterrupt: print("\n用户手动终止程序") except BaseException as e: print(f"程序异常:{str(e)}") finally: # 释放硬件资源 if sensor: sensor.stop() Display.deinit() os.exitpoint(os.EXITPOINT_ENABLE_SLEEP) time.sleep_ms(100) MediaManager.deinit() print("程序退出,资源已释放")
http://www.jsqmd.com/news/95761/

相关文章:

  • 终极右键菜单优化利器:ContextMenuManager完全使用手册
  • 年营收2000亿电商,3370万用户信息泄露,CEO引咎辞职
  • 终极网站下载工具:5分钟学会整站备份与离线浏览
  • 如何快速释放Windows磁盘空间:终极存储分析工具完整指南
  • 基于OpenSpec标准构建:HunyuanVideo-Foley API设计规范公开
  • 20、数字 FIR 滤波器的逐步设计
  • 3分钟学会原神帧率解锁:告别卡顿的终极优化指南
  • Driver Store Explorer终极指南:轻松管理Windows驱动存储库
  • 一键升级 OpenSSH 10到最新版:告别手工编译、兼容国产系统、批量部署无忧!
  • 22、IIR滤波器的逐步设计
  • 23、IIR滤波器的逐步设计与不同类型滤波器的特性分析
  • 9、卷积与相关性:原理、计算与应用
  • 10、Z变换:原理、计算与应用详解
  • 11、Z变换与差分方程求解全解析
  • 12、离散系统差分方程求解与信号处理相关问题解析
  • 13、离散时间傅里叶变换与离散傅里叶变换详解
  • 14、离散时间傅里叶变换与离散傅里叶变换详解
  • 4、深入理解BPF Maps:创建、操作与应用
  • 5、BPF 映射操作与类型详解
  • 6、BPF 映射类型与虚拟文件系统使用指南
  • 终极广告拦截方案:AdGuardHomeRules 完整使用指南
  • 智能自动化工具:重新定义百度网盘提取码获取体验
  • 近红外光谱开源数据集:快速上手与实战应用完整指南
  • 5分钟精通!ColorUI导航组件让界面切换效率提升300%
  • Midieditor实战突破:解锁专业级MIDI编辑新境界
  • ZonyLrcToolsX 歌词下载工具终极配置指南
  • 如何在IDEA中完美实现工作阅读两不误:Thief-Book插件终极指南
  • ImageToSTL:零基础图片转3D模型完整教程
  • Wan2.2-T2V-5B本地化部署与HuggingFace镜像网站加速下载技巧
  • ComfyUI-Manager终极指南:三步打造高效AI绘画工作流