3.1.1 MIPI 相机使用说明
环境准备
硬件连接
请将 MIPI 摄像头模组连接至开发板的 MIPI CSI 接口。具体连接方式可参考下图所示:

同时,开发板与显示器之间请使用 HDMI 线缆进行连接,以便输出图像画面。
设备测试
自动识别摄像头类型
首先确认摄像头所连接的 MIPI CSI 接口编号。例如若连接至 CSI1,则运行以下命令:
cam-test /usr/share/camera_json/csi1_camera_detect.json
若摄像头为已支持型号,系统将自动识别,并输出如下日志,同时在 /tmp/ 目录下生成配置文件:
...
I: ./sensors/cam_sensors_module.c(239): "detect imx219_spm sensors in csi3: success, set 1920x1080 to 1920x1080"
I: auto_detect_camera(1430): "auto detect sensor ===================== finish "
E: update_json_file(709): "Open /usr/share/camera_json/csi3_camera_auto.json file fail"
E: update_json_file(709): "Open /usr/share/csi3_camera_auto.json file fail"
I: update_json_file(723): "save json to /tmp/csi1_camera_auto.json success"
⚠️ 若无法确认 CSI 接口编号,请参考 MUSE 系列开发板用户手册 或尝试 CSI1 ~ CSI3 接口逐个测试。若均无法识别,可能 为硬件故障或未适配的摄像头,后者情况下,建议参考官方文档 Camera 快速点亮导览 进行适配操作。
配置 Virtuall Camera 模型
将自动生成的摄像头配置文件复制至指定路径,并重命名为 svivi_cam1.json:
sudo cp /tmp/csi1_camera_auto.json /root/svivi_cam1.json
打开该 JSON 文件,在顶层添加如下字段以启用 Virtual Camera 模式:
"use_v4l": 1
使用 V4L2 出图测试验证
使用调试工具 v4l2_test_spacemit 进行图像采集测试。
下载安装与编译:
mkdir v4l2_test_spacemit
wget https://archive.spacemit.com/ros2/code/v4l2_test_spacemit.tar.gz
tar xvzf v4l2_test_spacemit.tar.gz
gcc v4l2_capture.c v4l2_main.c v4l2_output.c v4l2_stream.c v4l2_common.c -o v4l2_test_spacemit --static
执行采图命令:
./v4l2_test_spacemit \
--device /dev/video50 \
--set-fmt-video width=1920,height=1080,pixelformat=NV12 \
--verbose \
--stream-dmabuf \
--stream-loop \
--stream-save 10 \
--stream-to=test.yuv
正常输出示例:
...
VIDIOC_DQBUF: ok, type:9
VIDIOC_QBUF: ok, type:9
do_handle_cap:723 [INFO]m2m capture dequeue----------------: 15
...
使用
Ctrl+C可中断采集⚠️ 注意事项:
- 最大支持分辨率为 1920×1080(1080p)
- 仅支持图像格式:NV12
- 内存类型要求:dmabuf
至此,说明 MIPI 摄像头可用,可以进行后续流程。
高级开发:C++ SDK 使用示例
使用JDK 提供的 SDK 实例更高级别控制和图像处理功能
C++样例代码
auto camera = JdkCamera::create("/dev/video50", 1920, 1080, V4L2_PIX_FMT_NV12);
auto jdkvo = std::make_shared<JdkVo>(1920, 1080, PIXEL_FORMAT_NV12);
auto frame = camera->getFrame();
auto ret = jdkvo->sendFrame(frame);
快速集成:JDK 摄像头采集 SDK
JDK SDK 下载与安装
wget https://archive.spacemit.com/ros2/code/jdk_sdk.tar.gz
sudo tar xvf jdk_sdk.tar.gz -C /opt/
mv /opt/jdk_sdk /opt/jdk
目录结构如下:
/opt/jdk
├── include
├── jdk_examples
├── ko
├── lib
├── Makefile
└── README.md
下载与解压 jdk_cam
wget https://archive.spacemit.com/ros2/code/jdk_cam.tar
tar xvf jdk_cam.tar
目录结构如下:
jdk_cam/
├── Makefile
├── src/main.cpp
└── workspace/