这个就是主程序的5个选择模式,其实大同小异,我们主要分析一下第一种标准模式的。

这个部分我们看到,其实就是初始化海思的sys和Vo,不是我们关注的重点,


海思的图像层和输出设备以及设备文件之间的绑定关系是这个样子的,所以我们也要对应起来。因为例子内部我们用到的是fb0,所以对应着g0和dhd0。这个是固定绑定关系,无需我们额外操作。


这个是开启了两个线程,分别做不同的事情,相关的参数解释上面也有,比较容易看懂。

进入到SAMPLE_HIFB_PANDISPLAY这个线程当中,我们看看里面都有些什么。算了直接上代码,上面有代码解析。
    /********************************
    * Step 1. open framebuffer device overlay 0
    **********************************/
    pstInfo->fd = open(file, O_RDWR, 0);//打开对应的设备
    if (pstInfo->fd < 0)
    {
        SAMPLE_PRT("open %s failed!\n", file);
        return HI_NULL;
    }

bShow = HI_FALSE;
    if (ioctl(pstInfo->fd, FBIOPUT_SHOW_HIFB, &bShow) < 0)//显示或隐藏该叠加层(此处为隐藏)
    {
        SAMPLE_PRT("FBIOPUT_SHOW_HIFB failed!\n");
        return HI_NULL;
    }
    /********************************
    * Step 2. set the screen original position
    **********************************/
    /* 2. set the screen original position */
    switch(pstInfo->ctrlkey)
    {
        case 3:
        {
            stPoint.s32XPos = 150;
            stPoint.s32YPos = 150;
        }
        break;
        default:
        {
            stPoint.s32XPos = 0;
            stPoint.s32YPos = 0;
        }
    }
    
    /*设置叠加层在屏幕上显示的起始点坐标*/
    if (ioctl(pstInfo->fd, FBIOPUT_SCREEN_ORIGIN_HIFB, &stPoint) < 0)
    {
        SAMPLE_PRT("set screen original show position failed!\n");
        close(pstInfo->fd);
        return HI_NULL;
    }

/********************************
    * Step 3. get the variable screen information
    获取屏幕的可变信息
    **********************************/
    if (ioctl(pstInfo->fd, FBIOGET_VSCREENINFO, &var) < 0)
    {
        SAMPLE_PRT("Get variable screen info failed!\n");
        close(pstInfo->fd);
        return HI_NULL;
    }

/* **********************************************************
    *Step 4. modify the variable screen info//改变可变信息
    *the screen size: IMAGE_WIDTH*IMAGE_HEIGHT//屏幕大小=宽*高
    * the virtual screen size: VIR_SCREEN_WIDTH*VIR_SCREEN_HEIGHT//虚拟
    *(which equals to VIR_SCREEN_WIDTH*(IMAGE_HEIGHT*2))
    *the pixel format: ARGB1555
    **************************************************************/
    SAMPLE_PRT("[Begin]\n");
    SAMPLE_PRT("wait 4 seconds\n");
    usleep(4 * 1000 * 1000);

switch (enClrFmt = pstInfo->enColorFmt)
    {
        //像素格式为argb8888,就是占4个字节,分别对应alp green...
        case HIFB_FMT_ARGB8888:
            var.transp = s_a32;
            var.red    = s_r32;
            var.green  = s_g32;
            var.blue   = s_b32;
            var.bits_per_pixel = 32;
            u32Color         = HIFB_RED_8888;
            enTdeClrFmt      = TDE2_COLOR_FMT_ARGB8888;
            g_osdColorFmt    = OSD_COLOR_FMT_RGB8888;
            break;
        default:
            var.transp = s_a16;
            var.red    = s_r16;
            var.green  = s_g16;
            var.blue   = s_b16;
            var.bits_per_pixel = 16;
            enClrFmt         = HIFB_FMT_ARGB1555;
            u32Color         = HIFB_RED_1555;
            enTdeClrFmt     = TDE2_COLOR_FMT_ARGB1555;
            break;
    }
    u32BytePerPixel    = var.bits_per_pixel/8;//因为是argb8888所以是32/8 如果是argb1555 16/8
    printf("u32BytePerPixel=%d\n", u32BytePerPixel);//这个的意思就是一个像素占几个字节
    switch(pstInfo->ctrlkey)
    {
        //{0,1,2,3}={1buffer, 2buffer, 0buffer pan display, 0buffer refresh}
        case 3://如果扩展参数为
        {
            var.xres_virtual = 48;//长,宽
            var.yres_virtual = 48;
            var.xres = 48;
            var.yres = 48;
        }
        break;
        default:
        {
            var.xres_virtual = u32Width;
            var.yres_virtual = u32Height * u32BytePerPixel;
            printf("var.yres_virtual=%d\n", var.yres_virtual);//其实就是最后一行的位置
            var.xres         = u32Width;
            var.yres         = u32Height;
        }
    }

var.activate       = FB_ACTIVATE_NOW;

/*********************************
    * Step 5. set the variable screen information
    ***********************************/
    if (ioctl(pstInfo->fd, FBIOPUT_VSCREENINFO, &var) < 0)//设置可变参数
    {
        SAMPLE_PRT("Put variable screen info failed!\n");
        close(pstInfo->fd);
        return HI_NULL;
    }

/**********************************
    * Step 6. get the fix screen information
    ************************************/
    //获取固定参数
    if (ioctl(pstInfo->fd, FBIOGET_FSCREENINFO, &fix) < 0)
    {
        SAMPLE_PRT("Get fix screen info failed!\n");
        close(pstInfo->fd);
        return HI_NULL;
    }
    u32FixScreenStride = fix.line_length;   /*fix screen stride*///最后一列的位置
    printf("u32FixScreenStride = fix.line_length=%d\n", u32FixScreenStride = fix.line_length);
    /***************************************
    * Step 7. map the physical video memory for user use
    ******************************************/
#ifdef __HuaweiLite__
    pShowScreen = fix.smem_start;
#else
    //把屏幕地址映射出来
    pShowScreen = mmap(HI_NULL, fix.smem_len, PROT_READ | PROT_WRITE, MAP_SHARED, pstInfo->fd, 0);
    if (MAP_FAILED == pShowScreen)
    {
        SAMPLE_PRT("mmap framebuffer failed!\n");
        close(pstInfo->fd);
        return HI_NULL;
    }
#endif
    //清空屏幕
    memset(pShowScreen, 0x0, fix.smem_len);

/* time to play*/
    bShow = HI_TRUE;
    if (ioctl(pstInfo->fd, FBIOPUT_SHOW_HIFB, &bShow) < 0)//显示出来(显示只看到背景)
    {
        SAMPLE_PRT("FBIOPUT_SHOW_HIFB failed!\n");
#ifndef __HuaweiLite__
        munmap(pShowScreen, fix.smem_len);
#endif
        close(pstInfo->fd);
        return HI_NULL;
    }
    #if 1
    /* Only for G0 or G1 */
    if (GRAPHICS_LAYER_G0 == pstInfo->layer || GRAPHICS_LAYER_G1 == pstInfo->layer)
    {
        for (i = 0; i < 1; i++)
        {
            if (i % 2)
            {
                var.yoffset = var.yres;
            }
            else
            {
                var.yoffset = 0;
            }
            //此处画出一个红色的box
            ptemp = (pShowScreen + var.yres * u32FixScreenStride * (i % 2));//当前显示地址+当前显示内存大小
            for (y = 100; y < 300; y++)//从100列开始  画长度300
            {
                for (x = 0; x < 300; x++)//从0行开始  画长度300
                {
                    if (HIFB_FMT_ARGB8888 == enClrFmt)
                    {
                        *((HI_U32*)ptemp + y * var.xres + x) = HIFB_RED_8888;
                    }else
                    {
                        *((HI_U16*)ptemp + y * var.xres + x) = HIFB_RED_1555;
                    }
                }
            }
            /*
            * Note : Not acting on ARGB8888, for ARGB8888 format image's alpha, you can change ptemp[x][y]'s value
            * HIFB_RED_8888 = 0xffff00000 means alpha=255(show),red.0x00ff0000 means alpha=0,red(hide).
            */
            SAMPLE_PRT("expected: the red box will appear!\n");
            sleep(2);
            //这些设置alp对rgb8888并不起作用
            stAlpha.bAlphaEnable = HI_TRUE;
            /*Alpha0 值,范围 0~255,默认为 255。在 RGB1555 格式
            下,当最高位为 0 时,选择该值作为 Alpha 叠加的 Alpha
            值。*/
            stAlpha.u8Alpha0     = 0x0;
            /*Alpha1 值,范围 0~255,默认为 255。在 RGB1:5:5:5 格式
            下,当最高位为 1 时,选择该值作为 Alpha 叠加的 Alpha
            值。*/
            stAlpha.u8Alpha1     = 0x0;

//也就是选择当前alp0=0x0 为叠加通道的透明度值,透明
            if (ioctl(pstInfo->fd, FBIOPUT_ALPHA_HIFB,  &stAlpha) < 0)
            {
                SAMPLE_PRT("Set alpha failed!\n");
                close(pstInfo->fd);
                return HI_NULL;
            }
            SAMPLE_PRT("expected: after set alpha = 0, the red box will disappear!\n");
            sleep(2);

stAlpha.u8Alpha0 = 0;
            stAlpha.u8Alpha1 = 0xFF;
            //不透明
            if (ioctl(pstInfo->fd, FBIOPUT_ALPHA_HIFB,  &stAlpha) < 0)
            {
                SAMPLE_PRT("Set alpha failed!\n");
                close(pstInfo->fd);
                return HI_NULL;
            }
            SAMPLE_PRT("expected:after set set alpha = 0xFF, the red box will appear again!\n");
            sleep(2);

SAMPLE_PRT("expected: the red box will erased by ----------------------------colorkey!\n");
            stColorKey.bKeyEnable = HI_TRUE;
            stColorKey.u32Key     = (enClrFmt==HIFB_FMT_ARGB8888 ? HIFB_RED_8888 : HIFB_RED_1555);
            //HIFB_RED_1555 0xFC00  1111110000000000  对应r值都为1,也就是透过红色
            s32Ret = ioctl(pstInfo->fd, FBIOPUT_COLORKEY_HIFB, &stColorKey);//使用此接口设置当前叠加层的 colorkey 功能
            if (s32Ret < 0)
            {
                SAMPLE_PRT("FBIOPUT_COLORKEY_HIFB failed!\n");
                close(pstInfo->fd);
                return HI_NULL;
            }
            sleep(2);
            SAMPLE_PRT("expected: the red box will appear again!\n");
            stColorKey.bKeyEnable = HI_FALSE;
            s32Ret = ioctl(pstInfo->fd, FBIOPUT_COLORKEY_HIFB, &stColorKey);//关闭关键色
            if (s32Ret < 0)
            {
                SAMPLE_PRT("FBIOPUT_COLORKEY_HIFB failed!\n");
                close(pstInfo->fd);
                return HI_NULL;
            }
            sleep(2);
        }
    }
    #endif

sleep(10);
    /* show bitmap */
    switch (pstInfo->ctrlkey)
    {
        /* 2 means none buffer and just for pan display.*/
        case 2:
        {
            /*change bmp*/
            printf("--------------------------------------\n");
            //打开mmz内存
            if (HI_FAILURE == HI_MPI_SYS_MmzAlloc(&g_Phyaddr, ((void**)&Viraddr),
                                                  NULL, NULL, 1920 * 1080 * u32BytePerPixel))
            {
                SAMPLE_PRT("allocate memory (maxW*maxH*%d bytes) failed\n",u32BytePerPixel);
                close(pstInfo->fd);
                return HI_NULL;
            }

s32Ret = HI_TDE2_Open();
            if (s32Ret < 0)
            {
                SAMPLE_PRT("HI_TDE2_Open failed :%d!\n", s32Ret);
                HI_M

3559A sample hifb解析相关推荐

  1. 海思3559A sample的整体架构

    sample的整体架构 1.sample的整体架构: sample中有很多个例程,所以有很多个main函数,common是通用性的主题函数,我们分析的是sample_venc 2.基本的架构是:ven ...

  2. 海思项目学习记录 -2、解析mmp的sample

    1.分析mmp的sample工程 注意:建立SI工程的时候注意要把外面的那个include文件夹加载进来 sample_venc的大体分析 (1)从main入手,main的传参分析 (2)几个基本概念 ...

  3. python解析xml+得到pascal voc xml格式用于目标检测+美化xml

    1.python解析xml img_path='./data/001.tif'xml_path='./xml/001.xml'img=cv2.imread(img_path)# cv2.imshow( ...

  4. 海思3536:kernel编译和mpp_single编译过程报错及解决方法

    ### 1.编译kernel 1.1 cd kernel/linux-3.10.y 1.2 cp arch/arm/configs/hi3536_full_defconfig.config 1.3 m ...

  5. YBTOJ:彩色圆环

    文章目录 前言 题目描述 Input Output Sample Input Sample Output 解析 代码 前言 尽信书,则不如无书 题目描述 Input 仅有一行,该行给出依次两个正整数N ...

  6. 海思开发板hi3559移植带opengl的qt并成功运行血泪史

    几个必不可少的流程:环境linux系统 1,安装海思交叉编译工具.2,编译qt库,配置qt编译构件,拷贝qt库到板子3,编译海思sdk(为编译gpu做准备).4,编译海思gpu kernel.5,修改 ...

  7. [图论]剑鱼行动:kruskal

    剑鱼行动 目录 剑鱼行动 Description Input Output Sample Input Sample Output 解析 难点 代码 Description 给出N个点的坐标,对它们建立 ...

  8. Perfetto工具集之traced_perf

    1.Perf工具概览 linux中包含了众多性能分析工具,perf(特指linux-tools perf)工具是2009年在linux内核2.6.31中引入的一个工具.它的主要功能是可以跟踪hardw ...

  9. OpenCORE原理和核心代码破解,增加AVI格式。

    OpenCORE原理和核心代码破解--1 一.OpenCORE整体结构 逻辑层主要由PVPlayer,PlayerDriver,PVPlayerEngine来组成,其中PVPlayer主要接受上层的操 ...

最新文章

  1. BPM实例分享:如何设置开窗高度与宽度?
  2. hibernate 高级映射 --张国亮总结第一季
  3. javascript 中的call和apply
  4. linux-basic(11)认识和学习bash
  5. oracle数据库中函数和存储过程中的区别
  6. ceph关闭同步之后的故障记录
  7. 手动编译包含两个import自写类的java类。
  8. python如何预测双色球信息_python预测下一期双色球号码【机器学习】
  9. java 产生无重复的随机数,Java程序生成无重复的随机数
  10. 面试题:用两个队列实现一个栈
  11. VC中CDockablePane使用心得
  12. spwm matlab仿真,H桥逆变器SPWMMATLAB仿真
  13. HBase eclipse开发环境搭建
  14. 男朋友该对女生说的23句话(转)
  15. 全国大学生数学建模大赛入门1——赛前准备及注意事项
  16. 什么是JIT,JDK17移除了JIT?
  17. 目标感强的人究竟有多厉害,我们采访了100位牛人
  18. 招商银行信用卡中心笔试编程题 - 整数乘积最大化
  19. 【Linux】linux的vim文件怎么全选复制、粘贴
  20. 全国(省,直辖市,自治区,特别行政区)映射集合

热门文章

  1. xampp 64位 php5.2,XAMPP 64位
  2. java Workbook接口 提供的方法
  3. scrapy 下载及处理文件和图片
  4. 2019高教杯数学建模B题赛后感
  5. 集线器,转发器,网桥,以太网交换机
  6. idea智能提示设置和修改提示快捷键
  7. 谷粒商城-基础篇-环境搭建(P1-P44)
  8. python中遍历列表和字典的方法
  9. Kubernetes集群中Pod间文件拷贝
  10. illustrator cs5 for mac 官方简体中文版 破解