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

【机器人-基础知识】ROS常见功能架构

文章目录

  • 1. ROS 驱动、节点、Launch
  • 2. 相机
    • 2.1. UVC(USB Video Class)
    • 2.2. CSI Camera(Camera Serial Interface)
    • 2.3. v4l2-ctl(Video for Linux 2)
      • 2.3.1. 安装:
      • 2.3.2. 常见命令
    • 2.4. GStreamer
      • 2.4.1. 基本语法结构
      • 2.4.2. 常用命令
      • 2.4.3. gscam (GStreamer Camera Driver for ROS)
    • 2.5. 像素格式(Pixel Format)

1. ROS 驱动、节点、Launch

在这里插入图片描述

2. 相机

2.1. UVC(USB Video Class)

USB 设备类标准,专门用于视频设备(如摄像头)与主机(如电脑、嵌入式系统)之间的通信。

  1. 免驱支持: 只要是 UVC 兼容的摄像头,插入电脑即可被识别(即插即用)
  2. 跨平台兼容: 支持 Windows、Linux、macOS、Android、ROS 等
  3. 标准化协议: 规范了视频格式(如 MJPEG、YUY2、H.264)、分辨率、帧率、控制命令(如曝光、白平衡)等
  4. 广泛应用: 常见于 USB 摄像头、网络摄像头、工业相机、机器人视觉系统

2.2. CSI Camera(Camera Serial Interface)

专为嵌入式系统和移动设备设计的高速、低功耗的摄像头模块。它通过 MIPI CSI(Mobile Industry Processor Interface Camera Serial Interface)标准与主机处理器(如 SoC)直接连接。

2.3. v4l2-ctl(Video for Linux 2)

一个 命令行工具,用于控制和查询 Linux 系统中支持 V4L2(Video for Linux 2) 标准的视频设备(如摄像头)。它是 v4l-utils 软件包的一部分,广泛用于调试、配置和查看 USB 摄像头(尤其是 UVC 摄像头)的参数。

2.3.1. 安装:

sudo apt update
sudo apt install v4l-utils

验证:

v4l2-ctl --version

2.3.2. 常见命令

功能命令说明
列出视频设备v4l2-ctl --list-devices显示所有摄像头设备及 /dev/videoX 路径
列出所有格式v4l2-ctl -d /dev/video0 --list-formats-ext列出支持的分辨率、帧率、像素格式
获取当前格式v4l2-ctl -d /dev/video0 --get-fmt-video显示当前设置的分辨率、像素格式等
设置分辨率和像素格式v4l2-ctl -d /dev/video0 --set-fmt-video=width=1920,height=1080,pixelformat=MJPG选择分辨率和像素格式(如 YUYV, MJPG, RG10
抓取单帧图片v4l2-ctl -d /dev/video0 --stream-mmap --stream-count=1 --stream-to=frame.raw抓取一帧保存为 frame.raw
抓取多帧并保存v4l2-ctl -d /dev/video0 --stream-mmap --stream-count=10 --stream-to=out.raw抓取多帧连续数据
设置帧率v4l2-ctl -d /dev/video0 --set-parm=30设置目标帧率(需驱动支持)
查询当前帧率v4l2-ctl -d /dev/video0 --get-parm显示当前帧率和捕获参数
列出控件v4l2-ctl -d /dev/video0 --list-ctrls列出所有可调节参数(曝光、增益、白平衡等)
设置曝光v4l2-ctl -d /dev/video0 --set-ctrl=exposure_absolute=500设置曝光值(不同摄像头范围不同)
自动曝光开关v4l2-ctl -d /dev/video0 --set-ctrl=exposure_auto=11 表示自动,0 表示手动
设置增益v4l2-ctl -d /dev/video0 --set-ctrl=gain=10设置模拟/数字增益
自动白平衡开关v4l2-ctl -d /dev/video0 --set-ctrl=white_balance_automatic=0关闭自动白平衡
设置白平衡v4l2-ctl -d /dev/video0 --set-ctrl=white_balance_temperature=4500手动设置色温
连续预览(终端输出)v4l2-ctl -d /dev/video0 --stream-mmap --stream-count=0无限流输出(可配合管道转到 mplayerffplay

2.4. GStreamer

GStreamer 是一个开源的、跨平台的底层多媒体处理框架,用于构建高效的音频、视频处理流水线(Pipeline)。它广泛应用于嵌入式系统、桌面应用、流媒体服务和机器人开发中,特别是在 NVIDIA Jetson(如 Orin Nano) 平台上,是处理摄像头、编码、解码、推流的首选工具。

2.4.1. 基本语法结构

gst-launch-1.0 [选项] <元素1> ! <元素2> ! <元素3> ... ! <元素N>

2.4.2. 常用命令

用途命令示例说明
查看可用插件gst-inspect-1.0列出所有已安装的 GStreamer 插件
查看某插件信息gst-inspect-1.0 nvarguscamerasrc显示插件的属性、参数、支持的格式
摄像头实时预览(CSI 摄像头)gst-launch-1.0 nvarguscamerasrc sensor-id=0 ! nveglglessink从 CSI 摄像头读取并直接显示
摄像头预览 + 缩放gst-launch-1.0 nvarguscamerasrc ! nvvidconv ! "video/x-raw,width=640,height=480" ! nveglglessink缩放视频到指定分辨率显示
保存为 JPG 图片gst-launch-1.0 nvarguscamerasrc num-buffers=1 ! nvjpegenc ! filesink location=frame.jpg截取一帧并保存为 JPG
保存为 MP4 视频(H.264 编码)gst-launch-1.0 nvarguscamerasrc ! nvv4l2h264enc ! h264parse ! qtmux ! filesink location=video.mp4保存视频为 MP4 格式
USB 摄像头实时预览gst-launch-1.0 v4l2src device=/dev/video0 ! videoconvert ! autovideosink从 USB 摄像头读取并显示
播放本地 MP4 文件gst-launch-1.0 filesrc location=video.mp4 ! qtdemux ! h264parse ! avdec_h264 ! autovideosink解码 MP4 并播放
播放 RTSP 流gst-launch-1.0 rtspsrc location=rtsp://ip/stream ! rtph264depay ! h264parse ! avdec_h264 ! autovideosink播放 H.264 编码的 RTSP 视频流
网络推流(H.264 → UDP)gst-launch-1.0 nvarguscamerasrc ! nvv4l2h264enc ! rtph264pay ! udpsink host=192.168.1.100 port=5000从摄像头采集并推送到远程主机
网络接收(UDP → 显示)gst-launch-1.0 udpsrc port=5000 caps="application/x-rtp,media=video,encoding-name=H264" ! rtph264depay ! avdec_h264 ! autovideosink接收 UDP 视频并播放

2.4.3. gscam (GStreamer Camera Driver for ROS)

摄像头驱动包( ROS/ROS2 节点),利用 GStreamer 多媒体框架来捕获视频流,并将其发布为 ROS 中的标准图像消息(如 sensor_msgs/Image),从而让 ROS 系统可以处理来自摄像头的图像数据。


2.5. 像素格式(Pixel Format)

格式名称FourCC / 缩写位深度存储方式说明与用途
RGB888RGB3 / BGR324-bit每像素 3 字节 (R,G,B)无压缩,彩色图,常用于图像处理。
RGBA8888RGB4 / BGR432-bit每像素 4 字节,含 Alpha 通道透明度支持,GUI 或视频特效。
YUYVYUYV / YUY216-bitYUV 4:2:2常见于 USB 摄像头,亮度+色度交错存储。
UYVYUYVY16-bitYUV 4:2:2与 YUYV 类似,U/Y 交换顺序。
NV12NV1212-bitYUV 4:2:0,平面存储,UV 交错Jetson 硬件加速常用格式(ISP 输出)。
NV21NV2112-bitYUV 4:2:0,平面存储,VU 交错Android 摄像头常见格式。
I420I420 / YUV42012-bitYUV 4:2:0,3 平面图像编码、视频压缩前处理。
GRAY8GREY8-bit单通道灰度图工业相机、机器视觉。
Bayer RGGBRGGB8-bitBayer 原始传感器数据相机 ISP 输入,需去马赛克。
Bayer BGGRBGGR8-bitBayer 原始传感器数据另一种 Bayer 排列方式。
Bayer GBRGGBRG8-bitBayer 原始传感器数据另一种 Bayer 排列方式。
Bayer GRBGGRBG8-bitBayer 原始传感器数据另一种 Bayer 排列方式。
Bayer RG10RG1010-bitBayer 原始传感器数据,高精度工业相机、高分辨率相机(如 IMX477、IMX708)。
Bayer RG12RG1212-bitBayer 原始传感器数据高动态范围拍摄。
MJPEGMJPG压缩JPEG 帧序列节省带宽,USB 摄像头常用。
H.264H264压缩视频码流网络传输、录像存储。
http://www.dtcms.com/a/333115.html

相关文章:

  • 【JAVA高级】实现word转pdf 实现,源码概述。深坑总结
  • JavaScript(JS)DOM(四)
  • 提词器电脑版哪个好用?芦笋提词器优势评测与下载
  • 算法02 二进制与位运算
  • 解锁AI大模型:Prompt工程全面解析
  • 迭代器模式C++
  • Unity中 terriaria草,在摄像机拉远的时候就看不见了,该怎么解决
  • week1-[循环嵌套]蛇
  • 低资源语言翻译:数据增强与跨语言迁移学习策略
  • git疑问,暂时记录
  • “降碳30%+节能25%,园区智慧能源管理系统重塑示范园区竞争力
  • Flutter Form组件的基本使用
  • 【Python办公】Excel转json(极速版)-可自定义累加字段(如有重复KEY)
  • 力扣top100(day04-06)--贪心算法
  • LeetCode 53.最大子数组和:贪心算法下的连续子数组最优解
  • Android项目中Ktor的引入与使用实践
  • mlir clone
  • 【C#补全计划】事件
  • 【C#】 GridControl与GridView、容器和视图
  • Spring事务 概念 配置 隔离级别 脏读幻读不可重复读 传播行为
  • pyinstaller-从安装到高级使用
  • align-content 设置侧轴上的子元素的排列方式(多行)
  • Git代码版本管理
  • OpenCV---getStructuringElement 结构元素获取
  • 设计心得——如何架构选型
  • ffmpeg 安装、配置与使用完全指南
  • 自学大语言模型之Transformer的Tokenizer
  • jenkins 自动部署
  • 开发Chrome/Edge插件基本流程
  • mysql中in 和 exists 区别