91欧美超碰AV自拍|国产成年人性爱视频免费看|亚洲 日韩 欧美一厂二区入|人人看人人爽人人操aV|丝袜美腿视频一区二区在线看|人人操人人爽人人爱|婷婷五月天超碰|97色色欧美亚州A√|另类A√无码精品一级av|欧美特级日韩特级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

【EASY EAI Nano開源套件試用體驗】3攝像頭與屏幕的使用

開發(fā)板試用精選 ? 來源:開發(fā)板試用 ? 作者:電子發(fā)燒友論壇 ? 2022-10-11 16:44 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

本文來源電子發(fā)燒友社區(qū),作者:碼農(nóng)愛學習, 帖子地址:https://bbs.elecfans.com/jishu_2307434_1_1.html


EASY EAI Nano屏幕顯示攝像頭測試(附上體驗視頻,詳見作者原貼)

本篇進行EASY EAI Nano的屏幕顯示與攝像頭顯示測試,先來看下最終的測試效果:

  • 左圖是顯示圖片
  • 右圖是顯示多個攝像頭,包括:
    • 雙面攝像頭中左邊的紅外攝像頭
    • 雙面攝像頭中右邊的RGB攝像頭
    • 外接USB攝像頭

1.png

本篇測評參考了官方文檔的一些內(nèi)容:https://www.easy-eai.com/document_details/3/129

1 攝像頭

1.1 MIPI CSI-2接口簡介

MIPI CSI-2接口是由MIPI聯(lián)盟下的Camera工作組指定的CSI(Camera Serial Interface)的第2版接口標準,主要由應(yīng)用層、協(xié)議層、物理層組成,最大支持4個虛擬通道傳輸數(shù)據(jù)。

EASY EAI Nano的雙面攝像頭,包括一個RGB攝像頭和一個紅外攝像頭,都是MIPI CSI-2接口。

通過指令檢查EASY EAI nano的MIPI-CSI2接口模塊是否正常工作

dmesg | grep mipi

2.png

1.2 三種類型的攝像頭

1.2.1 RGB攝像頭與IR攝像頭

MIPI CSI-2的RGB攝像頭在EASY EAI Nano套件下的位置定義如下所示,占用J3的bit1~18

MIPI CSI-2的紅外攝像頭在EASY EAI Nano套件下的位置定義如下所示,占用J3的bit22~37

3.png

1.2.2 USB攝像頭

USB攝像頭是基于UVC驅(qū)動工作的,

USB設(shè)備具有熱插拔、易擴展等特性,故應(yīng)用場合十分廣泛。

Linux系統(tǒng)通過sysfs管理USB設(shè)備。

EASY EAI nano評估套件上集成了多路USB接口,其中有2路USB2.0 Host、1路USB2.0 Device。

1.3 攝像頭操作的API介紹

EASY EAI nano已庫文件+頭文件的形式提供了攝像頭的使用,攝像頭的底層操作邏輯看不到,我們只需要關(guān)系頭文件中API接口的使用方法即可。

選項 描述
頭文件目錄 -I easyeai-api/peripheral_api/camera
庫文件目錄 -L easyeai-api/ peripheral_api/camera
庫連接參數(shù) -lcamera

easyeai-api/peripheral_api/camera/camera.h中的主要接口

/* usb camera */
int usbcamera_init(int bus, int port, int width, int height, int rot);
void usbcamera_exit(int bus, int port);
int usbcamera_getframe(int bus, int port, char *pbuf);
void usbcamera_preset_fps(int fps);
?
/* rgb camera */
int rgbcamera_init(int width, int height, int rot);
void rgbcamera_exit(void);
int rgbcamera_getframe(char *pbuf);
void rgbcamera_set_format(int format);
?
/* ir camera */
int ircamera_init(int width, int height, int rot);
void ircamera_exit(void);
int ircamera_getframe(char *pbuf);
void ircamera_set_format(int format);

1.4 測試例程

三種攝像頭的使用方式類似,RGB攝像頭IR攝像頭的使用方式幾乎一樣

RGB/IR攝像頭的使用:

// 打開攝像頭
#define CAMERA_WIDTH          720
#define CAMERA_HEIGHT         1280
ret = rgbcamera_init(CAMERA_WIDTH, CAMERA_HEIGHT,  90);
?
//獲取圖片
ret = rgbcamera_getframe(pbuf);
?
//保存圖片
fp = fopen("/tmp/photo", "w");
fwrite(pbuf, 1, IMAGE_SIZE, fp);
fclose(fp);
?
//釋放攝像頭
rgbcamera_exit();

USB攝像頭的使用:

// 打開攝像頭
#define CAMERA_WIDTH          720
#define CAMERA_HEIGHT         1280
ret = usbcamera_init(USB2_0, USB_DIRECT, CAMERA_WIDTH, CAMERA_HEIGHT,  90);
?
//獲取圖片
ret = usbcamera_getframe(USB2_0, USB_DIRECT, pbuf);
?
//保存圖片
fp = fopen("/tmp/photo", "w");
fwrite(pbuf, 1, IMAGE_SIZE, fp);
fclose(fp);
?
//釋放USB攝像頭
usbcamera_exit(USB2_0, USB_DIRECT);

以上測試函數(shù),會用攝像頭拍一張照片,并保存到/tmp目錄中。

2 顯示屏

2.1 DRM驅(qū)動框架介紹

EASY EAI nano評估板上默認支持5寸顯示屏(帶電容觸摸屏),分辨率為720x1280,EASY EAI nano產(chǎn)品使用DRM(Direct Rendering Manager)驅(qū)動框架實現(xiàn)多應(yīng)用同時使用同一個顯示器的目的,而EASY-EAI-Toolkit的display庫則是對DRM的封裝。

4.png

2.2 顯示屏操作的API介紹

頭文件與庫文件

選項 描述
頭文件目錄 -I easyeai-api/peripheral_api/display
庫文件目錄 -L easyeai-api/ peripheral_api/display
庫鏈接參數(shù) -ldisplay

easyeai-api/peripheral_api/display/disp.h中的主要接口

/* 公共api */
void disp_preset_uiLayer(int enable);
?
/* 適合初次使用 */
int disp_init(int width, int height); //默認輸入RGB888
void disp_exit(void);
void disp_commit(void *ptr, int data_len);
?
/* pro, 顯示多路視頻時,或旋轉(zhuǎn)輸入圖像角度,或裁切圖像*/
int disp_init_pro(disp_screen_t *screen);
void disp_exit_pro(void);
void disp_commit_pro(void *ptr, int chn, int data_len);

一些參數(shù)的含義:

  • width:顯示區(qū)域?qū)挾?/span>
  • height:顯示區(qū)域高度
  • ptr:用戶空間的顯示內(nèi)容空間
  • data_len:輸入圖像數(shù)據(jù)內(nèi)存長度
  • screen:顯示屏屬性,包含顯示區(qū)域大小、子窗口的描述等
  • chn:目標窗口索引

結(jié)構(gòu)體定義

typedef struct disp_win {
int enable;
int win_x;
int win_y;
int win_w;
int win_h;
int rotation;//順時針旋轉(zhuǎn)輸入圖像角度,支持90、180、270、0度
IMAGE_TYPE_E in_fmt;
int in_w;//輸入圖像寬度
int in_h;//輸入圖像高度
int HorStride;//輸入圖像水平步長
int VirStride;//輸入圖像垂直步長
/* 如果不設(shè)置crop系列參數(shù),則默認拉伸原圖鋪滿整個win ;
 *設(shè)置crop則先裁切再把裁切后的圖像鋪滿整個win,以便保持圖像寬高比例
 */
int crop_x;//裁切起始X坐標(基于旋轉(zhuǎn)前圖像的坐標系)
int crop_y;//裁切起始Y坐標(基于旋轉(zhuǎn)前圖像的坐標系)
int crop_w;//裁切后的圖像寬度(以旋轉(zhuǎn)前的圖像為參考)
int crop_h;//裁切后的圖像高度(以旋轉(zhuǎn)前的圖像為參考)
} disp_win_t;
?
typedef struct disp_screen {
    int screen_width;
int screen_height;
disp_win_t wins[VMIX_MAX_CHN_NUM];
} disp_screen_t;

2.3 測試例程

參考官方給的例程,進行修改,增加通過參數(shù)顯示指定圖片的功能,測試不同圖片顯示到屏幕的效果。

my-display.c的主程序如下:

int main(int argc, char *argv[])
{
    char *img_path = IMAGE_PATH;
    if (argc == 2)
    {
        img_path = argv[1];
        printf("recv:%sn", img_path);
    }
        
int ret = 0;
    char *pbuf = NULL;
FILE *fp = NULL;
disp_screen_t screen = {0};
?
signal(SIGINT, sigterm_handler);
?
/* 1、準備圖像數(shù)據(jù) */
pbuf = (char *)malloc(IMAGE_SIZE);
    if (!pbuf) {
        printf("malloc error: %s, %dn", __func__, __LINE__);
        return -1;
    }
fp = fopen(img_path, "r");
if (!fp) {
printf("fopen error: %s, %dn", __func__, __LINE__);
return -1;
}
    ret = fread(pbuf, 1, IMAGE_SIZE, fp);
fclose(fp);
if (ret != IMAGE_SIZE) {
printf("fread error: %s, %dn", __func__, __LINE__);
free(pbuf);
return -1;
}
?
/* 2、初始化顯示 */
screen.screen_width = DISP_WIDTH;
screen.screen_height = DISP_HEIGHT;
screen.wins[0].enable = 1;
    screen.wins[0].win_x = 0;
screen.wins[0].win_y = 0;
screen.wins[0].win_w = 720;
screen.wins[0].win_h = 1280;
    screen.wins[0].rotation = 0;
screen.wins[0].in_fmt = IMAGE_TYPE_RGB888;
screen.wins[0].in_w = DISP_WIDTH;
screen.wins[0].in_h = DISP_HEIGHT;
screen.wins[0].HorStride = DISP_WIDTH;
screen.wins[0].VirStride = DISP_HEIGHT;
?
ret = disp_init_pro(&screen);
if (ret) {
printf("error func:%s, line:%dn", __func__, __LINE__);
goto exit1;
}
?
/* 3、提交顯示 */
g_run = 1;
disp_commit_pro(pbuf, 0, IMAGE_SIZE);
    
while(g_run) {
sleep(1);
}
?
disp_exit_pro();
exit1:
free(pbuf);
pbuf = NULL;
    
    return ret;
}

修改CMakeLists.txt,增加如下內(nèi)容:

#--------------------------
# my-display
#--------------------------
link_directories(${toolkit_root}/peripheral_api/display)#-L
add_executable(my-display my-display.c)#-o
target_link_libraries(my-display pthread easymedia display)#-l
target_include_directories(my-display PRIVATE ${api_inc})#-I

在執(zhí)行函數(shù)時,附加一個圖片的路徑參數(shù),可以顯示指定的圖片:

5.png

準備一些測試圖片,格式為RGB888,分辨率720x1280,測試顯示兩張不同圖片的效果:

6.png

3 攝像頭+屏幕程序代碼分析

參考官方的攝像頭顯示例程,將紅外攝像頭、RGB攝像頭和USB攝像頭采集的畫面同時顯示到屏幕中,改寫的測試代碼如下。

my-disp-cam.c的主程序如下:

int main()
{
	char *prgb = NULL;
	char *pir = NULL;
    char *pusb = NULL;
	int ret = 0;
	disp_screen_t screen = {0};
    
    bool bHasUSBCamear = false;

	signal(SIGINT, sigterm_handler);

	/* camera init */
	ret = rgbcamera_init(CAMERA_WIDTH, CAMERA_HEIGHT, 90);
	if (ret) {
		printf("error func:%s, line:%dn", __func__, __LINE__);
		goto exit_donothing;
	}
	ret = ircamera_init(CAMERA_WIDTH, CAMERA_HEIGHT, 270); //此角度由攝像頭模組決定
	if (ret) {
		printf("error func:%s, line:%dn", __func__, __LINE__);
		goto exit_freergb;
	}
    ret = usbcamera_init(USB2_0, USB_DIRECT, CAMERA_WIDTH, CAMERA_HEIGHT, 180);
	if (ret) {
		printf("error func:%s, line:%dn", __func__, __LINE__);
	}
    else
    {
        bHasUSBCamear = true;
    }

	/* display init */
	screen.screen_width = DISP_WIDTH;
	screen.screen_height = DISP_HEIGHT;
    
	screen.wins[0].enable = 1;
	screen.wins[0].in_fmt = IMAGE_TYPE_RGB888;
	screen.wins[0].in_w = CAMERA_WIDTH;
	screen.wins[0].in_h = CAMERA_HEIGHT;
	screen.wins[0].rotation = 0;
	screen.wins[0].win_x = 0;
	screen.wins[0].win_y = 0;
	screen.wins[0].win_w = 360;
	screen.wins[0].win_h = 640;
    
	screen.wins[1].enable = 1;
	screen.wins[1].in_fmt = IMAGE_TYPE_RGB888;
	screen.wins[1].in_w = CAMERA_WIDTH;
	screen.wins[1].in_h = CAMERA_HEIGHT;
	screen.wins[1].rotation = 0;
	screen.wins[1].win_x = 360;
	screen.wins[1].win_y = 0;
	screen.wins[1].win_w = 360;
	screen.wins[1].win_h = 640;
    
    if (bHasUSBCamear)
    {
        screen.wins[2].enable = 1;
        screen.wins[2].in_fmt = IMAGE_TYPE_RGB888;
        screen.wins[2].in_w = CAMERA_WIDTH;
        screen.wins[2].in_h = CAMERA_HEIGHT;
        screen.wins[2].rotation = 0;
        screen.wins[2].win_x = 0;
        screen.wins[2].win_y = 640;
        screen.wins[2].win_w = 720;
        screen.wins[2].win_h = 640;
    }
    
	ret = disp_init_pro(&screen);
	if (ret) {
		printf("error func:%s, line:%dn", __func__, __LINE__);
		goto exit_freergb_freeir;
	}

	/* alloc buffer for cap data */
	prgb = (char *)malloc(IMAGE_SIZE);
	if (!prgb) {
		printf("error: %s, %dn", __func__, __LINE__);
		ret = -1;
		goto exit_freergb_freeir_freedisp;
	}
	pir = (char *)malloc(IMAGE_SIZE);
	if (!pir) {
		printf("error: %s, %dn", __func__, __LINE__);
		ret = -1;
		goto exit_freergb_freeir_freedisp_freeprgb;
	}
    if (bHasUSBCamear)
    {
        pusb = (char *)malloc(IMAGE_SIZE);
            if (!pusb) {
            printf("error: %s, %dn", __func__, __LINE__);
        }
    }

	g_run = 1;
	while(g_run) {
        ret = ircamera_getframe(pir);
		if (!ret) {
			disp_commit_pro(pir, 0, IMAGE_SIZE);
		}
		ret = rgbcamera_getframe(prgb);
		if (!ret) {
			disp_commit_pro(prgb, 1, IMAGE_SIZE);
		}
        if (bHasUSBCamear)
        {
            ret = usbcamera_getframe(USB2_0, USB_DIRECT, pusb);
            if (!ret) {
                disp_commit_pro(pusb, 2, IMAGE_SIZE);
            }
        }
	}
    
    if (bHasUSBCamear)
    {
        free(pusb);
        pusb = NULL;
        usbcamera_exit(USB2_0, USB_DIRECT);
    }

	free(pir);
	pir = NULL;
exit_freergb_freeir_freedisp_freeprgb:
	free(prgb);
	prgb = NULL;
exit_freergb_freeir_freedisp:
	disp_exit_pro();
exit_freergb_freeir:
	ircamera_exit();
exit_freergb:
	rgbcamera_exit();
exit_donothing:
    return ret;
}

修改CMakeLists.txt,增加如下內(nèi)容:

#--------------------------
# my-disp-cam
#--------------------------
link_directories(${toolkit_root}/peripheral_api/display)	#-L
link_directories(${toolkit_root}/peripheral_api/camera)		#-L
add_executable(my-disp-cam my-disp-cam.c)		#-o
target_link_libraries(my-disp-cam pthread rkaiq rkfacial rga easymedia display camera)	#-l
target_include_directories(my-disp-cam PRIVATE ${api_inc})	#-I

測試效果如下圖左圖,3個攝像頭可以同時顯示到屏幕,實測當攝像頭運動時,屏幕顯示的畫面也十分流暢。

另外,還可以修改攝像頭和屏幕的顯示方向,如下圖右圖,就是將USB攝像頭橫屏顯示的效果。

7.png

4 總結(jié)

本篇對EASY EAI Nano的屏幕和攝像頭的顯示功能進行測評,測試了屏幕顯示不同的圖片,屏幕顯示不同的攝像頭(MIPI紅外攝像頭、MIPI RGB攝像頭、外接USB攝像頭),以及多個攝像頭的同時顯示與屏幕顯示方向的測試。


聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 開發(fā)板
    +關(guān)注

    關(guān)注

    26

    文章

    6291

    瀏覽量

    118143
  • EASY-EAI靈眸科技
    +關(guān)注

    關(guān)注

    4

    文章

    67

    瀏覽量

    3620
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    EASY EAI Nano-TB(RV1126B)開發(fā)板試用】桌面系統(tǒng)功能測試-驅(qū)動攝像頭-Mediapipe人體姿態(tài)檢測1

    側(cè)。 EASY EAI Nano-TB開發(fā)板具有2路MIPI CSI-2接口。每路引出了4個Lane。位置定義如下所示。這里采用CSI-1 接口 攝像頭
    發(fā)表于 12-19 19:41

    EASY EAI Nano-TB(RV1126B)開發(fā)板試用】+1、開箱上電

    Nano-TB(RV1126B)開發(fā)板本體 顯示套件 :一塊電容觸摸屏及FPC連接線(短線) 攝像頭模塊 :雙目攝像頭模組及FPC連接線(長線) 電源適配器 :輸出規(guī)格為直流12V
    發(fā)表于 11-19 21:39

    EASY EAI Nano-TB(RV1126B)開發(fā)板試用】驅(qū)動攝像頭

    # 攝像頭節(jié)點(確認存在:ls /dev/video30) CAMERA_DEVICE = \"/dev/video30\" # 3. 打開攝像頭(CAP_V4L2 接口,適配
    發(fā)表于 11-17 13:35

    EASY EAI Nano-TB(RV1126B)開發(fā)板試用】1、初識

    非常感謝電子發(fā)燒友以及靈眸科技給了我這次試用EASY EAI Nano-TB(RV1126B)開發(fā)板的機會,星期四確認了我的試用機會,星期五
    發(fā)表于 11-16 11:15

    EASY EAI Nano-TB(RV1126B)開發(fā)板試用】開箱測評

    標識必須位于同一側(cè)。 EASY EAI Nano-TB開發(fā)板具有2路MIPI CSI-2接口。每路引出了4個Lane。位置定義如下所示。這里采用CSI-1 接口 攝像頭
    發(fā)表于 11-01 11:05

    EASY EAI Nano-TB(RV1126B)開發(fā)板試用】1.開箱測評

    配件很豐富,有攝像頭,顯示屏,揚聲器,耳麥等等,還有WIFI天線。 連接好如下圖 通電后如下 可惜的是顯示屏沒有點亮,不知道是不是屏幕有問題,還是板子里默認燒錄的固件有問題。 視屏如下
    發(fā)表于 10-25 09:03

    【作品合集】靈眸科技EASY EAI Orin Nano(RK3576)開發(fā)板測評

    RKMPP的ffmpeg 【EASY EAI Orin Nano(RK3576)開發(fā)板試用體驗】05-基于QT和ffmpeg硬解碼的多路攝像頭
    發(fā)表于 09-09 09:59

    EASY EAI Orin Nano開發(fā)板試用體驗】使用stream推流代碼和WEB服務(wù)器代碼實現(xiàn)在客戶端網(wǎng)頁上查看攝像頭圖像

    網(wǎng)頁上查看攝像頭圖像 EASY EAI Orin Nano開發(fā)板主控是RK3576帶有NPU,調(diào)試深入之后還是要做攝像頭相關(guān)的應(yīng)用開發(fā)的,
    發(fā)表于 08-11 23:15

    EASY EAI Orin Nano開發(fā)板試用體驗】EASY-EAI-Toolkit人臉識別

    碼:1234 )。 3.尋找人臉圖片素材,將其與算法模型文件放到EASY-EAI-Toolkit-3576/Demos/algorithm-face_detect/Release路徑下 二.人臉檢測代碼
    發(fā)表于 07-20 14:40

    EASY EAI Orin Nano開發(fā)板試用體驗】--USB攝像頭使用

    可用設(shè)備節(jié)點ls /dev/video* 3.定位接入USB攝像頭節(jié)點設(shè)備cd /sys/class/video4linux/cat /sys/class/video4linux/video22
    發(fā)表于 07-13 18:21

    EASY EAI Orin Nano開發(fā)板試用體驗】EASY-EAI-Toolkit初體驗

    本次EASY EAI Orin Nano開發(fā)板試用體驗主要是超級想體驗靈眸的EASY-EAI-Toolkit。 一、簡介
    發(fā)表于 06-28 21:21

    EASY EAI Orin Nano開發(fā)板試用體驗】人臉識別體驗

    /nfs -o nolock 【注】此處需要插上網(wǎng)線連上網(wǎng),要不提示連接服務(wù)器出錯。 3、進入人臉識別目錄,并執(zhí)行./build.sh編譯: root@EASY-EAI-ORIN-NANO:/home
    發(fā)表于 06-26 06:54

    EASY EAI Orin Nano開發(fā)板試用體驗】--開發(fā)板開箱了解

    感謝靈眸科技與論壇提供的開發(fā)板與平臺。EASY EAI Orin-Nano開發(fā)板實物如下: EASY EAI Orin
    發(fā)表于 06-25 23:32

    EASY EAI Orin Nano開發(fā)板試用體驗】安裝nfs服務(wù)器

    nolock root@EASY-EAI-ORIN-NANO:/home/orin-nano/Desktop# mkdir nfs root@EASY-EAI-ORIN-NANO:/home
    發(fā)表于 06-22 17:32

    EASY EAI Orin Nano開發(fā)板試用體驗】開發(fā)環(huán)境準備

    【前言】 首先感謝電子發(fā)燒友論壇以及靈眸科技給示了我這次非常難得的【EASY EAI Orin Nano開發(fā)板試用體驗】的機會,在進行評測之前首先需要創(chuàng)建開發(fā)環(huán)境。 靈眸科技有非常詳細
    發(fā)表于 06-22 16:42