PYTHON三种读取存入图像方法 VideoCapture读取视频两种方法 C++与PYTHON截图和缩放方法 waitKey Sleep sleep 图片文字putText

本文主要是介绍PYTHON三种读取存入图像方法 VideoCapture读取视频两种方法 C++与PYTHON截图和缩放方法 waitKey Sleep sleep 图片文字putText,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

PYTHON三种方法

方法一、cv2

import cv2
filename=r’D:\Work\ILSVRC\val_3.jpeg’
im1=cv2.imread(filename) #读文件BGR格式
im1 = cv2.resize(im1,(400,400)) #默认双线性插值
#cv2.imshow(‘cv2’,im1) #显示图像, 在现在的petalinux生成的系统中和vitis ai的镜像中均不能使用cv2.imshow
#cv2.waitKey(0)

Syntax: cv2.imread(path, flag)
Parameters:
path: A string representing the path of the image to be read.
flag: It specifies the way in which image should be read. It’s default value is cv2.IMREAD_COLOR
Return Value: This method returns an image that is loaded from the specified file.

cv2.IMREAD_COLOR: It specifies to load a color image. Any transparency of image will be neglected. It is the default flag. Alternatively, we can pass integer value 1 for this flag.
cv2.IMREAD_GRAYSCALE: It specifies to load an image in grayscale mode. Alternatively, we can pass integer value 0 for this flag.
cv2.IMREAD_UNCHANGED: It specifies to load an image as such including alpha channel. Alternatively, we can pass integer value -1 for this flag.

cv::rectangle
C++
void cv::rectangle (InputOutputArray img, Point pt1, Point pt2, const Scalar &color, int thickness=1, int lineType=LINE_8, int shift=0)
void cv::rectangle (InputOutputArray img, Rect rec, const Scalar &color, int thickness=1, int lineType=LINE_8, int shift=0)

Python
img = cv.rectangle(img, pt1, pt2, color[, thickness[, lineType[, shift]]])
img = cv.rectangle(img, rec, color[, thickness[, lineType[, shift]]])

方法二、matplotlib plt

import matplotlib
import matplotlib.pyplot as plt
import matplotlib.pyplot as plt
img2 = matplotlib.image.imread(pr)  #RGB格式
#cv2的BGR格式
plt.subplot(121)
plt.imshow(im2)
plt.show() #此命令才能显示

若是cv2.imread读取文件,plt显示需要转换
im1 = im1[:,:,::-1]  #BGR -> RGB

方法三、PIL

from PIL import Image
#import numpy as np
im2 = Image.open(filename) #不是矩阵形式
im2.show()
#arr = np.array(im2)
#print(arr.shape)
#print(arr.dtype)
#矩阵再转为图像
im3 = Image.fromarray(arr)
im3.save(‘01.png’)

OpenCV Show Image cvShowImage() 使用方法

新版的OpenCV在所有的函数和类前都加上了cv或Cv,这样很好的避免了区域污染(namespace pollution),而且不用在前面加‘cv::’,非常的使用。像之前的imshow()函数被现在的cvShowImage()所替代,现如今在OpenCV中显示一张图片可用如下代码:

C API:

IplImage *img = cvLoadImage(“Input.jpg”);
cvNamedWindow(“Image:”,1);
cvShowImage(“Image:”,img);
cvWaitKey();
cvDestroyWindow(“Image:”);
cvReleaseImage(&img);

C++:

cv::Mat image = cv::imread(“img.jpg”);
cv::namedWindow( “Display window”, cv::WINDOW_AUTOSIZE );
cv::imshow( “Display window”, image );
cv::waitKey(0);
cv::destroyWindow(“Display window”);
image.release();

C++版本截图实现

#include <opencv2/opencv.hpp>
#include <opencv2/highgui/highgui.hpp>
#include <opencv2/core/core.hpp>
#include
using namespace std;
using namespace cv;
cv::Mat img;
cv::Rect m_select;
int main()
{
img = cv::imread(“F://Visual Studio 2015//ROItest01//ROItest01//01.jpg”);
cv::imshow(“原图”, img);
m_select = Rect(174,230,111,217);
Mat ROI = img(m_select);
cv::imshow(“剪裁图”, ROI);
waitKey(0);
return 0;
}

PYTHON版本截图实现

def central_crop(image, crop_height, crop_width):
image_height = image.shape[0]
image_width = image.shape[1]
offset_height = (image_height - crop_height) // 2
offset_width = (image_width - crop_width) // 2
return image[offset_height:offset_height + crop_height, offset_width:
offset_width + crop_width, :]

Python缩放图像

    cv2.namedWindow("Display", cv2.WINDOW_AUTOSIZE)cv2.moveWindow("Display",50,50)height, width = img.shape[:2]  size = (int(width*2), int(height*2))  image_result = cv2.resize(image_result, size, interpolation=cv2.INTER_LINEAR)  cv2.imshow("Display", image_result)if cv2.waitKey(2000)==27: break       

waitKey()函数

1.1 waitKey()–这个函数是在一个给定的时间内(单位ms)等待用户按键触发;如果用户没有按下 键,则接续等待(循环)
1.2 如下所示: while(1){ if(waitKey(100)==27)break; } 在这个程序中,我们告诉OpenCv等待用户触发事件,等待时间为100ms,如果在这个时间段内, 用户按下ESC(ASCII码为27),则跳出循环,否则,则继续循环

Sleep sleep

#include <syswait.h>
usleep(n) //n微秒
Sleep(n)//n毫秒
sleep(n)//n秒

VideoCapture

1、cap = cv2.VideoCapture(0)
VideoCapture()中参数是0,表示打开笔记本的内置摄像头,参数是视频文件路径则打开视频,如cap = cv2.VideoCapture(“…/test.avi”)
2、ret,frame = cap.read()
cap.read()按帧读取视频,ret,frame是获cap.read()方法的两个返回值。其中ret是布尔值,如果读取帧是正确的则返回True,如果文件读取到结尾,它的返回值就为False。

C++

#include<opencv.hpp>
using namespace cv;
int main() {VideoCapture capture(0);while (1) {Mat frame;capture >> frame;imshow("摄像头捕捉", frame);waitKey(1);}
}
    Python有两种编程方式从摄像头提取视频流, video.capture(gstreamer pipeline), video.capture(index), 前者更灵活、更快、较复杂的调用方式,后者更简单、更容易实现的调用方式。video.capture(gstreamer pipeline),

video.capture(gstreamer pipeline)

# define the image
inputId = 'mediasrcbin media-device=/dev/media0 v4l2src0::io-mode=dmabuf v4l2src0::stride-align=256  ! video/x-raw, width=256, height=256, format=NV12, framerate=30/1 ! 
videoconvert! appsink’
# capture a video from camera
cam = cv2.VideoCapture(inputId, cv2.CAP_GSTREAMER)
# capture image from camera 
ret,frame = cam.read()

video.capture(gstreamer pipeline)

# capture a video from camera
cam = cv2.VideoCapture(1)    
# cam.set(3, width)
# cam.set(4, height)    cam.set(cv2.CAP_PROP_FRAME_WIDTH, 640)    cam.set(cv2.CAP_PROP_FRAME_HEIGHT, 480)
# capture image from camera 
ret,frame = cam.read() 
# resize the image
frame = cv2.resize(frame, (256, 256), interpolation=cv2.INTER_LINEAR)

图片文字

texts = [“wear mask”, “wear incorrectly”, “no mask”]
for i, bbox in enumerate(bboxes):
coor = np.array(bbox[:4], dtype=np.int32)
fontScale = 0.5
score = bbox[4]
class_ind = int(bbox[5])
#print(f"class_ind = {class_ind}")
bbox_color = colors[class_ind]
bbox_text = texts[class_ind]
#bbox_thick = int(0.6 * (image_h + image_w) / 600)
bbox_thick = 2
c1, c2 = (coor[0], coor[1]), (coor[2], coor[3])
cv2.rectangle(image, c1, c2, bbox_color, bbox_thick)
# 图片 添加的文字 位置 字体 字体大小 字体颜色 字体粗细
cv2.putText(image, bbox_text, (coor[0], coor[1]-10), cv2.FONT_HERSHEY_SIMPLEX, 0.75, bbox_color, 2)

这篇关于PYTHON三种读取存入图像方法 VideoCapture读取视频两种方法 C++与PYTHON截图和缩放方法 waitKey Sleep sleep 图片文字putText的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/997783

相关文章

流媒体平台/视频监控/安防视频汇聚EasyCVR播放暂停后视频画面黑屏是什么原因?

视频智能分析/视频监控/安防监控综合管理系统EasyCVR视频汇聚融合平台,是TSINGSEE青犀视频垂直深耕音视频流媒体技术、AI智能技术领域的杰出成果。该平台以其强大的视频处理、汇聚与融合能力,在构建全栈视频监控系统中展现出了独特的优势。视频监控管理系统EasyCVR平台内置了强大的视频解码、转码、压缩等技术,能够处理多种视频流格式,并以多种格式(RTMP、RTSP、HTTP-FLV、WebS

基于人工智能的图像分类系统

目录 引言项目背景环境准备 硬件要求软件安装与配置系统设计 系统架构关键技术代码示例 数据预处理模型训练模型预测应用场景结论 1. 引言 图像分类是计算机视觉中的一个重要任务,目标是自动识别图像中的对象类别。通过卷积神经网络(CNN)等深度学习技术,我们可以构建高效的图像分类系统,广泛应用于自动驾驶、医疗影像诊断、监控分析等领域。本文将介绍如何构建一个基于人工智能的图像分类系统,包括环境

python: 多模块(.py)中全局变量的导入

文章目录 global关键字可变类型和不可变类型数据的内存地址单模块(单个py文件)的全局变量示例总结 多模块(多个py文件)的全局变量from x import x导入全局变量示例 import x导入全局变量示例 总结 global关键字 global 的作用范围是模块(.py)级别: 当你在一个模块(文件)中使用 global 声明变量时,这个变量只在该模块的全局命名空

【C++ Primer Plus习题】13.4

大家好,这里是国中之林! ❥前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站。有兴趣的可以点点进去看看← 问题: 解答: main.cpp #include <iostream>#include "port.h"int main() {Port p1;Port p2("Abc", "Bcc", 30);std::cout <<

使用opencv优化图片(画面变清晰)

文章目录 需求影响照片清晰度的因素 实现降噪测试代码 锐化空间锐化Unsharp Masking频率域锐化对比测试 对比度增强常用算法对比测试 需求 对图像进行优化,使其看起来更清晰,同时保持尺寸不变,通常涉及到图像处理技术如锐化、降噪、对比度增强等 影响照片清晰度的因素 影响照片清晰度的因素有很多,主要可以从以下几个方面来分析 1. 拍摄设备 相机传感器:相机传

C++包装器

包装器 在 C++ 中,“包装器”通常指的是一种设计模式或编程技巧,用于封装其他代码或对象,使其更易于使用、管理或扩展。包装器的概念在编程中非常普遍,可以用于函数、类、库等多个方面。下面是几个常见的 “包装器” 类型: 1. 函数包装器 函数包装器用于封装一个或多个函数,使其接口更统一或更便于调用。例如,std::function 是一个通用的函数包装器,它可以存储任意可调用对象(函数、函数

综合安防管理平台LntonAIServer视频监控汇聚抖动检测算法优势

LntonAIServer视频质量诊断功能中的抖动检测是一个专门针对视频稳定性进行分析的功能。抖动通常是指视频帧之间的不必要运动,这种运动可能是由于摄像机的移动、传输中的错误或编解码问题导致的。抖动检测对于确保视频内容的平滑性和观看体验至关重要。 优势 1. 提高图像质量 - 清晰度提升:减少抖动,提高图像的清晰度和细节表现力,使得监控画面更加真实可信。 - 细节增强:在低光条件下,抖

C++11第三弹:lambda表达式 | 新的类功能 | 模板的可变参数

🌈个人主页: 南桥几晴秋 🌈C++专栏: 南桥谈C++ 🌈C语言专栏: C语言学习系列 🌈Linux学习专栏: 南桥谈Linux 🌈数据结构学习专栏: 数据结构杂谈 🌈数据库学习专栏: 南桥谈MySQL 🌈Qt学习专栏: 南桥谈Qt 🌈菜鸡代码练习: 练习随想记录 🌈git学习: 南桥谈Git 🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈�

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

高效录音转文字:2024年四大工具精选!

在快节奏的工作生活中,能够快速将录音转换成文字是一项非常实用的能力。特别是在需要记录会议纪要、讲座内容或者是采访素材的时候,一款优秀的在线录音转文字工具能派上大用场。以下推荐几个好用的录音转文字工具! 365在线转文字 直达链接:https://www.pdf365.cn/ 365在线转文字是一款提供在线录音转文字服务的工具,它以其高效、便捷的特点受到用户的青睐。用户无需下载安装任何软件,只