Nanopc T4 使用OpenCV

devtools/2024/9/25 0:08:49/

识别长方形: 

import cv2
import cv2 as cv
import time
import platform
import os# 获取操作系统类型
os_type = platform.system()
if os_type == "Windows":# Windows系统cap = cv.VideoCapture(0)  # 使用第零个摄像头
elif os_type == "Linux":# Linux系统cap = cv.VideoCapture(10)  # 使用第十个摄像头if not cap.isOpened():print("Cannot capture from camera. Exiting.")os._exit(1)  # 退出程序
last_time = time.time()while (True):ret, frame = cap.read()imgContour = frame.copy()imgCanny = cv2.Canny(frame, 60, 60)  # Canny算子边缘检测contours, hierarchy = cv2.findContours(imgCanny, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_NONE)  # 寻找轮廓点for obj in contours:area = cv2.contourArea(obj)  # 计算轮廓内区域的面积# cv2.drawContours(imgContour, obj, -1, (255, 0, 0), 4)  # 绘制轮廓线perimeter = cv2.arcLength(obj, True)  # 计算轮廓周长approx = cv2.approxPolyDP(obj, 0.02 * perimeter, True)  # 获取轮廓角点坐标CornerNum = len(approx)  # 轮廓角点的数量x, y, w, h = cv2.boundingRect(approx)  # 获取坐标值和宽度、高度if CornerNum == 4:if 90 < w != h > 50:objType = "ChangFangXing"cv2.rectangle(imgContour, (x, y), (x + w, y + h), (0, 0, 255), 2)  # 绘制边界框cv2.putText(imgContour, objType, (x + (w // 2), y + (h // 2)), cv2.FONT_HERSHEY_COMPLEX, 0.6, (0, 0, 0),1)  # 绘制文字cv2.imshow("shape Detection", imgContour)if cv.waitKey(1) & 0xFF == ord('q'):breakcap.release()
cv.destroyAllWindows()

识别人脸1:

import cv2
import cv2 as cv
import time
import platform
import os# 获取操作系统类型
os_type = platform.system()
if os_type == "Windows":# Windows系统cap = cv.VideoCapture(0)  # 使用第零个摄像头
elif os_type == "Linux":# Linux系统cap = cv.VideoCapture(10)  # 使用第十个摄像头if not cap.isOpened():print("Cannot capture from camera. Exiting.")os._exit(1)  # 退出程序
last_time = time.time()img = cv.imread("D:\WorkSpace\Python\qsc.png")def template_matching(img_match, img, arithmetic_model):'''【作用】进行图片模板匹配【参数1】模板图片【参数2】进行匹配的图片【参数3】算法模型【返回】无'''# 进行模板匹配result = cv.matchTemplate(img, img_match, arithmetic_model)# 获取最小最大匹配值,还有对应的坐标min_value, max_value, min_coordinate, max_coordinate = cv.minMaxLoc(result)# 默认最佳最大值,当算法为CV_TM_SQDIFF或CV_TM_SQDIFF_NORMED时改为最小值best_coordinate = max_coordinateif arithmetic_model == cv.TM_SQDIFF or arithmetic_model == cv.TM_SQDIFF_NORMED:best_coordinate = min_coordinate# 获取匹配图片的高和宽m_height, m_width = img_match.shape[:2]# 矩形的起始点和结束点r_start = best_coordinater_end = (best_coordinate[0] + m_width, best_coordinate[1] + m_height);# 矩形的颜色和线的宽度r_color = (0, 100, 40)r_line_width = 2# 绘制矩形并展示cv.rectangle(img, r_start, r_end, r_color, r_line_width)cv.imshow("Qu ShiChao", img)while (True):ret, frame = cap.read()template_matching(img, frame, cv.TM_SQDIFF)if cv.waitKey(1) & 0xFF == ord('q'):breakcap.release()
cv.destroyAllWindows()

通模型识别人脸

import cv2
import cv2 as cv
import time
import platform
import os# 获取操作系统类型
os_type = platform.system()
if os_type == "Windows":# Windows系统cap = cv.VideoCapture(0)  # 使用第零个摄像头
elif os_type == "Linux":# Linux系统cap = cv.VideoCapture(10)  # 使用第十个摄像头if not cap.isOpened():print("Cannot capture from camera. Exiting.")os._exit(1)  # 退出程序
last_time = time.time()while (True):ret, frame = cap.read()# 这里是你的xml存放路径face_cascade = cv2.CascadeClassifier("D:\WorkSpace\Python\lbpcascade_frontalface.xml")# 开始人脸检测faces = face_cascade.detectMultiScale(frame, scaleFactor=1.03, minNeighbors=6)# 先复制一张图片frame1 = frame.copy()# 在检测到的人脸中操作for x, y, w, h in faces:# 画出人脸框frame1 = cv2.rectangle(frame1, (x, y), (x + w, y + h), (0, 255, 0), 2)# 找出人脸区域face_area = frame1[y:y + h, x:x + w]# 在人脸区域检测人眼cv2.imshow('face', frame1)if cv.waitKey(1) & 0xFF == ord('q'):breakcap.release()
cv.destroyAllWindows()


http://www.ppmy.cn/devtools/38973.html

相关文章

数据结构之单链表之环形链表

1.题目 题目&#xff1a;给定一个链表的头节点 head &#xff0c;返回链表开始入环的第一个节点。 如果链表无环&#xff0c;则返回 null。 2.分析 首先&#xff0c;我们应该判断链表是否有环&#xff0c;这个可以根据我的上一篇文章的快慢指针来判断。 bool hasCycle(stru…

现货黄金今日行情分析:昨日高低点法

进行交易之前&#xff0c;投资者要对现货黄金今日行情进行一波分析&#xff0c;我们交易决策应该建立在合理分析的基础之上。那么打开市场交易软件看到现货黄金今日行情之后&#xff0c;该如何着手进行分析呢&#xff1f;下面我们就来讨论一下具体的方法。 要进行现货黄金今日行…

【JavaEE网络】HTTP/HTTPS协议的工作原理与格式详解

目录 HTTP/HTTPSHTTP是什么理解“应用层协议”理解HTTP协议的工作过程HTTP协议格式 HTTP/HTTPS HTTP是什么 应用层&#xff0c;一方面是需要自定义协议&#xff0c;一方面也会用到一些现成的协议 HTTP及HTTPS是应用层重点协议 使用浏览器&#xff0c;打开网站&#xff0c;这…

【StarRocks系列】 Trino 方言支持

我们在之前的文章中&#xff0c;介绍了 Doris 官方提供的两种方言转换工具&#xff0c;分别是 sql convertor 和方言 plugin。StarRocks 目前同样也提供了类似的方言转换功能。本文我们就一起来看一下这个功能的实现与 Doris 相比有何不同。 一、Trino 方言验证 我们可以通过…

Redis-6 三种集群模式:主从模式、哨兵模式、分片集群

主从模式 一.介绍一下redis的主从同步 单节点的redis的并发能力是有上限的&#xff0c;要实现高并发&#xff0c;就要搭建主从集群&#xff0c;实现读写分离。通常是一主多从&#xff0c;主节点负责写数据&#xff0c;从节点负责读数据。 二.介绍一下主从模式同步数据的流程…

3D 打印为压铸行业的带来新动力

近年来&#xff0c;随着多家车企的积极引领&#xff0c;一体化压铸技术已逐渐成为汽车行业的一大趋势。该技术不仅简化了车身的制造流程&#xff0c;而且优化了供应链环节&#xff0c;成为汽车制造业中的一次创新&#xff0c;同时显著提升了经济效益。 压铸技术&#xff0c;简而…

【Android】使用Handler实现一个定时器

需求 实现一个定时任务&#xff0c;每隔一秒执行一次 实现 使用Handler实现 private Handler topUIHandler;private void initTopUiHandler() {topUIHandler new Handler(getMainLooper()) {Overridepublic void handleMessage(Message msg) {//执行这个定时任务updateTop…

Excel Module: Iteration #1 EasyExcel生成下拉列表模版时传入动态参数查询下拉数据

系列文章 EasyExcel生成带下拉列表或多级级联列表的Excel模版自定义校验导入数据(修订) 目录 系列文章前言仓库一、实现1.1 下拉元数据对象1.2 构建下拉元数据的映射关系1.3 框架方式1.3.1 框架实现1.3.2 框架用例模版类加载下拉业务导出接口 1.4 EasyExcel方式1.4.1 EasyExce…