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

相关文章

python版本切换工具pyenv的安装及用法

《python版本切换工具pyenv的安装及用法》Pyenv是管理Python版本的最佳工具之一,特别适合开发者和需要切换多个Python版本的用户,:本文主要介绍python版本切换工具pyen... 目录Pyenv 是什么?安装 Pyenv(MACOS)使用 Homebrew:配置 shell(zsh

Python自动化提取多个Word文档的文本

《Python自动化提取多个Word文档的文本》在日常工作和学习中,我们经常需要处理大量的Word文档,本文将深入探讨如何利用Python批量提取Word文档中的文本内容,帮助你解放生产力,感兴趣的小... 目录为什么需要批量提取Word文档文本批量提取Word文本的核心技术与工具安装 Spire.Doc

Java调用DeepSeek API的8个高频坑与解决方法

《Java调用DeepSeekAPI的8个高频坑与解决方法》现在大模型开发特别火,DeepSeek因为中文理解好、反应快、还便宜,不少Java开发者都用它,本文整理了最常踩的8个坑,希望对... 目录引言一、坑 1:Token 过期未处理,鉴权异常引发服务中断问题本质典型错误代码解决方案:实现 Token

Nginx 访问控制的多种方法

《Nginx访问控制的多种方法》本文系统介绍了Nginx实现Web访问控制的多种方法,包括IP黑白名单、路径/方法/参数控制、HTTP基本认证、防盗链机制、客户端证书校验、限速限流、地理位置控制等基... 目录一、IP 白名单与黑名单1. 允许/拒绝指定IP2. 全局黑名单二、基于路径、方法、参数的访问控制

Python中Request的安装以及简单的使用方法图文教程

《Python中Request的安装以及简单的使用方法图文教程》python里的request库经常被用于进行网络爬虫,想要学习网络爬虫的同学必须得安装request这个第三方库,:本文主要介绍P... 目录1.Requests 安装cmd 窗口安装为pycharm安装在pycharm设置中为项目安装req

Python容器转换与共有函数举例详解

《Python容器转换与共有函数举例详解》Python容器是Python编程语言中非常基础且重要的概念,它们提供了数据的存储和组织方式,下面:本文主要介绍Python容器转换与共有函数的相关资料,... 目录python容器转换与共有函数详解一、容器类型概览二、容器类型转换1. 基本容器转换2. 高级转换示

nginx跨域访问配置的几种方法实现

《nginx跨域访问配置的几种方法实现》本文详细介绍了Nginx跨域配置方法,包括基本配置、只允许指定域名、携带Cookie的跨域、动态设置允许的Origin、支持不同路径的跨域控制、静态资源跨域以及... 目录一、基本跨域配置二、只允许指定域名跨域三、完整示例四、配置后重载 nginx五、注意事项六、支持

Qt实现对Word网页的读取功能

《Qt实现对Word网页的读取功能》文章介绍了几种在Qt中实现Word文档(.docx/.doc)读写功能的方法,包括基于QAxObject的COM接口调用、DOCX模板替换及跨平台解决方案,重点讨论... 目录1. 核心实现方式2. 基于QAxObject的COM接口调用(Windows专用)2.1 环境

MySQL查看表的历史SQL的几种实现方法

《MySQL查看表的历史SQL的几种实现方法》:本文主要介绍多种查看MySQL表历史SQL的方法,包括通用查询日志、慢查询日志、performance_schema、binlog、第三方工具等,并... 目录mysql 查看某张表的历史SQL1.查看MySQL通用查询日志(需提前开启)2.查看慢查询日志3.

MySQL底层文件的查看和修改方法

《MySQL底层文件的查看和修改方法》MySQL底层文件分为文本类(可安全查看/修改)和二进制类(禁止手动操作),以下按「查看方法、修改方法、风险管控三部分详细说明,所有操作均以Linux环境为例,需... 目录引言一、mysql 底层文件的查看方法1. 先定位核心文件路径(基础前提)2. 文本类文件(可直