USB摄像头

Quectel Pi H1单板电脑支持USB接口摄像头,下面选取微雪的一款OV5693 5MP USB接口摄像头为例进行测试。

硬件接口

USB摄像头的连接线插入Quectel Pi H1type-A接口。

硬件连接位置:

查看相关信息

  1. SSH终端中运行以下命令,可查看系统识别到的USB设备信息:
dmesg | grep usb

  1. SSH终端中运行以下命令,可查看新增设备节点:
v4l2-ctl --list-devices

  • /dev/video2 —— 主视频节点,后面gst命令主要操作这个节点

  • /dev/video3 —— 元数据节点

  • /dev/media3 —— 硬件拓扑控制器,控制整个pipeline

  1. SSH终端中运行以下命令,可查看video节点支持的格式:
v4l2-ctl --list-formats-ext --device /dev/video2

  • 由图可知,该摄像头支持MJPGYUYV两种格式的图片输出。

功能使用

前提条件

连接好HDMI屏幕,在SSH终端中运行以下命令:

mount -o rw,remount /
export XDG_RUNTIME_DIR=/dev/socket/weston
export WAYLAND_DISPLAY=wayland-1

实时预览

  1. device终端中运行以下命令:
# MJPG格式,分辨率和帧率需和video节点支持的格式对应
gst-launch-1.0 v4l2src device=/dev/video2 ! image/jpeg,width=1280,height=720,framerate=30/1 ! jpegdec ! videoconvert ! waylandsink fullscreen=true

# YUV格式,分辨率和帧率需和video节点支持的格式对应
gst-launch-1.0 v4l2src device=/dev/video2 ! video/x-raw,format=YUY2,width=1280,height=720,framerate=10/1 ! videoconvert ! waylandsink fullscreen=true

命令说明:

gst-launch-1.0 -e

启动管线;-e保证按Ctrl+C停止时能正确收尾(EOS)。

v4l2src device=/dev/video2

V4L2设备 /dev/video2 采集数据。

image/jpeg,width=1280,height=720,framerate=30/1

要求摄像头输出1280×720@30 fpsMJPEG;若摄像头不支持,pipeline会直接报错。

jpegdec

MJPEG帧解码成原始YUV/RGB像素数据。

videoconvert

把像素格式转成waylandsink能接受的格式(通常是NV12/BGRx)。

waylandsink fullscreen=true

Wayland作为显示后端,并把窗口设置为全屏(无标题栏、铺满屏幕)。

视频录制

  1. device终端中运行以下命令:
gst-launch-1.0 -e v4l2src device=/dev/video2 io-mode=2 ! \
  image/jpeg,width=1280,height=720,framerate=30/1 ! \
  jpegdec ! videoconvert ! tee name=t \
  t. ! queue ! v4l2h264enc ! h264parse ! mp4mux ! filesink location=/opt/out.mp4 \
  t. ! queue ! videoconvert ! waylandsink  fullscreen=true sync=false
  1. 此命令以720p 30 FPS配置启动相机,并在h264视频编码后将其另存为视频文件。如果gst管道状态更改为 “PLAYING”,则表示摄像头正在运行。
  2. 如果要停止摄像头录制,请按下CTRL+C
  3. MP4文件保存在 /opt/ 目录。

命令说明:

  • v4l2src device=/dev/video2 io-mode=2

/dev/video2 设备捕获视频流,io-mode=2表示使用内存映射(mmap)模式,提高性能。

  • image/jpeg,width=1280,height=720,framerate=30/1

指定捕获的视频流格式为MJPEG,分辨率为1280×720,帧率为30fps

  • jpegdec

解码MJPEG格式的视频流,将其转换为原始的RGB/YUV格式。

  • videoconvert

将解码后的视频格式转换为适合后续处理的格式(例如,从YUV转换为RGBA)。

  • tee name=t

将一路视频流分成两路,后续可以通过t.引用这两路流。

  • t. ! queue

tee元素中取出一路流,并通过queue元素进行缓冲。

  • v4l2h264enc

将视频流编码为H.264格式。

  • h264parse

解析H.264编码的视频流,使其符合MP4文件格式的要求。

  • mp4mux

H.264视频流封装为MP4文件格式。

  • filesink location=/opt/out.mp4

将封装好的MP4文件保存到 /opt/out.mp4

  • t. ! queue

tee元素中取出另一路流,并通过queue元素进行缓冲。

  • videoconvert

将视频格式转换为适合Wayland显示器显示的格式。

  • waylandsink fullscreen=true sync=false

将视频流输出到Wayland显示器,以全屏模式显示视频,禁用同步模式,避免Wayland显示器等待数据流,从而提高显示性能。

  1. 播放视频文件,请在device终端中运行以下命令:
gst-launch-1.0 -e filesrc location=/opt/out.mp4 ! qtdemux ! queue ! h264parse ! v4l2h264dec capture-io-mode=5 output-io-mode=5 !  videocrop top=0 bottom=40 left=0 right=0 ! videoconvert ! waylandsink  fullscreen=true enable-last-sample=false

命令说明:

  • filesrc location=/opt/out.mp4

/opt/out.mp4文件读取数据。

  • qtdemux

MP4文件中的视频和音频流分离出来。

  • queue

缓冲数据,避免处理过程中的数据丢失。

  • h264parse

解析视频流中的H.264编码数据。

  • v4l2h264dec capture-io-mode=5 output-io-mode=5

使用V4L2解码器解码H.264视频流,capture-io-mode=5output-io-mode=5是硬件加速相关的参数。

  • videocrop top=0 bottom=40 left=0 right=0

由于视频流自动对齐,填充额外的像素信息,导致视频底部有绿边,因此裁剪底部40像素。

  • videoconvert

格式转换元素,确保裁剪后的视频流格式适合Wayland显示器。

  • waylandsink fullscreen=true enable-last-sample=false

将解码后的视频输出到Wayland显示器上,并设置为全屏模式,同时禁用最后一帧显示。

拍照

  1. device终端中运行以下命令:
gst-launch-1.0 -e v4l2src device=/dev/video2 io-mode=2 ! \
  image/jpeg,width=1280,height=720,framerate=30/1 ! \
  tee name=t \
  t. ! queue ! jpegdec ! videoconvert ! waylandsink sync=false \
  t. ! queue ! multifilesink location=/opt/shot-%05d.jpg max-files=5
  1. 按下CTRL+C,自动保存最后5张图片。

命令说明:

  • v4l2src device=/dev/video2 io-mode=2

USB摄像头采集MJPEG数据。

  • image/jpeg,width=1280,height=720,framerate=30/1

要求摄像头输出1280×720@30 fpsMJPEG流。

  • tee name=t

把同一路流一分为多,后面用t.引用。

  • t. ! queue ! jpegdec ! videoconvert ! waylandsink sync=false

预览分支:解码MJPEG → 转成RGB → 送到Wayland窗口实时显示。sync=false可减少延迟。

  • t. ! queue ! multifilesink location=shot-%05d.jpg max-files=5

拍照分支:每一帧原封不动保存为JPG,文件名自动编号 %05d5位数字)。max-files=5只保留最近5张,旧文件被自动删除。

  1. 要查看照片,请在device终端中输入以下命令:
gst-launch-1.0 filesrc location=/opt/shot-00036.jpg ! jpegdec ! imagefreeze ! waylandsink fullscreen=true
  1. 退出查看,请按下CTRL+C

命令说明:

  • filesrc location=/opt/shot-00036.jpg

从文件系统读取 /opt/shot-00036.jpg

  • jpegdec

JPEG压缩数据解码成原始RGB/YUV像素帧。

  • imagefreeze

只保留第一帧,后续不断重复这一帧 → 实现“静止图片”效果。

  • waylandsink fullscreen=true

把图像送到Wayland合成器全屏显示。