转自:https://blog.csdn.net/ldswfun/article/details/8745577

在移植android hal的过程中,移植的首要任务是要确保驱动完好,camera是属于字符设备,但是对于其测试代码的编写就不像一般的驱动那么简单啦,因为camera的测试代码一定是要用v4l2 api,所以接下来就是介绍我们写camera的测试代码的流程。

1,打开设备

  1. static int open_device(char *dev_name)
  2. {
  3. assert(dev_name);
  4. int fd = -1;
  5. fd = open(dev_name , O_RDWR);
  6. if( -1 == fd )
  7. {
  8. MYLOGD("open %s fail: %s\n", dev_name, strerror (errno));
  9. exit(EXIT_FAILURE);
  10. }
  11. MYLOGD("the fd of %s is %d ", dev_name, fd);
  12. return fd;
  13. }

2,初始化camera,设置camera输出图像的格式

  1. static int init_cam_device(int dev_fd)
  2. {
  3. int ret = -1;
  4. int input_index;
  5. //ret = fimc_v4l2_querycap(dev_fd);
  6. //assert(ret == 0);
  7. //获取到输入源通道
  8. input_index = cam_v4l2_enuminput(dev_fd);
  9. assert(input_index == 0);
  10. ret = cam_v4l2_s_input(dev_fd, input_index);
  11. assert(ret == 0);
  12. MYLOGD("VIDIOC_S_FMT start... dev_fd = %d\n", dev_fd);
  13. ret = cam_v4l2_s_format(dev_fd, IMAGE_HEIGHT, IMAGE_WIDTH, V4L2_PIX_FMT_YUYV);
  14. assert(ret == 0);
  15. ret = cam_v4l2_g_fmt(dev_fd);
  16. assert(ret == 0);
  17. init_cam_mmap(dev_fd);
  18. return 1;
  19. }

4,向内核申请buffer,并将buffer映射mmap到引用空间

struct buffer
{
  void *start; //mmap后的地址;
  size_t length//大小;
}user_buffers[4]; //用于记录将内核buffer映射mmap到用户空间的地址和大小

//申请4个buffer

cam_v4l2_reqbuf(dev_fd, 4);
//查询申请到的buffer信息,比如每个buffer的其实位置和大小

cam_v4l2_querybuf(dev_fd, &buf, buf_index);

//将buffer映射到用户空间

user_buffers[buf_index].length = buf.length;

user_buffers[buf_index].start = mmap(NULL   buf.length,
      PROT_READ | PROT_WRITE /* required */ ,
      MAP_SHARED /* recommended */ ,
      dev_fd, buf.m.offset);

注释  :  NULL: /* start anywhere */

buf.length: buffer在内核的地址

buf.m.offset:内核中的buffer大小

5,将所有的buffer全部放到循环工作队列中,集中管理

for (i = 0; i < max_buffers; ++i)
{
cam_v4l2_qbuf(dev_fd, i);
}

6,开始获取图像:

ioctl(dev_fd, VIDIOC_STREAMON, &type);

7,通过select来监控camera数据是否准备好

FD_ZERO (&rd_set);
FD_SET (dev_fd, &rd_set);

ret = select(maxfd + 1, &rd_set, NULL, NULL, NULL);

if(FD_ISSET(dev_fd, &rd_set))//如果camera准备好,就可以去读数据了

read_frame(dev_fd)

8,read_frame(dev_fd)的实现:

//select仅仅是知道有数据可以读了,但是在多个buffer中,

//不知道是哪个buffer准备好了,所以将准备好的buffer出队列,从而知道buffer的编号

int index = cam_v4l2_dqbuf(dev_fd);

//将buffer中的yuv420数据转换成rgb565,

//因为lcd是没办法显示yuv的,所以需要将yuv转换成rgb565

yuyv_to_rgb(src_address, data_buf);

//将转换好的rgb565数据方到framebuffer中去显示

show_rgb565_img(data_buf, LCD_WIDTH, LCD_HEIGHT);

这个过程仅仅是将一个流程写下来了,每个函数都是封装了一次,没办法一一去写出来,

所以我会将源代码文件上传,给大家去下载。包含Android.mk

可以到这个链接下载:

http://download.csdn.net/detail/ldswfun/5208766

同时附上一些图片让大家去理解这个过程

android摄像头(camera)之 v4l2的c测试代码【转】的更多相关文章

  1. android摄像头(camera)之buffer管理

    一,V4L2驱动申请buffer 视频应用可以通过两种方式从V4L2驱动申请buffer 1. V4L2_MEMORY_USERPTR方式, 顾名思义是用户空间指针的意思,应用层负责分配需要的内存空间 ...

  2. Android中直播视频技术探究之---采集摄像头Camera视频源数据进行推流(采用金山云SDK)

    一.前言 在之前已经详细介绍了Android中的一种视频数据源:Camera,不了解的同学可以点击进入:Android中Camera使用详解 ,在这篇文章中我们介绍了如何采集摄像头的每一帧数据,然后进 ...

  3. Android中直播视频技术探究之---摄像头Camera视频源数据采集解析

    一.前言 在视频直播中一般都是两种视频数据源,一个是摄像头数据,一个是录制桌面数据,而一般来说美女妹子直播都是来自于摄像头数据,游戏直播都是录制桌面数据的,那么今天就来看看第一个数据源数据采集分析,A ...

  4. Android Camera 通过V4L2与kernel driver的完整交互过程

    http://blog.chinaunix.net/uid-26215986-id-3552456.html 原文地址:Android Camera 通过V4L2与kernel driver的完整交互 ...

  5. 介绍 Android 的 Camera 框架

    总体介绍 Android Camera 框架从整体上看是一个 client/service 的架构,有两个进程:一个是 client 进 程,可以看成是 AP 端,主要包括 JAVA 代码与一些 na ...

  6. Android摄像头:只拍摄SurfaceView预览界面特定区域内容(矩形框)---完整(原理:底层SurfaceView+上层绘制ImageView)

    Android摄像头:只拍摄SurfaceView预览界面特定区域内容(矩形框)---完整实现(原理:底层SurfaceView+上层绘制ImageView) 分类: Android开发 Androi ...

  7. Android:Camera

    Android Camera开发 Android手机关于Camera的使用,一是拍照,二是摄像,由于Android提供了强大的组件功能,为此对于在Android手机系统上进行Camera的开发,我们可 ...

  8. Android USB Camera(1) : 调试记录【转】

    转自:http://blog.csdn.net/eternity9255/article/details/53069037 版权声明:本文为博主原创文章,未经博主允许不得转载. 目录(?)[-] 前言 ...

  9. android摄像头获取图像——第二弹

    使用android内的Camera对象 (1)Camera是控制着摄像头的api,拥有一系列控制摄像头的上层方法:camera类能够调用底层的摄像头接口,完成启动摄像头.预 览摄像头图像.拍照等功能: ...

随机推荐

  1. 【BZOJ1880】[Sdoi2009]Elaxia的路线(最短路)

    [BZOJ1880][Sdoi2009]Elaxia的路线(最短路) 题面 BZOJ 洛谷 题解 假装我们知道了任意两点间的最短路,那么我们怎么求解答案呢? 不难发现公共路径一定是一段连续的路径(如果 ...

  2. history新增方法

    history对象包含用户访问过的URL,属于window对象的一部分,传统的使用中,它拥有length属性(浏览器历史列表URL数目) 及back().forward().go()方法. 而新的H5 ...

  3. 调用Microsoft.Office.Interop.Word生成自定义Word文档

    具体思路: 1.先制作Word模版,使用文本框+书签的方式来设计模版: 2.模版制作完之后,根据模版生成新文件,使用File.Copy方法,生成.doc格式新文件: 3.后台取得数据,参照网页渲染的方 ...

  4. bracketed-paste-magic:zle:41: not enough arguments for -U

    原因是zsh的插件出问题了,解法方法如下: 把 ~/.oh-my-zsh/lib/misc.zsh 文件中的第一段 if 注释掉 OK 啦 # ]]; then # for d in $fpath; ...

  5. 【codeforces contest 1119 F】Niyaz and Small Degrees

    题目 描述 \(n\) 个点的树,每条边有一个边权: 对于一个 \(X\) ,求删去一些边后使得每个点的度数 \(d_i\) 均不超过 \(X\) 的最小代价: 你需要依次输出 \(X=0 \to n ...

  6. 【学习笔记 边分树】【uoj400】【CTSC2018】暴力写挂

    题目 描述 ​ 有两棵树\(T\)和\(T'\),节点个数都为\(n\),根节点都为\(1\)号节点; ​ 求两两点之间 $$ \begin{align} depth(x) + depth(y) - ...

  7. 【POJ1734】Sightseeing Trip 无向图最小环

    题目大意:给定一个 N 个顶点的无向图,边有边权,如果存在,求出该无向图的最小环,即:边权和最小的环,并输出路径. 题解:由于无向图,且节点数较少,考虑 Floyd 算法,在最外层刚开始遍历到第 K ...

  8. poj 2785(折半枚举+二分搜索)

    传送门:Problem 2785 题意: 给定 n 行数,每行都有 4 个数A,B,C,D. 要从每列中各抽取出一个数,问使四个数的和为0的所有方案数. 相同数字不同位置当作不同数字对待. 题解: 如 ...

  9. Centos7.2安装搜狗拼音

    方法一: Fedora 19/20/21/rawhide 使用以下命令添加源: # yum install dnf-plugins-core # dnf copr enable mosquito/my ...

  10. org.apache.catalina.LifecycleException: Failed to stop component(生命周期异常)

    真是郁闷透顶,以前昨天还可以用,换了myeclipse自带的tomcat就可以用: 异常: org.apache.catalina.LifecycleException: Failed to stop ...