RPI-HMI-080D 使用教程

产品特性

  • 8/10.1英寸DSI触控屏,电容式十点触摸控制
  • IPS显示面板,硬件分辨率为1280×800
  • 采用全贴合工艺,确保画面更加清晰,减少光反射。
  • 钢化玻璃触摸盖板,硬度可达6H
  • 双 4Kp60 HDMI 显示输出
  • 集成500万像素前置摄像头
  • 支持Raspberry Pi 5/Raspberry Pi 4一体式安装
  • 直接通过Raspberry Pi的DSI接口驱动LCD,刷新率可达60Hz
  • 配合Raspberry Pi使用时,支持Bookworm系统免驱使用
  • 支持通过软件控制背光亮度
  • 铝合金CNC+钣金机壳,无风扇设计,提供优异的散热性能
  • 嵌入式安装,兼容VESA标准支架安装

参数介绍

参数描述
CPUBroadcom BCM2712、四核 Cortex-A76 (ARM v8) 64 位 SoC,主频 2.4GHz
GPUOpenGL ES 3.1 & Vulkan 1.0
CAM内置500万像素前置摄像头
USB2 个 USB 2.0 端口,双层 A 型连接器,每个通道最高支持 480Mbps
2 个 USB 3.0 端口,双层 A 型连接器,每个通道最高支持 5Gbps
ETH千兆以太网
Wi-Fi双频 802.11ac Wi-Fi
BLE蓝牙 5.0/低功耗蓝牙 (BLE)
HDMI2 个 标准HDMI 端口,支持 4K 60Hz
内存64GB
尺寸8.0" / 10.1"
分辨率1280 x 800
刷新率60Hz
可视角度178°
最大亮度300cd/㎡
色域50%NTSC
背光调节软件调光

电气规格

参数最小值标准值最大值单位Note
输入电压4.755.005.25VNote 1
输入电流55TBDANote 2
工作温度02560Note 3
存储温度-102570Note 3

•Note 1:输入电压超过最大值或操作不当可能会对设备造成永久性损坏。
•Note 2:输入电流需≥5A,否则将导致启动失败或者显示异常,长时间处于异常状态可能会对设备造成永久性损坏。
•Note 3:请不要将显示屏长期置于高温高湿的存储环境,显示屏需在极限值范围内工作,否则将可能损坏显示屏。

硬件组装

如果您购买的是一体机版本(PI5-HMI-080D、PI5-HMI-101D、PI4-HMI-080D或PI4-HMI-101D),则无需进行硬件组装,直接通电即可使用。
以下为PI5-HMI-080D的硬件组装步骤:

准备好以下配件:

1.首先拧开金属后盖的四颗螺丝,取出金属后盖。


2.将导热硅胶片(①和②)和散热器(⑤)分别安装在树莓派5主板的正反面,并插入配套的64GB系统卡(③)。


3.将树莓派5主板与扩展板连接,确保树莓派的安装孔与屏背面的四个螺柱孔对齐,使用M2.5*4mm的银色金属螺丝固定。


4.使用CSI排线(⑩),将CSI接口连接到树莓派的CAM/DISP 1接口;
  使用DSI排线(⑨),将DSI接口连接到树莓派的CAM/DISP 0接口;


5.安装金属前板(⑧),并将硅胶按键(④)固定在外壳内,使用KM2.5*5mm的黑色金属螺丝固定。
(PI4 和 PI5的前盖板孔位不一致,请注意区分)


6.使用M2.5*5mm的黑色金属螺丝固定侧盖板。


7.最后,安装绿色端子到后盖板,完成硬件组装。


软件设置

Bookworm系统设置

如果您使用的是预装的系统卡,您无需进行任何软件配置。插入卡片并启动设备,默认用户名为pi,密码为raspberry,即可直接进入桌面环境。

手动安装系统和驱动

  • 2. 烧录完成后,在TF卡根目录找到config.txt文件,打开并在文件末尾添加以下代码,保存并安全弹出TF卡。
dtoverlay=vc4-kms-v3d
dtoverlay=ov5647
dtoverlay=vc4-kms-dsi-waveshare-panel,10_1_inch
  • 3. 将TF卡插入树莓派,开机后设备会自动识别显示器和触摸屏,您可以正常使用。

Buster和Bullseye系统设置


方法一:手动安装驱动

1. 在树莓派官网下载最新版本的镜像,将压缩文件下载到PC上,并解压得到.img文件。
2. TF卡连接到PC,使用SDFormatter软件格式化TF卡。
3. 打开Win32DiskImager软件,选择第1步准备的系统镜像,点击write烧写系统镜像。
4. 烧写完成后,将TF卡接入到树莓派上,并启动树莓派,登录树莓派的终端(可以将树莓派接到HDMI显示器或用ssh远程登录)。

#第一步:下载并进入Waveshare-DSI-LCD驱动文件夹
git clone https://github.com/waveshare/Waveshare-DSI-LCD
cd Waveshare-DSI-LCD
#第二步:终端输入uname -a查看内核版本,并cd到对应文件目录 #6.1.21则运行下面指令 cd 6.1.21
#第三步:请确定当前使用的系统是多少位的,32位系统进入32目录,64位系统进入64目录 cd 32 #cd 64
#第四步:运行屏幕驱动 sudo bash ./WS_xinchDSI_MAIN.sh 101C I2C0
#第五步:等待几秒,当驱动安装完成,没有提示任何报错时,进行重启加载DSI驱动即可正常使用 sudo reboot #注意:以上步骤需要确保树莓派可以正常连接到互联网。

5.等待系统重启,将可以正常显示和触摸。

方法二:烧写预安装镜像

1.选择您对应的树莓派版本镜像,下载并解压为.img文件
树莓派4B/CM4版本下载:Waveshare DSI LCD - Pi4预安装镜像
2.TF卡连接到PC,使用SDFormatter软件格式化TF卡。
3.打开Win32DiskImager软件,选择第1步准备的系统镜像,点击write烧写系统镜像。
4.烧写完成后,打开TF卡根目录的config.txt文件,在[all]下方加入以下代码,保存并安全弹出TF卡。

dtoverlay=WS_xinchDSI_Screen,SCREEN_type=8,I2C_bus=10
dtoverlay=WS_xinchDSI_Touch,invertedx,swappedxy,I2C_bus=10
5.启动树莓派,30秒后屏幕和触摸功能应正常工作。。

调节背光亮度

  • 1.打开"Screen Configuration"应用程序;

  • 2.进入"Screen"->"DSI-2"->"Brightness" ,勾选您需要设置的背光亮度,最后点击"Apply",即可完成背光设置。

微雪也提供了对应的应用程序(该程序仅用于Bookworm和Bullseye系统),用户可以通过以下方式下载安装使用:

wget https://www.waveshare.net/w/upload/f/f4/Brightness.zip
unzip Brightness.zip
cd Brightness
sudo chmod +x install.sh
./install.sh

安装完成后,可以在开始菜单-》Accessories -》Brightness 打开该程序,如下图:

另外,也在终端输入以下命令可以控制背光亮度:

echo X | sudo tee /sys/class/backlight/*/brightness

其中X表示0~255中的任意数字。0表示背光最暗,255表示背光最亮。例如:

echo 100 | sudo tee /sys/class/backlight/*/brightness
echo 0 | sudo tee /sys/class/backlight/*/brightness
echo 255 | sudo tee /sys/class/backlight/*/brightness

显示旋转

Bookworm显示旋转

GUI 界面旋转

  • 1.打开"Screen Configuration"应用程序;

  • 2.进入"Screen"->"DSI-1"->"Touchscreen" ,勾选"6-0038 generic ft5x06(79)"

  • 3.单击"Apply"并关闭当前窗口。根据弹出提示重新启动,然后触摸屏选择完成。

  • 4.进入"Screen"->"DSI-1"->"Orientation" ,勾选您需要旋转的方向,最后点击“Apply”,即可完成显示屏和触摸的同步旋转。


注意:仅Bookworm系统支持以上同步旋转方法。对于Bullseye和Butser系统,显示旋转后,需手动单独设置触摸旋转。

lite版本显示旋转

  • 1.需要修改/boot/cmdline.txt文件:
sudo nano /boot/cmdline.txt
  • 2.在cmdline.txt文件开头,添加对应显示旋转角度的指令:(请注意,该命令需要放在同一行上,每个命令用空格分隔。)
video=DSI-1:800x480M@60,rotate=90

通过将rotate值更改为 90、180 或 270 来更改显示旋转的角度。

  • 3.保存并重新启动
sudo reboot

Bullseye/Buster显示旋转

GUI 界面旋转

  • 1.打开"Screen Configuration"应用程序;

  • 2.进入"Screen"->"DSI-1"->"Orientation" ,勾选您需要旋转的方向,最后点击"Apply",即可完成显示旋转。


lite版本显示旋转

  • 1.需要修改/boot/cmdline.txt文件:
sudo nano /boot/cmdline.txt
  • 2.在cmdline.txt文件开头,添加对应显示旋转角度的指令:(请注意,该命令需要放在同一行上,每个命令用空格分隔。)
video=DSI-1:800x480M@60,rotate=90

通过将rotate值更改为 90、180 或 270 来更改显示旋转的角度。

  • 3.保存并重新启动
sudo reboot

Stretch/Jessie显示旋转

对于一些比较古老的系统,它们不使用vc4-kms-v3d 或 vc4-fkms-v3d 驱动模式,显示旋转方法如下

  • 1. 在config.txt文件中加入语句(config文件位于TF卡根目录,即/boot中):
display_rotate=1 #1:90;2: 180; 3: 270
  • 2. 保存后重启树莓派即可
sudo reboot

触摸旋转

Bookworm 触摸

如果使用图形界面进行旋转,可以在屏幕布局编辑器窗口中勾选“Touchscreen”来同步触摸旋转。屏幕旋转方法请参考前面的介绍。命令行旋转方法请参考以下文字:
1. 创建一个名为的新文件99-waveshare-touch.rules

sudo nano /etc/udev/rules.d/99-waveshare-touch.rules

2. 根据需要添加以下行:

#90°:
ENV{ID_INPUT_TOUCHSCREEN}=="1", ENV{LIBINPUT_CALIBRATION_MATRIX}="0 -1 1 1 0 0"

#180°:
#ENV{ID_INPUT_TOUCHSCREEN}=="1", ENV{LIBINPUT_CALIBRATION_MATRIX}="-1 0 1 0 -1 1"

#270°:
#ENV{ID_INPUT_TOUCHSCREEN}=="1", ENV{LIBINPUT_CALIBRATION_MATRIX}="0 1 0 -1 0 1"

3. 保存并重启

sudo reboot

Bullseye/Buster 触摸

部分系统显示旋转后,触摸方向不一致,需要按下文操作进行触摸旋转:
1. 安装libinput

sudo apt-get install xserver-xorg-input-libinput
  • 如果你安装的是Ubuntu系统,或者是Jetson Nano。安装指令为
sudo apt install xserver-xorg-input-synaptics

2. 在/etc/X11/下创建xorg.conf.d目录 (如果该目录已存在,这直接进行第3步)

sudo mkdir /etc/X11/xorg.conf.d

3. 复制40-libinput-conf 文件到刚刚创建的目录下

sudo cp /usr/share/X11/xorg.conf.d/40-libinput.conf /etc/X11/xorg.conf.d/

4. 编辑该文件

sudo nano /etc/X11/xorg.conf.d/40-libinput.conf
#找到 touchscreen的部分,在里面添加对应的旋转角度指令,然后保存即可
#90°Right触摸旋转:
Option "CalibrationMatrix" "0 1 0 -1 0 1 0 0 1"
#180° Inverted触摸旋转: 
#Option "CalibrationMatrix" "-1 0 1 0 -1 1 0 0 1"
#270° Left旋转: 
#Option "CalibrationMatrix" "0 -1 1 1 0 0 0 0 1"
类似下图位置:


5. 重启树莓派

sudo reboot

完成以上步骤后触摸将会进行旋转。

远程登陆树莓派

配置Wi-Fi

  • 在支持 5GHz 频段的树莓派设备(如 Pi 3B+、Pi 4、CM4、Pi 400)上,需要先设置国家代码,才能正常使用无线网络。

1. 打开终端,输入 sudo raspi-config,选择 Localisation Options > WLAN Country(设置国家代码),按回车。
2. 从列表中选择你所在的国家(例如:中国选择 CN),确认后按 OK。(如果你不知道你的国家代码可以去wikipedia查找)
3. 返回主界面,按 Finish,系统会提示重启,选择 Yes,等待树莓派重启。
4. 完成后,你就能在树莓派上连接无线网络,输入密码完成连接。

Config-wlan水印新.gif

查找设备IP

获取树莓派的 IP 地址是进行远程登录的前提,请在配置好WIFI或者连接好网线后,参考以下步骤操作。

在桌面查看 IP 地址

如果使用桌面版操作系统,将鼠标悬停在右上角的网络图标上,会显示当前连接的网络名称和 IP 地址。

登录路由器查看

  • 通过登录路由器的管理界面,可以查看连接到网络的设备及其 IP 地址。

使用手机应用获取地址(仅限苹果设备)

  • 在应用商店搜索Fing应用程序,它是一款适用于智能手机的免费网络扫描仪,扫描当前网络,列出所有设备及其 IP 地址。
  • 注意:您的手机和树莓派必须在同一网络上,因此请将您的手机连接到正确的无线网络。
  • 打开 Fing 应用程序时,触摸屏幕左上角的设备扫描。
  • 几秒钟您将获得一个设备连接列表 其中包含连接网络的所有设备。
  • 此时我们就成功获取树莓派的IP地址:192.168.0.105。

使用Advanced IP Scanner

  • 你可以通过一些局域网IP扫描工具,这里以Advanced IP Scanner为例程
    1. 运行Advanced IP Scanner
    2. 点击Scan按钮,扫描当前局域网内的IP地址
    3. 找到所有Manufacturer中有Raspberry Pi字样的IP地址并记录
    4. 将设备上电,并确保设备连接上网络后
    5. 重新点击Scan按钮,扫描当前局域网内的IP地址
    6. 排除掉所有先前记录的Manufacturer中有Raspberry Pi字样的IP地址,剩下的就是你的树莓派IP地址了

使用nmap指令获取

  • 下载并安装nmap,否则计算机无法识别该指令。
  • 按住键盘WIN+R,输入cmd,打开终端。
  • 在使用nmap指令前我们需要知道我们电脑的IP地址,通过电脑的IP地址我们才能知道IP网段,再去使用nmap扫描这个网段下的设备。
 ipconfig  
  • 如果您的 IP 地址是192.168.1.5,则其他设备的地址将在这个192.168.1.0/24子网范围内(这涵盖192.168.1.0到192.168.1.255)。
  • 我的计算机是192.168.0.104。现在在整个子网范围上使用nmap带有标志(ping 扫描)的命令。-sn这可能需要几秒钟:
nmap -sn 192.168.0.0/24
  • 此时我们就成功获取树莓派的IP地址:192.168.0.105。

启用SSH和VNC

  • 打开树莓派终端输入raspi-config进入设置界面,选择Interface Options。
  • 进入Interfaces选项卡。
  • 选择SSH旁边的Enable。
  • 点击OK。
  • 重启树莓派。

VNC同理,参考以上步骤配置。

    • boot盘符下新建一个名为ssh的文件,不要任何扩展名,你可以新建一个ssh.txt,确保文件夹选项中的设置是显示扩展名的,然后将.txt删除,这样你就获得了一个没有任何扩展名的名为ssh的文件。


远程登陆

VNC登陆

请先确保树莓派与你的电脑出于一个路由器下或同一网段并参考上述步骤开启了VNC登陆功能。

  1. 下载打开远程登录软件VNC-Viewer
  2. 打开VNC输入树莓派的IP地址:

  3. 选择Continue:

  4. Username:pi Password:raspberry :

  5. 这里就登录成功了:

SSH登陆

使用MobaXterm软件

请先确保树莓派与你的电脑出于一个路由器下或同一网段并参考上述步骤开启了SSH登陆功能。

  1. 打开远程登录软件MobaXterm
  2. 点击session,点击ssh,在Remote host输入树莓派的IP地址:
  3. 登录名为pi,密码是raspberry:

使用Windows自带的SSH登录指令

  1. 同时按win键和R键,输入cmd,回车,打开命令行
  2. 假设你获取到的地址为192.168.10.36,,指令就应为:
    ssh pi@192.168.10.36
  3. 输入yes确认:
  4. 输入树莓派的默认密码 raspberry:
  5. 注意:输入密码时屏幕上没有变化属于正常现象,密码输入完成后按回车键访问树莓派:
  6. 这里SSH就登录成功了:

PUTTY登录

  1. 打开对应的烧录工具putty,点击session,在IP adress输入树莓派的IP地址:
  2. 选择Accept(接受):
  3. 登录名为pi,密码是raspberry:

Raspberry Pi Connect 登陆

此功能需要Wayland窗口服务器。Raspberry Pi OS Bookworm及更高版本默认使用 Wayland。屏幕共享与 Raspberry Pi OS Lite 或使用 X 窗口服务器的系统 不兼容。

安装Connect

如果您的 Raspberry Pi OS 版本尚未安装 Connect,请打开终端窗口。运行以下命令来更新您的系统和软件包:

sudo apt update
sudo apt full-upgrade

在 Raspberry Pi 上运行以下命令来安装 Connect:

sudo apt install rpi-connect

启动Connect

安装后,使用rpi-connect命令行界面为当前用户启动 Connect:

rpi-connect on

或者,单击菜单栏中的“连接”图标以打开下拉菜单并选择“打开 Raspberry Pi 连接”: 
要停止 Connect,请运行以下命令:

rpi-connect off

将 Raspberry Pi 设备与 Connect 帐户关联

现在您已经在 Raspberry Pi 设备上安装并启动了 Connect,您必须将您的设备与 Connect 帐户关联。

如果您在菜单栏中使用 Connect 插件,首次单击“打开 Raspberry Pi Connect”以打开浏览器,提示您使用 Raspberry Pi ID 登录:

或者,从下拉菜单中选择“登录…​” :

如果您还没有 Raspberry Pi ID,请单击免费创建一个

完成 Raspberry Pi 的连接

验证后,为您的设备指定一个名称。选择一个唯一标识设备的名称。单击“创建设备并登录”按钮继续。

您现在可以远程连接到您的设备。菜单栏中的 Connect 图标将变为蓝色,表示您的设备现已登录 Connect 服务。您应该会收到一封电子邮件通知,表明有新设备已链接到您的 Connect 帐户。

访问你的 Raspberry Pi 设备

现在您的设备已显示在 Connect 界面上,您只需使用浏览器即可从任何地方访问您的设备。Connect 提供了多种方式与您的设备进行远程交互。

  • 在任何计算机上访问connect.raspberrypi.com
  • Connect 将您重定向到 Raspberry Pi ID 服务进行登录。登录后,Connect 会显示已链接设备的列表。可用于屏幕共享的设备会在设备名称下方显示灰色的屏幕共享徽章。


  • 单击您想要访问的设备右侧的“通过连接”按钮。从菜单中选择“屏幕共享”选项。这将打开一个显示设备桌面的浏览器窗口。


  • 现在,您可以像在本地一样使用您的设备。如需有关连接的更多信息,请将鼠标悬停在“断开连接”按钮右侧的挂锁图标上。


更多信息,请参考树莓派官网介绍

使用摄像头

在 Raspberry Pi OS Bookworm 中,相机捕获应用程序已从 libcamera-* 更改为 rpicam-*。虽然当前仍支持使用旧版的 libcamera,但该组件将于未来被弃用。为了确保系统的长期兼容性,建议尽快迁移到 rpicam。

注意: 默认出货的系统为 Raspberry Pi OS Bookworm,用户应直接使用 rpicam-* 进行相机管理。 如果您正在使用的是 Raspberry Pi OS Bullseye 系统,请参考下方链接,使用与 libcamera-* 相关的教程进行配置。

Rpicam

运行最新版本的 Raspberry Pi OS 时,rpicam-apps已经安装了五个基本功能。在这种情况下,官方的 Raspberry Pi 相机也将被检测并自动启用。
您可以通过输入以下内容来检查一切是否正常:

rpicam-hello 

会看到一个大约五秒钟的相机预览窗口.
注意:如果运行在 Bullseye 的 Raspberry Pi 3 和更早版本的设备上,您需要重新启用 Glamor,才能使 X Windows 硬件加速预览窗口正常工作。在终端窗口中输入sudo raspi-config,然后选择Advanced Options、Glamor和Yes.退出并重新启动您的 Raspberry Pi.默认情况下,运行 Bullseye 的 Raspberry Pi 3 和更早的设备可能未使用正确的显示驱动程序。请参阅 /boot/firmware/config.txt 文件,并确保 dtoverlay=vc4-fkms-v3d or dtoverlay=vc4-kms-v3d 当前处于活动状态。如果您需要更改此设置,请重新启动。

rpicam-hello

相当于相机的“hello world”,它启动相机预览流并将其显示在屏幕上,可以通过单击窗口的关闭按钮或在终端中使用ctrl^C来停止预览.
rpicam-hello -t 0
调谐文件

Raspberry Pi 的libcamera有针对每种不同类型的相机模块的调谐文件。文件里的参数将传递给算法和硬件以产生最佳质量的图像。 libcamera只能自动确定正在使用的图像传感器,而不能自动确定整个模块,即使整个模块会影响“调谐”。因此,有时需要覆盖特定传感器的默认调谐文件。
例如,无红外滤光片 (NoIR) 版本的传感器需要与标准版本不同的 AWB(白平衡) 设置,因此与 Pi 4 或更早设备一起使用的 IMX219 NoIR 应使用以下方式运行:

rpicam-hello --tuning-file /usr/share/libcamera/ipa/rpi/vc4/imx219_noir.json

Raspberry Pi 5 在不同的文件夹中使用不同的调谐文件,因此在这里您将使用:

rpicam-hello --tuning-file /usr/share/libcamera/ipa/rpi/pisp/imx219_noir.json

这也意味着用户可以复制现有的调谐文件并根据自己的喜好进行更改,只要参数--tuning-file指向新版本即可。
--tuning-file参数与其他命令行选项一样,同样适用于所有rpicam-apps.

rpicam-jpeg

rpicam-jpeg是一个简单的静态图像捕捉应用程序。
要捕获全分辨率 JPEG 图像,请使用以下指令,这将显示大约五秒钟的预览,然后将全分辨率 JPEG 图像捕获到文件中test.jpg

rpicam-jpeg -o test.jpg

该-t <duration>选项可用于更改预览显示的时间长度,并且--width和--height选项将更改捕获的静态图像的分辨率。例如:

rpicam-jpeg -o test.jpg -t 2000 --width 640 --height 480
曝光控制

所有这些都rpicam-apps允许用户以固定的快门速度和增益运行相机。拍摄曝光时间为 20ms、增益为 1.5x 的图像,该增益将用作传感器内的模拟增益,直到达到内核传感器驱动程序允许的最大模拟增益,之后其余部分将用作数字增益。

rpicam-jpeg -o test.jpg -t 2000 --shutter 20000 --gain 1.5

Raspberry Pi 的 AEC/AGC 算法允许应用程序指定曝光补偿:能够通过给定的停止次数使图像变暗或变亮。

rpicam-jpeg --ev -0.5 -o darker.jpg
rpicam-jpeg --ev 0 -o normal.jpg
rpicam-jpeg --ev 0.5 -o brighter.jpg
数字增益

数字增益由 ISP 应用,而不是由传感器应用。数字增益将始终非常接近 1.0,除非:

  • 请求的总增益(通过选项--gain或通过相机调整中的曝光配置文件)超过了可以在传感器内用作模拟增益的增益。只有所需的额外增益才会用作数字增益。
  • 其中一个颜色增益小于 1(请注意,颜色增益也用作数字增益)。在这种情况下,公布的数字增益将稳定为 1 / 分钟(红色增益,蓝色增益)。这意味着其中一个颜色通道(而不是绿色通道)应用了单位数字增益。
  • AEC/AGC 正在发生变化。当 AEC/AGC 移动时,数字增益通常会发生一定程度的变化,以尝试消除任何波动,但它会很快恢复到正常值。

rpicam-still

模拟raspistill原始应用程序的许多功能.

rpicam-still -o test.jpg
编码器

rpicam-still允许文件以多种不同的格式保存。它支持png和bmp编码。它还允许将文件保存为 RGB 或 YUV 像素的二进制转储,没有编码或文件格式。在后一种情况下,读取文件的应用程序必须了解其自身的像素排列。

rpicam-still -e png -o test.png
rpicam-still -e bmp -o test.bmp
rpicam-still -e rgb -o test.data
rpicam-still -e yuv420 -o test.data

注意,保存图像的格式取决于-e(相当于——encoding)选项,不会根据输出文件名自动选择。

Raw图像捕捉

raw图是由图像传感器直接产生的图像,在ISP(图像信号处理器)或任何CPU内核对其进行任何处理之前。对于彩色图像传感器,这些通常是Bayer格式图像。请注意,原始图像与我们之前看到的经过处理但未编码的RGB或YUV图像有很大不同。
获取raw图:

rpicam-still --raw --output test.jpg

这里,-r选项(也是——raw)表示捕获原始图像和JPEG。实际上,原始图像就是生成JPEG的raw图像。原始图像以DNG (Adobe Digital Negative)格式保存,并与许多标准应用程序(如draw或RawTherapee)兼容。原始图像保存到具有相同名称但扩展名为. ng的文件中,因此是test.dng。
这些DNG文件包含与图像捕获有关的元数据,包括黑电平、白平衡信息和ISP用于生成JPEG的颜色矩阵。这使得这些DNG文件在以后使用上述一些工具进行“手动”原始转换时更加方便。使用exiftool显示编码到DNG文件中的所有元数据:

File Name                       : test.dng
Directory                       : .
File Size                       : 24 MB
File Modification Date/Time     : 2021:08:17 16:36:18+01:00
File Access Date/Time           : 2021:08:17 16:36:18+01:00
File Inode Change Date/Time     : 2021:08:17 16:36:18+01:00
File Permissions                : rw-r--r--
File Type                       : DNG
File Type Extension             : dng
MIME Type                       : image/x-adobe-dng
Exif Byte Order                 : Little-endian (Intel, II)
Make                            : Raspberry Pi
Camera Model Name               : /base/soc/i2c0mux/i2c@1/imx477@1a
Orientation                     : Horizontal (normal)
Software                        : rpicam-still
Subfile Type                    : Full-resolution Image
Image Width                     : 4056
Image Height                    : 3040
Bits Per Sample                 : 16
Compression                     : Uncompressed
Photometric Interpretation      : Color Filter Array
Samples Per Pixel               : 1
Planar Configuration            : Chunky
CFA Repeat Pattern Dim          : 2 2
CFA Pattern 2                   : 2 1 1 0
Black Level Repeat Dim          : 2 2
Black Level                     : 256 256 256 256
White Level                     : 4095
DNG Version                     : 1.1.0.0
DNG Backward Version            : 1.0.0.0
Unique Camera Model             : /base/soc/i2c0mux/i2c@1/imx477@1a
Color Matrix 1                  : 0.8545269369 -0.2382823821 -0.09044229197 -0.1890484985 1.063961506 0.1062747385 -0.01334283455 0.1440163847 0.2593136724
As Shot Neutral                 : 0.4754476844 1 0.413686484
Calibration Illuminant 1        : D65
Strip Offsets                   : 0
Strip Byte Counts               : 0
Exposure Time                   : 1/20
ISO                             : 400
CFA Pattern                     : [Blue,Green][Green,Red]
Image Size                      : 4056x3040
Megapixels                      : 12.3
Shutter Speed                   : 1/20

我们注意到只有一个校准光源(由AWB算法确定的光源,尽管它总是被标记为“D65”),并且将ISO数除以100给出正在使用的模拟增益。

超长曝光

为了捕捉长时间曝光的图像,请禁用AEC/AGC和AWB,因为这些算法将迫使用户在收敛时等待许多帧。
禁用它们的方法是提供显式的值。此外,可以使用——immediate选项跳过捕获的整个预览阶段。
因此,要执行100秒曝光捕捉,使用;

rpicam-still -o long_exposure.jpg --shutter 100000000 --gain 1 --awbgains 1,1 --immediate

作为参考,三款官方树莓派相机的最大曝光时间可以在这个表格中找到。

rpicam-vid

rpicam-vid可以帮助我们在树莓派设备上捕获视频。Rpicam-vid显示一个预览窗口,并将编码的比特流写入指定的输出。这将产生一个未打包的视频比特流,它没有被打包在任何类型的容器(如mp4文件)格式中。

  • rpicam-vid请使用的是 H.264 编码

例如,下面的命令将一个10秒的视频写入一个名为test.h264的文件:

rpicam-vid -t 10s -o test.h264

您可以使用VLC和其他视频播放器播放结果文件:

VLC test.h264

在Raspberry Pi 5上,您可以通过指定输出文件的MP4文件扩展名直接输出到MP4容器格式:

rpicam-vid -t 10s -o test.mp4
编码器

rpicam-vid支持动态JPEG以及未压缩和未格式化的YUV420:

rpicam-vid -t 10000 --codec mjpeg -o test.mjpeg
rpicam-vid -t 10000 --codec yuv420 -o test.data

codec选项决定输出格式,而不是输出文件的扩展名。
segment选项将输出文件分割成段大小的块(以毫秒为单位)。通过指定非常短(1毫秒)的段,这可以方便地将运动JPEG流分解为单个JPEG文件。例如,下面的命令将1毫秒的段与输出文件名中的计数器结合起来,为每个段生成一个新的文件名:

rpicam-vid -t 10000 --codec mjpeg --segment 1 -o test%05d.jpeg
捕获高帧率视频

为了尽量减少高帧率(> 60fps)视频的帧丢失,请尝试以下配置调整:

  • 将H.264的目标水平用 --level 4.2 这个参数设置为4.2
  • 通过将denoise选项设置为cdn_off来禁用软件颜色降噪处理。
  • 禁用nopreview的显示窗口以释放一些额外的CPU周期。
  • 在/boot/firmware/config.txt中设置force_turbo=1,确保在视频捕获过程中CPU时钟不节流。有关更多信息,请参阅force_turbo文档。
  • 将ISP输出分辨率参数调整为--width 1280 --height 720或更低,以实现帧率目标。
  • 在Raspberry Pi 4上,您可以通过在/boot/firmware/config.txt中添加gpu_freq=550或更高的频率来超频GPU以提高性能。有关详细信息,请参阅在超频文档。

下面的命令演示了如何实现1280×720 120fps视频:

rpicam-vid --level 4.2 --framerate 120 --width 1280 --height 720 --save-pts timestamp.pts -o video.264 -t 10000 --denoise cdn_off -n
Libav与picam-vid的集成

Rpicam-vid可以使用ffmpeg/libav编解码器后端对音频和视频流进行编码。您可以将这些流保存到文件中,也可以通过网络将它们流式传输。
要启用libav后端,将libav传递给 codec 选项:

rpicam-vid --codec libav --libav-format avi --libav-audio --output example.avi
UDP

要使用树莓派作为服务器在UDP上流式传输视频,使用以下命令,将< IP -addr>占位符替换为客户端或多播地址的IP地址,并将<port>占位符替换为您想要用于流式传输的端口:

rpicam-vid -t 0 --inline -o udp://<ip-addr>:<port>

使用树莓派作为客户端通过UDP查看视频流,使用以下命令,将<port>占位符替换为您想要流式传输的端口:

vlc udp://@:<port> :demux=h264

或者,在客户端使用以下命令使用ffplay进行流:

ffplay udp://<ip-addr-of-server>:<port> -fflags nobuffer -flags low_delay -framedrop
TCP

还可以通过TCP传输视频。使用树莓派作为服务器:

rpicam-vid -t 0 --inline --listen -o tcp://0.0.0.0:<port>

使用树莓派作为客户端通过TCP查看视频流,使用以下命令:

vlc tcp/h264://<ip-addr-of-server>:<port>

或者,在客户端使用以下命令以每秒30帧的速度使用ffplay流:

ffplay tcp://<ip-addr-of-server>:<port> -vf "setpts=N/30" -fflags nobuffer -flags low_delay -framedrop
RTSP

要使用VLC通过RTSP传输视频,使用树莓派作为服务器,使用以下命令:

rpicam-vid -t 0 --inline -o - | cvlc stream:///dev/stdin --sout '#rtp{sdp=rtsp://:8554/stream1}' :demux=h264

使用树莓派作为客户端查看RTSP上的视频流,使用以下命令:

ffplay rtsp://<ip-addr-of-server>:8554/stream1 -vf "setpts=N/30" -fflags nobuffer -flags low_delay -framedrop

或者在客户端使用以下命令使用VLC进行流:

vlc rtsp://<ip-addr-of-server>:8554/stream1

如果需要关闭服务器上的预览窗口,使用nopreview命令。
使用内联标志强制流报头信息进入每个内帧,这有助于客户端在错过开头时理解流。

rpicam-raw

rpicam-raw直接从传感器将视频记录为原始的 Bayer帧。它不显示预览窗口。将两秒钟的原始剪辑记录到一个名为test.raw的文件中,执行如下命令:

rpicam-raw -t 2000 -o test.raw

Rpicam-raw输出没有任何格式信息的原始帧。应用程序将像素格式和图像尺寸打印到终端窗口,以帮助用户解析像素数据。
默认情况下,rpicam-raw在单个可能非常大的文件中输出原始帧。使用segment选项将每个原始帧定向到一个单独的文件,使用%05d指令使每个帧文件名唯一:

rpicam-raw -t 2000 --segment 1 -o test%05d.raw

通过快速存储设备,rpicam-raw可以以10fps的速度将18MB的1200万像素HQ相机帧写入磁盘。rpicam-raw无法将输出帧格式化为DNG文件;要实现这个功能,请使用 rpicam-still以低于10的帧率选项来避免掉帧的情况:

rpicam-raw -t 5000 --width 4056 --height 3040 -o test.raw --framerate 8

有关原始格式的更多信息,请参阅mode文档。

rpicam-detect

注意:树莓派操作系统不包含rpicam-detect。如果您已经安装了TensorFlow Lite,则可以构建rpicam-detect。有关更多信息,请参见rpicam-apps构建说明。不要忘记在运行cmake时传递-DENABLE_TFLITE=1。
rpicam-detect显示一个预览窗口,并使用Google MobileNet v1 SSD (Single Shot Detector)神经网络来监控内容,该神经网络经过训练,可以使用Coco数据集识别大约80类对象。Rpicam-detect可以识别人、汽车、猫和许多其他物体。
每当rpicam-detect检测到目标对象时,它就捕获一个全分辨率JPEG。然后返回到监控预览模式。
有关模型使用的一般信息,请参阅TensorFlow Lite对象检测器部分。例如,当你外出时,你就能监视你的猫:

rpicam-detect -t 0 -o cat%04d.jpg --lores-width 400 --lores-height 300 --post-process-file object_detect_tf.json --object cat

rpicam参数设置

  • --help -h 打印全部选项,以及每个选项的简要介绍
rpicam-hello -h
  • --version 输出libcamera和rpicam-apps的版本字符串
rpicam-hello --version

示例输出:

rpicam-apps build: ca559f46a97a 27-09-2021 (14:10:24)
libcamera build: v0.0.0+3058-c29143f7
  • --list-cameras 列出连接到树莓派的摄像头及其可用的传感器模式
rpicam-hello --list-cameras

传感器模式标识符有以下形式:

S<Bayer order><Bit-depth>_<Optional packing> : <Resolution list>

裁剪在原生传感器像素(即使在像素分割模式下)中指定为(<x>, <y>)/<Width>×<Height>。(x, y)指定 width × height大小的裁剪窗口在传感器阵列中的位置。
例如,以下输出显示索引为0的IMX219传感器和索引为1的IMX477传感器的信息:

Available cameras
-----------------
0 : imx219 [3280x2464] (/base/soc/i2c0mux/i2c@1/imx219@10)
    Modes: 'SRGGB10_CSI2P' : 640x480 [206.65 fps - (1000, 752)/1280x960 crop]
                             1640x1232 [41.85 fps - (0, 0)/3280x2464 crop]
                             1920x1080 [47.57 fps - (680, 692)/1920x1080 crop]
                             3280x2464 [21.19 fps - (0, 0)/3280x2464 crop]
           'SRGGB8' : 640x480 [206.65 fps - (1000, 752)/1280x960 crop]
                      1640x1232 [41.85 fps - (0, 0)/3280x2464 crop]
                      1920x1080 [47.57 fps - (680, 692)/1920x1080 crop]
                      3280x2464 [21.19 fps - (0, 0)/3280x2464 crop]
1 : imx477 [4056x3040] (/base/soc/i2c0mux/i2c@1/imx477@1a)
    Modes: 'SRGGB10_CSI2P' : 1332x990 [120.05 fps - (696, 528)/2664x1980 crop]
           'SRGGB12_CSI2P' : 2028x1080 [50.03 fps - (0, 440)/4056x2160 crop]
                             2028x1520 [40.01 fps - (0, 0)/4056x3040 crop]
                             4056x3040 [10.00 fps - (0, 0)/4056x3040 crop]
  • --camera 选择要使用的相机。从可用摄像机列表中指定一个索引。
rpicam-hello --list-cameras 0 
rpicam-hello --list-cameras 1 
  • --config -c,指定一个文件,里面包含了指令参数选项和值。一般是起名为example_configuration.txt的文件,将选项和值指定为键值对,每行一个选项
timeout=99000
verbose=

注意:省略通常在命令行中使用参数的前缀--。对于缺少值的标志,例如上面示例中的verbose,必须包含尾随的=。
然后可以运行以下命令,来指定99000毫秒的超时和详细输出:

rpicam-hello --config example_configuration.txt 
  • --time -t,默认5000毫秒的延时
rpicam-hello -t  

指定应用程序在关闭前运行多长时间。这适用于视频录制和预览窗口。当捕获静止图像时,应用程序在捕获输出图像之前显示一个超时毫秒的预览窗口。

rpicam-hello -t 0
  • --preview 设置桌面或DRM预览窗口的位置(x,y坐标)和大小(w,h尺寸)。不会影响从相机请求的图像的分辨率或宽高比

以以下逗号分隔的形式传递预览窗口尺寸:x,y,w,h

rpicam-hello --preview 100,100,500,500
  • --fullscreen -f,强制预览窗口使用整个屏幕,没有边框或标题栏。缩放图像以适应整个屏幕。不接受值
rpicam-hello -f
  • --qt-preview 使用Qt预览窗口,它比其他选项消耗更多的资源,但支持X窗口转发。与全屏标志不兼容。不接受值。
rpicam-hello --qt-preview
  • --nopreview 使应用程序不显示预览窗口。不接受值
rpicam-hello --nopreview
  • --info-text

默认值: "#%frame (%fps fps) exp %exp ag %ag dg %dg"
在桌面环境中运行时,将提供的字符串设置为预览窗口的标题。支持以下图像元数据替换:

指令说明
%frame帧序列号
%fps瞬时帧速率
%exp捕捉图像时的快门速度, 单位是ms
%ag感光芯片控制的图像模拟增益
%dg通过ISP控制的图像数值增益
%rg每个像素点红色组件的增益
%bg每个像素点蓝色组件的增益
%focus图像的角点度量,数值越大表示图像越清晰
%lp当前镜头的屈光度 (1/米为单位的距离)
%afstate自动对焦状态 (idle, scanning, focused, failed)
rpicam-hello --info-test "Focus measure: %focus" 
  • --width
  • --height

每个都接受一个单独的数字来定义所捕获图像的尺寸(以像素为单位)。
对于rpicam-still、rpicam-jpeg和rpicam-vid,指定输出分辨率。
对于rpicam-raw,指定原始帧分辨率。对于具有2×2 bin读出模式的相机,指定一个等于或小于bin模式的分辨率捕获2×2 bin原始帧。
对于rpicam-hello没有效果。
录制1080p的视频

rpicam-vid -o test.h264 --width 1920 --height 1080

捕获2028×1520分辨率的JPEG。如果与HQ相机一起使用,则使用2×2 bin模式,因此原始文件(test. ng)包含2028×1520原始Bayer图像。

rpicam-still -r -o test.jpg --width 2028 --height 1520
  • --viewfinder-width
  • --viewfinder-height

每个参数都能接受一个数字,以像素为单位定义预览窗口中显示的图像的尺寸。不影响预览窗口的尺寸,因为图像会调整大小以适应。不影响捕获的静止图像或视频。

rpicam-still --viewfinder-width 1920 --viewfinder-height 1080
  • --mode 允许以以下冒号分隔格式指定相机模式:<width>:<height>:<bit-depth>:<packing>,如果提供的值没有精确匹配,系统将为传感器选择最接近的可用选项。可以使用packed(P)或者unpacked(U)的打包格式,影响存储的视频和静止图像的格式,但不影响传递到预览窗口的帧的格式。

Bit-depth和packing是可选的,Bit-depth默认是12,Packing默认为P(已打包)。
有关传感器可用的位深度、分辨率和packing选项的信息,请参见list-cameras。
如下所示:

    • 4056:3040:12:P - 4056×3040 resolution, 12 bits/pixel, packed.
    • 1632:1224:10 - 1632×1224 resolution, 10 bits/pixel.
    • 2592:1944:10:U - 2592×1944 resolution, 10 bits/pixel, unpacked.
    • 3264:2448 - 3264×2448 resolution.
  • --viewfinder-mode 与mode选项相同,但它适用于传递给预览窗口的数据。有关更多信息,请参阅mode文档。
  • --lores-width 和 --lores-height

提供来自相机的第二个低分辨率图像流,按比例缩小到指定的尺寸。每个都接受一个数字来定义低分辨率流的维度(以像素为单位)。可用于预览和视频模式。不提供静态捕获。对于rpicam-vid,禁用额外的颜色去噪处理。对结合图像后处理的图像分析有用。

rpicam-hello --lores-width 224 --lores-height 224
  • --hflip 水平翻转图像。不接受值。
rpicam-hello --hflip -t 0
  • --vflip 垂直翻转图像。不接受值。
 rpicam-hello --vflip -t 0
  • --rotation 旋转从传感器提取的图像。只接受值0或180。
rpicam-hello  --rotation 0
  • --roi 对从传感器全域提取的图像进行裁剪。接受四个十进制值,范围从0到1,格式如下:<x>,<y>,<w>,<h>。这些值中的每一个都以0到1之间的小数表示可用宽度和高度的百分比。

这些值定义了以下比例:
<x>:在提取图像之前要跳过的x坐标
<y>:在提取图像之前要跳过的y坐标
<w>:要提取的图像宽度
<h>:要提取的图像高度
默认为0,0,1,1(从第一个X坐标和第一个Y坐标开始,使用100%的图像宽度,使用100%的图像高度)。
例子:
rpicam-hello --roi 0.25,0.25,0.5,0.5选择从图像中心裁剪的像素总数的一半(跳过前25%的X坐标,跳过前25%的Y坐标,使用图像总宽度的50%,使用图像总高度的50%)。
rpicam-hello --roi 0,0,0.25,0.25选择从图像左上角裁剪的像素总数的四分之一(跳过X坐标的前0%,跳过Y坐标的前0%,使用图像宽度的25%,使用图像高度的25%)。

  • --hdr 默认值:关闭,在HDR模式下运行相机。如果没有传递值,则假定为auto。接受下列值之一:
    • off -禁用HDR。
    • auto -在支持的设备上启用HDR。如果可用,使用传感器的内置HDR模式。如果传感器没有内置HDR模式,则使用板载HDR模式(如果可用)。
    • single-exp 在支持的设备上启用HDR。如果可用,使用传感器的内置HDR模式。如果传感器没有内置HDR模式,则使用板载HDR模式(如果可用)。
rpicam-hello --hdr

使用板载HDR模式,如果可用,即使传感器有一个内置的HDR模式。如果板载HDR模式不可用,则禁用HDR。
Raspberry Pi 5及更高版本的设备具有板载HDR模式。
要检查传感器中内置的HDR模式,将此选项添加到列表相机中。

camera控制选项

以下选项控制影响相机图像质量的图像处理和算法。

  • sharpness

设置图像清晰度。接受以下范围内的数值:

    • 0.0是不应用锐化
    • 大于0.0但小于1.0的值应用的锐化量小于默认值
    • 1.0应用默认锐化量
    • 大于1.0的值应用额外的锐化
rpicam-hello --sharpness 0.0
  • contrast

指定图像对比度。接受以下范围内的数值:

    • 0.0适用最小对比度
    • 大于0.0但小于1.0的值应用的对比度小于默认值
    • 1.0应用默认的对比度
    • 大于1.0的值应用额外的对比度
rpicam-hello --contrast 0.0
  • brightness

指定图像亮度,作为输出图像中所有像素的偏移量添加。接受以下范围内的数值:

    • -1.0最小亮度(黑色)
    • 0.0应用标准亮度
    • 1.0应用最大亮度(白色)

对于更多的用法,推荐ev

rpicam-hello --brightness 1.0
  • saturation

指定图像颜色饱和度。接受以下范围内的数值:

    • 0.0应用最小饱和度(灰度)
    • 大于0.0但小于1.0的值应用的饱和度小于默认值
    • 1.0应用默认的饱和度
    • 大于1.0的值应用额外的饱和度
rpicam-hello --saturation  0.6
  • ev

指定图像的曝光值(EV)补偿。接受一个数值,该数值控制沿着以下频谱传递给自动曝光/增益控制(AEC/AGC)处理算法的目标值:

    • -10.0应用最小目标值
    • 0.0应用标准目标值
    • 10.0应用最大目标值
rpicam-hello --ev  10.0
  • shutter

指定使用快门的曝光时间,以微秒为单位。当您使用此选项时,增益仍然可以变化。如果相机运行的帧率太快,它不允许指定的曝光时间(例如,帧率为1fps,曝光时间为10000微秒),传感器将使用帧率允许的最大曝光时间。
有关官方相机的最小和最大快门时间列表,请参阅相机硬件文档。高于最大值的值会导致未定义的行为。

rpicam-hello --shutter 10000
  • gain

analoggain与gain的效果是一样的
设置组合模拟和数字增益。当传感器驱动可以提供所要求的增益时,只使用模拟增益。当模拟增益达到最大值时,ISP应用数字增益。接受数值。
有关官方摄像机的模拟增益限制列表,请参阅摄像机硬件文档
有时,即使在不超过模拟增益限制的情况下,数字增益也会超过1.0。这可能发生在以下情况:
其中任何一个颜色增益低于1.0,这将导致数字增益稳定在1.0/min(红增益,蓝增益)。这使总数字增益应用于任何高于1.0的颜色通道,以避免变色伪影。
自动曝光/增益控制(AEC/AGC)变化时的轻微差异。

rpicam-hello --gain 0.8
  • metering 默认值:centre

设置自动曝光/增益控制(AEC/AGC)算法的测光模式。接受以下值:

    • centre 中心加权计量
    • spot 点测光
    • average 平均或全帧测光
    • custom 自定义测光模式定义在相机调整文件

有关定义自定义测光模式和在现有测光模式中调整区域权重的更多信息,请参阅Raspberry Pi相机和libcamera的调谐指南

rpicam-hello --metering centre
  • exposure

设置曝光配置文件。更改曝光配置文件不应影响图像曝光。相反,不同的模式调整增益设置,以达到相同的净结果。接受以下值:

    • sport:曝光时间短,收益大
    • normal:正常暴露,正常增益
    • long:曝光时间长,收益小

您可以使用调谐文件编辑曝光配置文件。有关更多信息,请参阅Raspberry Pi相机和libcamera的调谐指南

rpicam-hello --exposure sport
  • awb

设置曝光配置文件。更改曝光配置文件不应影响图像曝光。相反,不同的模式调整增益设置,以达到相同的最终结果。接受以下值: 可用的白平衡模式:

模式色温
auto2500K ~ 8000K
incadescent2500K ~ 3000K
tungsten3000K ~3500K
fluorescent4000K ~ 4700K
indoor3000K ~ 5000K
daylight5500K ~ 6500 K
cloudy7000K ~ 8500K
custom自定义范围, 通过调谐文件设置

这些值只是近似值:值可能会根据相机调整而变化。
没有模式完全禁用AWB。相反,你可以用awbgains来修正颜色增益。
有关AWB模式的更多信息,包括如何定义自定义模式,请参阅Raspberry Pi相机和libcamera的调谐指南

rpicam-hello --awb auto
  • awbgains

设置一个固定的红蓝增益值来代替自动白平衡(AWB)算法。设置非零值禁用AWB。接受以逗号分隔的数字输入,格式如下:<red_gain>,<blue_gain>

rpicam-jpeg -o test.jpg --awbgains 1.5,2.0
  • denoise

默认值:auto
设置去噪模式。接受以下值:

    • auto:启用标准空间降噪。对视频使用超快的彩色去噪,对图像使用高质量的彩色去噪。在预览窗口中不启用额外的颜色噪点。
    • off:关闭空间和颜色去噪。
    • cdn_off:禁用颜色噪点。
    • cdn_fast:使用快速颜色去噪。
    • cdn_hq:使用高质量的颜色去噪。由于吞吐量降低,不适合视频/取景器。

即使是快速的色彩降噪也会降低帧率。高质量的色彩降噪显著降低了帧率。

rpicam-hello --denoise off
  • tuning-file

指定摄像机调谐文件。调整文件允许您控制图像处理的许多方面,包括自动曝光/增益控制(AEC/AGC),自动白平衡(AWB),色彩阴影校正,色彩处理,去噪等等。接受调谐文件路径作为输入。 有关调谐文件的详细信息,请参见调谐文件

  • autofocus-mode

默认值:default 指定自动对焦模式。接受以下值:

    • default:将相机置于连续自动对焦模式,除非镜头位置或自动对焦捕捉覆盖到手动模式
    • manual:不移动镜头,除非手动配置镜头位置
    • auto:仅在相机启动时或在捕捉之前移动镜头进行自动对焦扫描,如果也使用了自动对焦捕捉功能
    • continuous:随场景变化自动调整镜头位置

此选项仅支持某些相机模块。

rpicam-hello --autofocus-mode auto
  • autofocus-range

默认值:normal
指定自动对焦范围。接受以下值:

    • normal:聚焦范围相当接近无穷远
    • macro:仅对焦近处的物体,包括相机支持的最近焦距
    • full:聚焦整个范围,从最近的物体到无穷远

此选项仅支持某些相机模块。

rpicam-hello autofocus-range normal
  • autofocus-speed

默认值:normal
指定自动对焦速度。接受以下值:

    • normal:以正常速度改变镜头位置
    • fast:快速改变镜头位置

此选项仅支持某些相机模块。

rpicam-hello --autofocus-speed normal
  • autofocus-window

指定传感器全域内的自动对焦窗口。接受四个十进制值,范围从0到1,格式如下:<x>,<y>,<w>,<h>。这些值中的每一个都以0到1之间的小数表示可用宽度和高度的百分比。
这些值定义了以下比例:
<x>:在应用自动对焦之前要跳过的x坐标
<y>:在应用自动对焦之前要跳过的y坐标
<w>:自动对焦区域宽度
<h>:自动对焦区域高度
默认值在两个维度中使用输出图像的中间三分之一(总图像区域的1/9)。
例子:

rpicam-hello—autofocus-window 0.25,0.25,0.5,0.5

选择从图像中心裁剪的像素总数的一半(跳过前25%的X坐标,跳过前25%的Y坐标,使用图像总宽度的50%,使用图像总高度的50%)。

rpicam-hello—autofocus-window 0,0,0.25,0.25

选择从图像左上角裁剪的像素总数的四分之一(跳过X坐标的前0%,跳过Y坐标的前0%,使用图像宽度的25%,使用图像高度的25%)。
此选项仅支持某些相机模块。

  • lens-position

默认值:default 将镜头移动到一个固定的焦距,通常以屈光度表示(单位为1/米距离)。接受以下值范围:

    • 0.0:将镜头移动到“无限远”位置
    • 任何其他数字:将镜头移动到1 /数字位置。例如,值2.0将聚焦在大约0.5m处
    • normal:将镜头移动到与镜头超焦距位置相对应的默认位置

镜头校准并不完善,因此同一型号的不同相机模块可能会有所不同。

  • verbose

别名:-v
默认值:1 设置详细程度。接受以下值:

    • 0:无输出
    • 1:正常输出
    • 2:详细输出
rpicam-hello --verbose 1

更详细的资料,点击这里参考。

Libcamera

自 Bullseye 版本之后,树莓派的摄像头驱动由原来的 Raspicam 切换为 libcamera。libcamera 是一个开源的软件栈(以下简称为“驱动”),它为用户提供了更强大的功能,同时也便于第三方开发者移植和创建自己的摄像头驱动。

截至 2023 年 12 月 11 日,官方已为 libcamera 提供了picamera2 库,使得用户可以更加方便地通过 Python 程序调用 libcamera 软件栈。


libcamera 提供了六个常用指令,用户可以通过这些指令快速进行摄像头接口的预览和测试。这些指令能够帮助用户调试和验证摄像头是否正常工作。

libcamera-hello

这个是一个简单的“hello world" 程序,用来预览摄像头并将摄像头画面显示在屏幕上。和之前一样,用户可以用以下指令拍摄一张图片。

使用示例
libcamera-hello

这个指令会在屏幕上预览摄像头大概5秒时间,用户可以用-t <duration>参数来设置预览的时间, 其中<duration>的单位是毫秒,如果设置为0的话就是保持一直预览。比如:

libcamera-hello -t 0
调谐文件

树莓派的libcamera驱动会针对不同的摄像头模块调用一个调谐文件,调谐文件中提供了各种参数,调用摄像头的时候,libcamera会调用调谐文件中的参数,结合算法对图像进行处理最终输出成预览画面。由于libcamera驱动只能自动感光芯片信号,但是摄像头的最终显示效果还会受整个模块的影响,调谐文件的使用就是为了可以灵活处理不同模块的摄像头,调整提高图像质量。
如果在使用默认调谐文件的情况下,摄像头的输出图像不理想的话,用户可以通过调用自定义的调谐文件来对图像进行调整。比如,如果你使用的是官方的NOIR版本摄像头,相对于于Raspberry Pi Camera V2 常规款,NOIR摄像头可能需要不同的白平衡参数,这种情况下就可以通过调用调谐文件来进行切换。

libcamera-hello --tuning-file /usr/share/libcamera/ipa/raspberrypi/imx219_noir.json

用户可以复制默认的调谐文件,根据自己的需求进行修改。
备注:调谐文件的使用适用于其他的libcamera指令,后续指令中就不再做介绍

预览窗口

大部分的libcamera指令都会显示一个预览窗口在屏幕上,用户可以通过--info-text 参数来自定义预览窗口的标题信息, 同时也可以通过%directives 调用一些摄像头参数并显示在窗口上
比如如果使用HQ Camera: 可以通过--info-txe "%focus" 在窗口上显示摄像头的焦距

libcamera-hello --info-text "focus %focus"

备注:更多关于参数的设置,可以参考后续的指令参数设置章节

libcamera-jpeg

libcamera-jpeg 是一个简单的静态图片拍摄程序,不同于libcamera-still的复杂功能,libcamera-jpeg代码更简洁,并且有很多相同的功能来完成图片拍摄。

拍摄一张全像素的JPEG图像
libcamera-jpeg -o test.jpg

这个拍摄指令会显示一个5秒左右的预览串口,然后拍摄一张全像素的JPEG图像,保存为test.jpg
用户可以通过-t 参数来设置预览时间,同时可以通过--width 和 --height来设置拍摄图像的分辨率。例如:

libcamera-jpeg -o test.jpg -t 2000 --width 640 --height 480
曝光控制

所有的 libcamera 指令都允许用户自行设置快门时间和增益,例如:

libcamera-jpeg -o test.jpg -t 2000 --shutter 20000 --gain 1.5

这条指令会拍摄一张图像,其中曝光时间为 20 毫秒,摄像头增益设置为 1.5 倍。设置的增益参数会优先调整感光芯片内部的模拟增益。如果设定的增益超过了驱动程序内置的最大模拟增益值,系统会先将芯片的模拟增益设置到最大值,剩余的增益倍数则通过数字增益实现。
备注:数字增益是通过 ISP(图像信号处理器)实现的,而不是直接调整芯片内置寄存器。在正常情况下,数字增益通常接近 1.0,除非出现以下三种情况:

  1. 增益需求超过模拟增益范围:当模拟增益无法满足设定的增益需求时,数字增益会用来进行补偿。
  2. 某一颜色通道增益小于 1:数字增益还可以用于调整颜色增益。当某一颜色通道(如红色或蓝色)的增益值小于 1 时,系统会应用统一的数字增益,其最终值为 1 / min(red_gain, blue_gain)。
  3. 自动曝光/增益控制(AEC/AGC)调整:当 AEC 或 AGC 发生变化时,数字增益可能会随之调整,以消除因参数波动引起的亮度变化。这种变化通常会迅速恢复到“正常值”。

树莓派的 AEC/AGC 算法允许程序设置曝光补偿(EV 值),通过调整光圈参数来控制图像的亮度。
例如:

libcamera-jpeg --ev -0.5 -o darker.jpg
libcamera-jpeg --ev 0 -o normal.jpg
libcamera-jpeg --ev 0.5 -o brighter.jpg

libcamera-still

libcamera-still 和 libcamera-jpeg 的功能非常相似,但 libcamera-still 继承了更多原先 raspistill 提供的功能。例如,用户仍然可以使用类似以下的指令来拍摄一张图片:

测试指令
libcamera-still -o test.jpg
编码器

libcamea-still支持不同格式的图像文件,可以支持png和bmp编码,也支持直接不带编码或者任何图像格式地将RGB或者YUV像素的二进制转储保存成文件。如果是直接保存RGB或者YUV数据,程序在读取此类文件的时候必须了解文件的像素排列方式。

libcamera-still -e png -o test.png
libcamera-still -e bmp -o test.bmp
libcamera-still -e rgb -o test.data
libcamera-still -e yuv420 -o test.data

备注:图像保存的格式是通过-e参数控制的, 如果没有调用-e参数设置的话,默认按照输出的文件名的格式保存。

原始图像拍摄

原始图像(Raw image)图像就是直接图像传感器输出的图像, 没有经过任何ISP或者CPU处理。对于彩色相机传感器,一般来说原始图像的输出格式是Bayer. 注意原始图和我们之前说的位编码的RGB和YUV图像不同,RGB和YUV也是经过ISP处理后的图像的。
拍摄一张原始图像的指令:

libcamera-still -r -o test.jpg

原始图像一般是以DNG (Adobe digital Negative) 格式保存的,DNG格式可以兼容大部分标准程序, 比如dcraw 或者RawTherapee. 原始图像会被保存为.dng后缀的相同名字的文件,比如如果运行上面的指令,为被另存为test.dng, 并同时生成一张jpeg文件。DNG文件中包含了已图像获取有关的元数据, 比如白平衡数据,ISP颜色矩阵等, 下面是用exiftool工具显示的元数据编码信息:

File Name                       : test.dng
Directory                       : .
File Size                       : 24 MB
File Modification Date/Time     : 2021:08:17 16:36:18+01:00
File Access Date/Time           : 2021:08:17 16:36:18+01:00
File Inode Change Date/Time     : 2021:08:17 16:36:18+01:00
File Permissions                : rw-r--r--
File Type                       : DNG
File Type Extension             : dng
MIME Type                       : image/x-adobe-dng
Exif Byte Order                 : Little-endian (Intel, II)
Make                            : Raspberry Pi
Camera Model Name               : /base/soc/i2c0mux/i2c@1/imx477@1a
Orientation                     : Horizontal (normal)
Software                        : libcamera-still
Subfile Type                    : Full-resolution Image
Image Width                     : 4056
Image Height                    : 3040
Bits Per Sample                 : 16
Compression                     : Uncompressed
Photometric Interpretation      : Color Filter Array
Samples Per Pixel               : 1
Planar Configuration            : Chunky
CFA Repeat Pattern Dim          : 2 2
CFA Pattern 2                   : 2 1 1 0
Black Level Repeat Dim          : 2 2
Black Level                     : 256 256 256 256
White Level                     : 4095
DNG Version                     : 1.1.0.0
DNG Backward Version            : 1.0.0.0
Unique Camera Model             : /base/soc/i2c0mux/i2c@1/imx477@1a
Color Matrix 1                  : 0.8545269369 -0.2382823821 -0.09044229197 -0.1890484985 1.063961506 0.1062747385 -0.01334283455 0.1440163847 0.2593136724
As Shot Neutral                 : 0.4754476844 1 0.413686484
Calibration Illuminant 1        : D65
Strip Offsets                   : 0
Strip Byte Counts               : 0
Exposure Time                   : 1/20
ISO                             : 400
CFA Pattern                     : [Blue,Green][Green,Red]
Image Size                      : 4056x3040
Megapixels                      : 12.3
Shutter Speed                   : 1/20
超长曝光

如果要拍摄一张超长曝光的图片,我们需要禁用AEC/AGC和白平衡,否则这些算法会导致图片在收敛的时候多等待很多帧数据。禁用这些算法需要另设置显式值,另外, 用户可以通过--immediate设置来跳过预览过程。
这里是拍摄一张曝光100秒的图像指令:

libcamera-still -o long_exposure.jpg --shutter 100000000 --gain 1 --awbgains 1,1 --immediate

备注:几款官方摄像头的最长曝光时间参考表格.

模块最长曝光时间(s)
V1(OV5647)6
V2(IMX219)11.76
V3(IMX708)112
HQ(IMX477)670

libcamera-vid

libcamera-vid是一个视频录制程序, 默认使用的是树莓派的硬件H.264编码器。这个程序运行之后会在屏幕上显示一个预览窗口,同时将比特流编码输出到指定文件。比如,录制一个10s的视频。

libcamera-vid -t 10000 -o test.h264

如果要查看视频可以用vlc来进行播放

vlc test.h264

备注:录制的是未打包的视频流, 用户可以使用--save-pts 设置输出时间戳,方便后续将比特流转成其他视频格式。

libcamera-vid -o test.h264 --save-pts timestamps.txt

如果想要输出mkv文件,可以用以下指令:

mkvmerge -o test.mkv --timecodes 0:timestamps.txt test.h264
编码器

树莓派支持JPEG格式以及没有压缩和格式的YUV420:

libcamera-vid -t 10000 --codec mjpeg -o test.mjpeg
libcamera-vid -t 10000 --codec yuv420 -o test.data

--codec选项设置的是输出格式,而不是输出文件的扩展名。
使用--segment参数可以将输出文件分割成段(单位是ms),适用于需要脚JPEG视频流分割成单独的时间比较短(大概1ms)的JPEG文件

libcamera-vid -t 10000 --codec mjpeg --segment 1 -o test%05d.jpeg
UDP 视频流传输

可以使用UDP进行视频流传输,树莓派端运行(server):

libcamera-vid -t 0 --inline -o udp://<ip-addr>:<port>

其中<ip-addr>需要替换成实际的客户端IP地址或者组播地址。
在客户端(client),输入以下指令进行视频流获取和显示(两个指令使用一种即可);

vlc udp://@:<port> :demux=h264
vlc udp://@:<port> :demux=h264

注意:port需要跟你在树莓派端设置的一致

TCP视频流传输

可以使用TCp进行视频流传输, 树莓派端运行(server):

libcamera-vid -t 0 --inline --listen -o tcp://0.0.0.0:<port>

客户端(client)运行:

vlc tcp/h264://<ip-addr-of-server>:<port> #两条指令选一条即可
ffplay tcp://<ip-addr-of-server>:<port> -vf "setpts=N/30" -fflags nobuffer -flags low_delay -framedrop
RTSP视频流传输

在树莓派上,通常使用vlc来对RTSP视频流做处理,

libcamera-vid -t 0 --inline -o - | cvlc stream:///dev/stdin --sout '#rtp{sdp=rtsp://:8554/stream1}' :demux=h264

播放端,可以运行以下任一条指令:

vlc rtsp://<ip-addr-of-server>:8554/stream1
ffplay rtsp://<ip-addr-of-server>:8554/stream1 -vf "setpts=N/30" -fflags nobuffer -flags low_delay -framedrop

在所有预览指令中,如果想要关掉树莓派端的预览窗口,可以用参数-n(--nopreview)设置。另外注意--inline参数的设置,改设置会强制将视频流的报头信息包含在每个 I (intra)帧中,这个设置可以让客户端在丢失视频头的情况下仍然可以正确解析视频流。

高帧率模式

如果使用 libcamera-vid 指令录制高帧率视频(通常帧率超过 60fps),为了减少丢帧情况,需要注意以下几点:

  1. 设置 H.264 的目标级别: 需要将 H.264 的编码级别设置为 4.2,可通过添加 --level 4.2 参数实现。
  2. 关闭彩色降噪功能:录制高帧率视频时必须关闭彩色降噪功能,以减少额外的性能消耗。可以使用参数 --denoise cdn_off 来关闭。
  3. 关闭预览窗口(适用于帧率高于 100fps 的情况):如果帧率设置超过 100fps,建议关闭预览窗口以释放更多 CPU 资源,避免丢帧。可通过参数 -n 实现。
  4. 启用强制 Turbo 模式:在 /boot/config.txt 文件中添加 force_turbo=1 设置,确保视频录制过程中 CPU 时钟频率不会被限制,从而提高性能。
  5. 调整 ISP 输出分辨率:降低分辨率可以减少资源占用,例如使用参数 --width 1280 --height 720 设置分辨率为 1280x720,或者根据摄像头型号调整为更低的分辨率。
  6. 对 GPU 进行超频(适用于 Raspberry Pi 4 或更高型号):可以通过在 /boot/config.txt 文件中添加 gpu_freq=550(或更高值)来对 GPU 进行超频,以提高性能满足高帧率需求。

示例:
以下指令用于录制分辨率为 1280x720、帧率为 120fps 的视频:

libcamera-vid --level 4.2 --framerate 120 --width 1280 --height 720 --save-pts timestamp.pts -o video.264 -t 10000 --denoise cdn_off -n

libcamera-raw

libcamera-raw类似于视频录制程序,不同的地方是,libcamera-raw录制的是直接传感器输出的Bayer格式的数据,也就是原始图像数据。libcamera-raw不会显示预览窗口。比如录制一个2秒的原始数据片段.

libcamera-raw -t 2000 -o test.raw

程序会在没有格式信息的情况下直接转储原始帧, 程序会将像素格式和图像尺寸直接打印在终端,用户可以根据输出的数据查看像素数据.
默认情况下,程序会将原始帧保存成一个文件,文件通常比较大,用户可以通过--segement参数将文件进行分割。

libcamera-raw -t 2000 --segment 1 -o test%05d.raw

如果内存条件比较好(比如使用SSD), libcamera-raw可以以大概10帧每秒的速度将官方的HQ Camera的数据(大概18MB每帧)写入到硬盘中, 为了达到这个速度,程序写入的是没有格式化过的原始帧,没有办法像libcamera-still那样保存成DNG文件。 如果想要确保不出现丢帧的情况,可以使用--framerate 降低帧率。

libcamera-raw -t 5000 --width 4056 --height 3040 -o test.raw --framerate 8

通用的指令设置选项

通用的指令设置选项适用于libcamera的所有指令

--help, 	-h

打印程序帮助信息,可以打印每个程序指令的可用设置选项,然后退出.

--version

打印软件版本,打印libcamera和libcamera-app的软件版本,然后退出.

--list-cameras

显示识别到的可支持的摄像头。 比如:

Available cameras
-----------------
0 : imx219 [3280x2464] (/base/soc/i2c0mux/i2c@1/imx219@10)
    Modes: 'SRGGB10_CSI2P' : 640x480 [206.65 fps - (1000, 752)/1280x960 crop]
                             1640x1232 [41.85 fps - (0, 0)/3280x2464 crop]
                             1920x1080 [47.57 fps - (680, 692)/1920x1080 crop]
                             3280x2464 [21.19 fps - (0, 0)/3280x2464 crop]
           'SRGGB8' : 640x480 [206.65 fps - (1000, 752)/1280x960 crop]
                      1640x1232 [41.85 fps - (0, 0)/3280x2464 crop]
                      1920x1080 [47.57 fps - (680, 692)/1920x1080 crop]
                      3280x2464 [21.19 fps - (0, 0)/3280x2464 crop]
1 : imx477 [4056x3040] (/base/soc/i2c0mux/i2c@1/imx477@1a)
    Modes: 'SRGGB10_CSI2P' : 1332x990 [120.05 fps - (696, 528)/2664x1980 crop]
           'SRGGB12_CSI2P' : 2028x1080 [50.03 fps - (0, 440)/4056x2160 crop]
                             2028x1520 [40.01 fps - (0, 0)/4056x3040 crop]
                             4056x3040 [10.00 fps - (0, 0)/4056x3040 crop]

按照打印的信息, IMX219摄像头后缀0, IM新477摄像头后缀1. 在调用摄像头的时候,就可以对应的后缀进行指定

--camera

指定摄像头,对应的后缀可以参考指令--list-camera的打印信息。
比如: libcamera-hello -c config.txt
其中的设置文件中,一行一个设置参数,用key=value的格式:

timeout=99000
verbose=
--config,	-c

一般情况下,我们可以通过指令直接设置摄像头参数,这里使用--config参数,可以指定设置文件,直接读取文件中的设置参数来对摄像头预览效果进行设置

--timeout, 	-t

-t选项 设置了libcamera程序运行时间, 如果运行的是视频录制指令,timeout选项设置的是录制时长,如果运行的是图像拍摄指令,timeout设置的拍摄并输出图像之前的预览时间。
如果在运行libcamera程序的时候没有设置timeout,默认的timeout数值就是5000(5秒), 如果将timeout设置为0,那程序就会一直运行。
示例: libcamera-hello -t 0

--preview,  -p

-p 设置预览预览窗口大小以及窗口的位置(则合格设置在 X和DRM版本的窗口中都有效), 设置格式为 --preview <x. y, w, h> 其中x y设置预览窗口在显示屏上的坐标位置, w和h设置的是预览窗口的宽度和长度
预览串口的设置不会影响摄像头图像预览的分辨率和宽高比。 程序会将预览图像缩放到预览窗口中显示,并会按照原来的图像宽高比做适配。
示例: libcamera-hello -p 100,100,500,500

--fullscreen, -f

-f选项设置预览窗口全屏显示,全屏显示模式的预览窗口和边框。同-p一样,不会影响分辨率和宽高比,会自动适配。
示例: libcamera-still -f -o test.jpg

--qt-preview

使用基于QT框架的预览窗口, 正常情况下不推荐用这个设置,因为这个预览程序不会使用零拷贝缓冲区共享以及GPU加速, 这个会导致占用资源过高。 QT预览窗口支持X转发(默认预览程序不支持).
Qt预览串口不支持--fullscreen设置选项, 如果用户要使用Qt预览,建议保持小预览窗口,避免资源占用过高影响系统正常运行。
示例: libcamera-hello --qt-preview

--nopreview, -n

不预览图像。这个设置会关掉图像预览功能.
示例:libcamera-hello -n

--info-text

设置预览窗口的标题和信息显示(只在X图形窗口下有效)使用格式为 --info-text <string>。调用改选项,有多个参数可以设置,参数通常以%指令格式调用。 程序会按照指令调用图形元数据中的对应数值。
如果没有指定窗口信息,默认的--info-text设置为 "#%frame (%fps fps) exp %exp ag %ag dg %dg"
示例: libcamera-hello --info-test "Focus measure: %focus 可用参数:

指令说明
%frame帧序列号
%fps瞬时帧速率
%exp捕捉图像时的快门速度, 单位是ms
%ag感光芯片控制的图像模拟增益
%dg通过ISP控制的图像数值增益
%rg每个像素点红色组件的增益
%bg每个像素点蓝色组件的增益
%focus图像的角点度量,数值越大表示图像越清晰
%lp当前镜头的屈光度 (1/米为单位的距离)
%afstate自动对焦状态 (idle, scanning, focused, failed)
--width
--height

这两个参数分别设置图像的宽度和高度。对于libcamera-still, libcamera-jpeg和libcamera-vid指令,这两个参数可以设置输出图像/视频的分辨率。
如果使用libcamera-raw指令,这两个参数会影响获取的元数据帧的大小。 摄像头有一个2x2的分块读取模式,如果设置的分辨率小于分开模式, 摄像头会按照2x2的分块大小获取元数据帧。
libcamera-hello无法指定分辨率.< br /> 示例:
libcamera-vid -o test.h264 --width 1920 --height 1080 录制1080p视频
libcamera-still -r -o test.jpg --width 2028 --height 1520 拍摄一张分辨率为2028x1520的JPEG图像。

--viewfinder-width
--viewfinder-height

这个设置选项也是用来设置图像的分辨率,不同的是只设置的预览的图像大小。并不会影响最终输出的图像或者视频的分辨率。 预览图像大小的设备不会影响预览窗口尺寸,会根据窗口适配。
示例: libcamera-hello --viewfinder-width 640 --viewfinder-height 480

--rawfull

这个设置强制感光芯片激活了--width和--height的设置, 在全分辨率读取模式下输出静态图像和视频。这个设置libcamera-hello无效。
使用该设置,会牺牲帧率。全分辨率模式下,帧读取速度会比较慢。
示例: libcamera-raw -t 2000 --segment 1 --rawfull -o test%03d.raw 示例指令会捕获多张全分辨率模式下的元数据帧。 如果你使用的是HQ摄像头。 每个帧的大小为18MB, 而如果没有设置--rawfull, HQ摄像头默认的是2x2模式, 每帧的数据大小只有4.5MB.

--mode

这个参数比rawfull更通用,用于设置摄像头模式,使用的时候,需要指定宽度,高度,位深度和打包模式,并用冒号分割。设置的数值不一定要完全精确,系统会自动匹配最接近的数值,另外位深度和打包模式是可设置的(默认为12 和 P 表示打包)

  • 4056:3040:12:P - 4056x3040分辨率,12bit每像素, 打包。打包意味着原始图像数据会在缓冲区被打包,这种情况下,两个像素点仅会占用3个字节,可以节省内存
  • 1632:1224:10 - 1632x1224分辨率,10bit每像素, 默认打包。10-bit 打包的模式下,4个像素点数据会占用5 bytes.
  • 2592:1944:10:U -2592x1944分辨率,10bits每像素,不打包。不打包的情况下,每个限速会占用2bytes内存,这种情况下,最高的6 bits会被设置为0
  • 3262:2448 -3264x2448分辨率, 默认使用12bits和打包模式。 但是,如果摄像头型号,比如Camera V2 (IMX219)不支持12bits模式,系统会自动选择为10bits模式
--viewfinder-mode       #Specify sensor mode, given as <width>:<height>:<bit-depth>:<packing>

--mode参数是用来在录制视频和拍摄静态图像的时候设置摄像头模式,如果想要在预览的时候设置,可以用--viewfinder-mode参数

--lores-width
--lores-height	

这个两个选项设置低分辨率图像。 低分辨率数据流会压缩图像,导致图像的纵横比改变。在使用libcamera-vid录制视频的时候,如果设置了低分辨率,会禁用掉颜色去噪处理等功能。
示例: libcamera-hello --lores-width 224 --lores-height 224 注意,低分辨率设置通常要结合图像后处理使用,否则效用不大。

--hflip   #水平翻转图像
--vflip    #垂直翻转图像
--rotation     #根据给出的角度,水平或者垂直翻转图像 <angle>

这三个选项用来翻转图像。 --rotation的参数目前只支持0 和180, 其实就是相当于--hflip和--vflip.
示例: libcamera-hello --vflip --hflip

--roi   #裁剪图像<x, y, w, h>

--roi允许用户从传感器提供的完整图像中根据坐标裁剪自己想要的图像区域,也就是数字缩放,注意坐标值要是在有效范围的。 比如 --roi 0, 0, 1, 1就是无效的指令。
示例:libcamera-hello --roi 0.25,0.25,0.5,0.5 示例指令会从图像中心裁剪1/4图像出来。

--hdr				Run the camera in HDR mode (supported cameras only)

hdr参数用来设置摄像头的宽动态模式。这个设置只有在摄像头支持宽动态的情况下才能生效。你可以使用--list-camera来查看摄像头是否支持hdr模式

--sharpness #设置图像的锐度 <number>

通过<number>数值调整图像的锐度。 如果设置为0,就是不应用锐化。 如果设置的值超过1.0,会使用而外的锐化量。
示例: libcamera-still -o test.jpg --sharpness 2.0

--contrast  #设置图像对比度 <number>

示例: libcamera-still -o test.jpg --contrast 1.5

--brightness  #设置图像亮度<number>

设置范围是-1.0 ~ 1.0
示例: libcamera-still -o test.jpg --brightness 0.2

--saturation  #设置图像色彩饱和度 <number>

示例:libcamera-still -o test.jpg --saturation 0.8

--ev  #设置EV补偿<number>

以光圈为单位来设置图像的EV补偿,设置范围是-10 ~ 10, 默认值是0. 该程序运行使用了 AEC/AGC 算法。
示例:libcamera-still -o test.jpg --ev 0.3

--shutter  #设置曝光时间 ,单位是ms <number>

注意:如果相机的帧率太快,可能会导致无法按照设定的快门时间工作,如果遇到这种情况,可以尝试用--framerate来降低帧速率。
示例:libcamera-hello --shutter 30000

--gain  #设置增益值 (数值增益和模拟增益组合) <number>
--analoggain  #--gain的代名词

--analoggain和--gain是一样的,使用analoggain只是为了兼容raspicam的程序。

--metering  #设置测光模式 <string>

设置AEC/AGC算法的测光模式, 可用的参数有:

  • centre - 中心测光 (默认)
  • spot -点测光
  • averag -平均或者全幅测光
  • custom -自定义测光模式, 可以通过调谐文件设置

示例:libcamera-still -o test.jpg --metering spot

--exposure   #设置曝光配置文件 <string>

曝光模式可以设置为normal或者sport. 这两种模式的报告配置文件不会影响图像的整体曝光,但是如果是sport模式的话,程序会缩短曝光时间和提高增益来达到同样的曝光效果。

  • sport:曝光时间短,增益大
  • normal:正常曝光,正常增益
  • long:曝光时间长,增益小

示例:libcamera-still -o test.jpg --exposure sport

--awb  #设置白平衡模式<string>

可用的白平衡模式:

模式色温
auto2500K ~ 8000K
incadescent2500K ~ 3000K
tungsten3000K ~3500K
fluorescent4000K ~ 4700K
indoor3000K ~ 5000K
daylight5500K ~ 6500 K
cloudy7000K ~ 8500K
custom自定义范围, 通过调谐文件设置

示例: libamera-still -o test.jpg --awb tungsten

--awbgains   #设置固定的颜色增益<number,number>

设置红色和蓝色增益。
示例: libcamera-still -o test.jpg --awbgains 1.5, 2.0

--denoise  #设置去噪模式 <string>

支持的去噪模式:

  • auto -默认模式, 使用标准空间去噪, 如果是视频,会使用快速色彩降噪,拍摄静态图片的时候会使用高质量的色彩降噪。预览图像不会使用任何色彩去噪
  • off - 关闭空间去噪和色彩去噪
  • cdn_off -关闭色彩去噪
  • cdn_fast - 使用快速色彩去噪
  • cdn_hq - 使用高质量色彩去噪,不适用于视频录制。

示例: libcamera-vid -o test.h264 --denoise cdn_off

--tuning-file #指定摄像头调谐文件 <string>

关于更多调谐文件的说明, 可以参考官方教程
示例: libcamera-hello --tuning-file ~/my~camera-tuning.json

--autofocus-mode			Specify the autofocus mode <string>

设置自动对焦模式。

  • default -默认情况下,摄像头会开始连续自动对焦模式,除非设置了--lens-position 或者 --autofocus-on-capture 手动对焦的方式
  • manual -手动对焦模式,可以通过--lens-position来设置对焦位置
  • auto -只有在开启摄像头的时候会做一次对焦,其他情况下不调整对焦。(如果使用的是libcamera-still指令,只有使用--autofocus-on-capture情况下,会在拍照前做一次对焦)
  • continuous -摄像头会根据场景变化,自动调整对焦位置
--autofocus-range   Specify the autofocus range <string>

设置自动对焦范围

  • normal --默认项, 从最近到无穷远
  • macro -微距模式,只对近处的物体对焦。
  • full -全距离模式,对最近物体调整到无穷远
--autofocus-speed   Specify the autofocus speed <string>

设置对焦速度。

  • normal -默认项,正常速度
  • fast -快速对焦模式
--autofocus-window   --autofocus-window

显示对焦窗口,需要设置x,y,width, height, 其中的坐标值设置是根据图像的比例来的。比如--autofocus-window 0.25,0.25,0.5,0.5 会设置一个窗口,这个窗口大小是图像的一半,并且在居中位置。

--lens-position	    Set the lens to a given position <string>

设置对焦位置。

  • 0.0 --设置对焦位置为无穷远
  • number --设置对焦位置为 1/number number是你设置的任意数值, 比如,如果设置2, 表示会对焦到0.5m的位置
  • default -- 对焦到镜头超焦距相对于的默认位置
--output, -o  #输出文件名 <string>

设置输出图像或者视频的文件名。 除了设置文件名之外,还可以指定输出的udp或者tcp服务器地址,从而将图像输出到服务器上。 有兴趣的可以查看后续tcp和udp的相关设置说明。
示例: libcamera-vid -t 100000 -o test.h264

--wrap  #将输出文件计数器打包<number>

示例: libcamera-vid -t 0 --codec mjpeg --segment 1 --wrap 100 -o image%d.jpg

--flush  #马上刷新输出文件

--flush会将每一帧图像写入的同时都马上更新到硬盘中,降低延迟。
示例:libcamera-vid -t 10000 --flush -o test.h264

静态图片拍摄设置参数

--qiality, -q  #设置JPEG图像质量 <0 ~ 100>
--exif, -x #添加而外的EXIF标志
--timelapse  #延时拍照的时间间隔, 单位是ms
--framestart #帧计数的开始数值
--datetime  #用日期格式命名输出文件
--timestamp #用系统时间戳命名输出文件
-- restart  #设置JPEG重启时间间隔
--keypress, -k  # 设置回车按键拍照模式
--signal, -s  #设置信号触发拍照
--thumb #设置缩略图参数 <w:h:q>
--ebcoding, -e  #设置图像编码类型。 jpg / png / bmp / rgb / yuv420
--raw, -r  #保存原始图像
--latest #关联符号到最新保存的文件
--autofocus-on-capture  #设置在拍照前做一次对焦动作

视频录制图像设置参数

--quality, -q  # 设置JPEG指令 <0 - 100>
--bitrate, -b  # 设置H.264比特率
--intra, -g #设置内部帧周期 (只支持H.264)
--profile #设置H.264配置
--level  #设置H.264等级
--codec  #设置编码类型 h264 / mjpeg / yuv420
--keypress, -k  #设置回车暂停和录制
--signal, -s #设置信号暂停和录制
--initial #在录制或者暂停状态下启动程序
--split #切割视频并保存到另外的文件
--segment #将视频分割成多个视频段
--circular  #将视频写入循环缓冲区中
--inline #在每个I帧中写入数据头(只支持H.264)
--listen #等待TCP连接
--frames #设置录制的帧数

Raspicam

在 Buster 版本的树莓派系统中,摄像头驱动默认是 Raspicam,用户可以直接启用摄像头并使用,无需额外配置。

安装Raspicam(可选)

打开树莓派终端,并输入以下指令安装驱动. 注意:此驱动暂时无法支持64位的树莓派系统。

sudo apt-get update
cd
sudo apt install cmake
git clone https://github.com/raspberrypi/userland
cd userland
./buildme
cp build/bin/* ~/bin/

按照后之后需要重启系统

sudo reboot

调用摄像头

raspistill

raspistill指令用于拍摄静态图片。 示例:raspistill -o cam.jpg

raspivid

raspivid指令用于录制视频。 示例: raspivid -o vid.h264

raspiyuv

raspiyuv指令具有跟raspisitll相同的功能,不同的是raspiyuv不是输出jpgs等标准图像文件,而是从相机的ISP输出中生成YUV420或者RGB888图像文件。
大部分情况下,拍摄图像,用raspistill比较好,但是如果你想用未压缩的黑白图像的时候,可以选择使用raspiyuv指令。 示例:raspiyuv -o cam.jpg

指令设置选项

raspicam 指令在使用的时候,可以通过设置选项来调整图像最终成像效果。以下列出可用的设置选项以供参考.

--preview, -p  #设置预览窗口<x, y, w, h>

用户可以通过设置x, y的值来设置预览窗口的位置, 设置w, h的值来调整预览图像的分辨率。

--fullscreen, -f  #全屏预览窗口

将预览窗口全屏显示

--nopreview, -n  #不显示预览窗口

关掉预览窗口,指令会直接输出图像或者视频到文件。

--opacity, -op  #设置预览窗口透明度

设置预览窗口的透明度, 0 是不可见, 255 是全透明

--sharpness, -sh  #设置图像锐度 (-100 - 100)

默认锐化值为0

--contrast. -co  #设置图像对比度 (-100 - 100)

默认的对比度为0

--brightness, -br  #设置图像对比度 (0 - 100)

默认亮度为50, 0是全黑,100是全白。

--saturation, -sa  #设置图像饱和度 (-100 - 100)

默认饱和度是0

--ISO  #设置快门感光度 (100 - 800)

设置拍照时的感光度

--vstab, -vs  #开启视频稳定

只有视频录制模式有效,开启视频防抖。

--ev  #设置EV补偿

设置图像的EV补偿值, 默认0

--exposure,  -ex  #设置曝光模式

可设置的曝光选项:

  • auto: 自动曝光模式
  • night: 夜间拍摄模式
  • nightpreview
  • backlight: 背光模式
  • spotlight
  • sports: 运动模式(运动模式下会缩短快门时间
  • snow: 雪景模式
  • beach: 海滩模式
  • verylong: 长曝光模式
  • fixedfps: 固定fps
  • antishake: 防抖模式
  • fireworks: 烟花模式

注:根据摄像头型号,有部分模式不可用

--flicker, -fli   #闪烁避免

可设置的模式:

  • off: 关闭防闪烁模式
  • auto: 自动检测注频率
  • 50Hz: 设置防闪烁频率是50Hz
  • 60Hz: 设置防闪烁频率是60Hz
--awb,  #设置自动白平衡模式
  • off: 关闭自动白平衡
  • auto: 自动白平衡模式(默认)
  • sun: 晴天模式 (5000K ~ 6500K)
  • cloud: 多云模式 (6500K ~ 12000K)
  • shade:阴影模式
  • tungsten: 钨丝灯模式(2500K ~ 3500K)
  • incandescent: 白炽灯模式(2500K ~ 4500K)
  • flash: 闪光灯模式
  • horizon: 地平线模式
  • greyworld: 如果使用的是不带红外滤光片的相机(比如NoIR), 可以修复因为缺少IR滤镜而导致的白平衡失调的情况

注:根据摄像头型号,有部分模式不可用

--imfx, -ifx  #设置图像滤镜效果

可设置的图像滤镜效果:

  • none: 无效果(默认)
  • negative:颜色翻转
  • solarise: 日照效果
  • posterise: 海报效果
  • whiteboard: 白板效果
  • backboard:黑板效果
  • sketch: 素描
  • denoise: 去噪
  • emboss: 浮雕
  • oilpaint: 油画
  • hatch: 纹理
  • gpen: 铅笔素描
  • pastel: 彩色铅笔
  • watercolour: 水彩
  • film: 胶片
  • blur: 模糊
  • saturation: 饱和

注:根据摄像头型号,有部分模式不可用

--colfx, -cfx  #设置颜色效果<U:V>

U和V参数的设置范围是 0 ~ 255, 用来调整U和Y通道的数值。 比如: --colfx 128:128 会讲图像设置成单色图。

--metering, -mm  #设置测光模式

可设置选项:

  • average: 平均或者全幅测光
  • spot:点测光
  • backlit: 预设一个背光图像
  • matrix: 矩阵测光
--rotation, -rot  #设置图像旋转 (0 - 359)

可以通过角度参数设置图像旋转角度

--hflip, -hf  #设置图像水平翻转

设置图像水平翻转

--vflip, -vf  #设置图像垂直翻转

垂直翻转图像

--roi, #裁剪图像 <x, y, w, h>

根据参数裁剪图像,注意参数都是规划化在(0,0 ~ 1.0), 比如,如果要裁剪1/4图像,可以用指令 -roi 0.5,0.5,0.25,0.25

--shutter, --ss  设置快门速度/时间

设置快门时间(单位:ms)。 快门时间根据感光芯片的不同,可设置的最大快门时间不同。

型号最大数字(ms)
V1 (OV5647)6000000 (6s)
V2 (IMX219)10000000 (10s)
HQ (IMX477200000000 (200s)
--drc, -drc  #启用/关闭动态范围压缩
  • off (默认)
  • low
  • med
  • high
--stats, -st  #通过静态图像帧来统计图像
--awbgains, -awbg

设置蓝色和绿色增益, 在设置 --awb off 的情况下生效

--analoggain, -ag

设置模拟增益值

--digitalgain, -dg

设置数字增益值

--mode, -md

设置传感器模式:

  • OV5647
模式分辨率纵横比帧率FoV
0自动选择
11920 x 108016:91-30fps局部
22592 x 19444:31-15fps全幅
32592 x 19444:30.1666 - 1fps全幅
41296 x 9724:31 - 42fps全幅
51296 x 73016:91- 49fps全幅
6640 x 4804:342.1 - 60fps全幅
7640 x 4804:360.1 - 90fps全幅
  • IMX219
模式分辨率纵横比帧率FoV
0自动选择
11920 x 108016:90.1-30fps局部
23280 x 24644:30. 1-15fps全幅
33280 x 24644:30.1 - 15fps全幅
41640 x 9724:31 - 42fps全幅
51296 x 73016:91- 49fps全幅
6640 x 4804:342.1 - 60fps全幅
7640 x 4804:360.1 - 90fps全幅
  • HQ Camera
模式分辨率纵横比帧率FoV
0自动选择
12028 x 1080169:900.1-50fps局部
22028 x 10804:30. 1-50fps全幅
34056x30404:30.005 - 10fps全幅
41332x99074:5550.1-120 fps局部
--camselect, -cs

当系统接入多个摄像头时,选择摄像头, 0 或 1.

--annotate, -a #启用/设置注释

在元数据中使用位掩码的方式来表示参数,可以直接用加法表示。 比如, 12 可以表示显示时间(4)和显示日期 (8), 就是通过加法 4+8 =12表示的。
可设置的选项

参数说明
-a 4时间
-a 8日期
-a 12时间和日期,实际就是 4 + 8
-a 16快门设置
-a 32CAF设置
-a 64增益设置
-a 128镜头设置
-a 256动画设置
-a 512帧数
-a 1024黑色背景
-a "ABC %Y-%m-%d %X"显示文本
-a 4 -a "ABC %Y-%m-%d %X"显示自定义格式的时间/日期
-a 8 -a "ABC %Y-%m-%d %X"显示自定义格式的时间/日期
--annotateex, -ae  #设置额外注解参数
--stereo, -3d

设置双目模式。

  • sbs - 并排模式
  • tb: -竖排模式
  • off -关掉双目模式(默认)
--decimate, -dec

将双目图像的宽度和高度减半

--setting, -set

输出当前的摄像头设置

raspistill 设置参数

--width, -w  #设置图像宽度
--height, -h  #设置图像高度
--quality, 0q  #设置JPEG质量 <0 ~ 100>
--raw, -r  #将原Bayer数据添加到JPEG元数据中
--output, -o #输出文件 <filename>
--latest, -l  #关联最后一帧图像到文件 <filename>
--verbose, -v #打印详情
--timeout, -t  #设置程序预览时间
--timelapse, -tl  #设置演示摄影
--framestart, -fs #保存第一帧的编号
--datetime, -dt  #用日期时间命名文件
--timestamp, -ts #用时间戳命名文件
--thumb, -th #设置缩略图参数 <x:y:qulity>, 默认为(64:48:35)
--demo, -d  #运行演示模式<ms》
--encoding, -e #按照指定格式编码, jpg, bmp或者png
--restart, -rs  #设置JPEG重启标志
--exif, -x   #设置EXIF标记
--gpsdexif, -gps #设置实时exif 时间 (需要有GPS Dongle接入)
--fullpreview,  -fg  #全屏预览
--keypress, -k  #按键拍照模式
--signal, -s  # 信号模式
--burst, -bm #抓拍模式

raspivid 设置参数

--width, -w #设置视频宽度
--height, -h #设置视频高度
--bitrate, -b #设置比特率
--output, -o #设置输出文件名 <filename>
--listen, -l #使用网络连接的时候,等待网络连接
--versbose, -v #打印详情
--timeout, -t  #设置预览时间
--demo, -d #运行演示 <ms>
--framerate, -fs #设置帧率
--penc, -e #显示编码后的预览图像
--intra, -g #设置内部刷新周期
--qp, -qp #设置量化参数
--profile, -pf #指定H264配置文件, baseline / main / high
--level, -lev  #设置H264编码等级
--irefresh, -if #设置 H264内部刷新类型 cyclic / adaptive / both / cyclicrows
--inline, -ih  #插入PPS,SPS头
--spstimings, -stm #将时序信息插入到SPS块中
--timed, -td  #定时切换录制和暂停功能
--keypress, -k  #按键暂停录制
--signal, -s  #根据SIGUSR1 切换暂停和录制状态
--split, -sp  #在signal和keypress 模式下,每次重新录制的时候都会重新创建文件
--vectors, -x  #矢量输出
--flush, -fl  #写入视频数据后立即强制刷新输出数据缓冲区, 绕过了写入数据的任何操作系统缓存,并且可以减少延迟。
--save-pts, -pts  #将时间戳信息保存到指定文件。
--codec, -cd  # 指定编码器 H264 / MJPEG
--initial, -i  #设置启动是的初始状态
--segment, -sg #将视频流分割到多个文件中
--wrap, -wr  #设置分割的最大值
--start, -sn #设置初始分割编码
--raw, -r #设置元数据文件名
--raw-format, -rf #指定元数据格式 yuv / rgb / grey

资料

软件

FAQ

问题:如何替换树莓派开机logo图片?

将自定义图片替换此目录的图片即可 /usr/share/plymouth/themes/pix/splash.png


问题:如何将摄像头画面铺满屏幕?

可以使用此命令

libcamera-hello -p 0,0,1280,800 -t 0 --width 1280 --height 800


售后

周一-周五(9:30-6:30)周六(9:30-5:30)

手机:13434470212

邮箱:services04@spotpear.cn

QQ:202004841

TAG: NUCLEO MX25R6435扩展RAM Sipeed 荔枝派 Maix Bit RISC-V AI+lOT K210开发板套件 ESP32 S3 工业级隔离型转换器 MP2.5GD 树莓派5 PCIE转双2.5G以太网扩展板 Pi5 RTL8125 荔枝派糖Lichee Tang Nano 4K高云FPGA GOAI开发板Sipeed W1NSR-LV4C Luckfox RK3576摄像头IMX415 800万98度IR-CUT广角3840x2160像素 RoArm-M2 ESP32 4-DOF大扭矩总线舵机机械臂ST3235 QMI8658C 电子墨水屏 双电子眼睛0.71寸圆形LCD显示屏适用于Arduino/树莓派/PICO/STM32 树莓派Pico 1.14寸LCD 树莓派13.3寸LCD DSI显示屏MIPI触摸屏1920x1080 英伟达 ESP32 1.9寸LCD 树莓派5散热片 USB转2.5G网口转换器RJ45免驱动原装RTL8156B Milk-V Duo S 512MB SG2000 RISC-V UART串口控制台 树莓派5电源 树莓派10.1寸LCD显示屏HDMI触摸1920x1200迷你PC电脑副屏 树莓派自动对焦摄像头