5.OSD叠加学习之在YUV图片上显示 竖线横线斜线

2023-05-16

目录

  • 实现效果图:
  • 实现思路:
  • 代码编写

实现效果图:

在这里插入图片描述

实现思路:

无论是显示 竖线横线还是斜线,无非是对 多个连续的 像素点进行操作,明白了一个像素点如何点亮,加个循环偏移量,线也就成了。所以先来说说单个像素点。图片组成如图:

Y Y  Y Y  Y Y  Y Y 
Y Y  Y Y  Y Y  Y Y

Y Y  Y Y  Y Y  Y Y
Y Y  Y Y  Y Y  Y Y

U U U U U U U U
V V V V V V V V 

YUV420,Y:U: V = 4:1:1,也就是说,图中一起的4个Y 对应 下面的一组 UV(至于为什么是4:1:1,他就是这么规定的,俺也不知道),这四个Y 一个U 一个V 的组合对应 一个像素点。所以,我们要对一个像素点进行操作,就是对这个组合进行操作(至于YUV分别是什么,请移步本系列第一篇文章)。

这里先总结下本人刚开始接触时,遇到的认知错误(实属不应该),一开始对格式的认知错误,以为是一行中连续四个Y,对应一组UV。这就导致了,在代码实现的时候,画第一条直线还是“正常”显示,无非就是画了两倍长的线,但一改变线的长度或位置,Y 和 UV 就对应不上了,这是显然的,因为正常是两行 Y 对应一行UV,但因为我的格式认知错误,写代码使 第二行Y 去对应第二行UV。导致越画越离谱。 所以说,地基不稳,房会倒。。。

回到主题,知道了怎么对像素点操作之后,一切就简单了,线的长度就是写的字节大小,线的宽度就是行数。调整字节数与行数的比例不就搞定 横线竖线,在加个斜率 就搞定斜线了。思路整完,搞代码!!

代码编写

/*横*/
int LUX_YUV_horizontal(int x,int y,int pointlength,char *pColourData)
{
    int xData          = 0;
    int yData          = 0;
    int yColorPoint    = yData*LUX_YUV_WIDTH;
    int uColorPoint    = LUX_Y_ALL_SIZE;
    int vColorPoint    = LUX_YU_ALL_SIZE;
    const int yAddNum  = 4;
    
    int i = 0;

    for(int pointWidth = 0 ;pointWidth < pointThickness;pointWidth++)
    {
        if(y+pointWidth%2)
        {
            memset(pColourData + x*2 + (y+pointWidth)*LUX_YUV_WIDTH,128,pointlength*2);
            memset(pColourData + uColorPoint + x + (y+pointWidth)/2*960,100,pointlength);
            memset(pColourData + vColorPoint + x + (y+pointWidth)/2*960,100,pointlength);
        }
        
    }
   
    


    return 0;
}
/*竖*/
int LUX_YUV_vertical(int x,int y,int pointlength,char *pColourData)
{
    int xData          = 0;
    int yData          = 0;
    int yColorPoint    = yData*LUX_YUV_WIDTH;
    int uColorPoint    = LUX_Y_ALL_SIZE;
    int vColorPoint    = LUX_YU_ALL_SIZE;
    const int yAddNum  = 4;
    


#if 1
    for(int pointWidth = 0 ;pointWidth < pointlength*2;pointWidth++)
    {
        if(y+pointWidth%2)
        {
            memset(pColourData + x * 2 + (y+pointWidth)*1920,128,pointThickness);
            memset(pColourData + uColorPoint + x + (y+pointWidth)/2*960,100,pointThickness/2);
            memset(pColourData + vColorPoint + x + (y+pointWidth)/2*960,100,pointThickness/2);
        }
              
    }
    
#endif


    return 0; 
}

/*撇*/
int LUX_YUV_Skimming(int x,int y,int pointlength,char *pColourData)
{
    int xData          = 0;
    int yData          = 0;
    int yColorPoint    = LUX_YUV_WIDTH;
    int uColorPoint    = LUX_Y_ALL_SIZE;
    
    int vColorPoint    = LUX_YU_ALL_SIZE;
    const int yAddNum  = 4;
    


#if 1
    for(int pointWidth = 0 ;pointWidth < pointlength*2;pointWidth++)
    {
        
        memset(pColourData + x * 2 + pointWidth + (y+pointWidth)*yColorPoint,128,pointThickness);
        memset(pColourData + uColorPoint + x + pointWidth/2 + (y+pointWidth)/2*960,100,pointThickness/2); 
        memset(pColourData + vColorPoint + x + pointWidth/2 + (y+pointWidth)/2*960,100,pointThickness/2);  
             
    }
    
#endif

}
/*捺*/
int LUX_YUV_holdHown(int x,int y,int pointlength,char *pColourData)
{
    int xData          = 0;
    int yData          = 0;
    int yColorPoint    = yData*LUX_YUV_WIDTH;
    int uColorPoint    = LUX_Y_ALL_SIZE;
    int vColorPoint    = LUX_YU_ALL_SIZE;
    const int yAddNum  = 4;
  

#if 1
   for(int pointWidth = 0 ;pointWidth < pointlength*2;pointWidth++)
    {
        
        memset(pColourData + x * 2 - pointWidth + (y+pointWidth)*1920,128,pointThickness);
        memset(pColourData + uColorPoint + x - pointWidth/2 + (y+pointWidth)/2*960,100,pointThickness/2); 
        memset(pColourData + vColorPoint + x - pointWidth/2 + (y+pointWidth)/2*960,100,pointThickness/2);      
             
    }
    
#endif

    return 0;
}

注:整个工程在最后一起上传。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

5.OSD叠加学习之在YUV图片上显示 竖线横线斜线 的相关文章

  • 12.RTT-IIC设备-AHT10温湿度传感器

    本系列博客更新结束啦 xff01 完结啦 xff01 xff01 xff01 撒花 xff01 xff01 xff01 关于RTT的设备和驱动专题更新完毕啦 xff0c 本期是最后一期 一段学习旅途的结束意味着下一段学习冒险的开始 虽然本系
  • RTduino+sht31温湿度传感器

    本次博客使用的是STM32F103C8T6 xff0c 因为该BSP已经对接好RTduino了可以直接上手使用 一 RTduino简介 RTduino是RT Thread实时操作系统的Arduino生态兼容层 xff0c 为RT Threa
  • 一文揭秘字节跳动、华为、京东的薪资职级

    声明 xff1a 本文所有数字均不是官方数据 xff0c 为网络资料收集整理 字节跳动 01 全球员工总数 字节的员工数量目前超过5万人 图片来源 xff1a 字节范 02 岗位职级 字节跳动的职级研发序列一共10级 xff1a 字节跳动创
  • ESP_C3在ubuntu下运行RT-Thread

    1 clone源代码RT Thread git clone git 64 github com RT Thread rt thread git 2 开始搭建ESP IDF环境 进入源码到bsp文件夹下找到ESP32 C3 xff0c 开始配
  • uniapp中使用弹出层

    uniapp中使用弹出层 因为业务的需要 xff0c 需要弹出一个复选框 xff0c 使用uniapp中自带的框架 使用 xff1a 第一步 xff1a 下载下示例项目 xff0c 找到主要的文件夹 第二步 xff1a 将该文件夹放到组件的
  • 手写一个uniapp的步骤条组件

    span class token operator lt span template span class token operator gt span span class token operator lt span view span
  • uniapp中的分页

    数据量过多就会使用分页 第一种 xff1a API span class token comment 和data同级 span span class token function variable function onReachBotto
  • uniapp中生成随机的二维码并进行保存

    需求 xff1a 需要根据用户id的不同生成不同的二维码 xff0c 并进行本地保存 第一步 xff1a 下载插件 这里对于二维码的生成 xff0c 使用的是第三方插件weapp qrcode min js xff0c 主要用到的文件是 d
  • Pc端的基本Echarts

    Pc端的基本Echarts 双环传态图组件 span class token operator lt span template span class token operator gt span span class token oper
  • el-table表格的sortable排序的使用以及出现小数、%排序错乱

    前端实现排序 xff1a 只需要在表头上加上一个sortable属性即可 span class token tag span class token tag span class token punctuation lt span el t
  • 浏览器的回退和导航栏的选中转态不同步,路由在新窗口打开

    问题1 xff1a 浏览器的回退和导航栏的选中状态不能同步的问题 问题 xff1a 用户后退时候 xff0c 左边导航栏显示的还是上一个页面的导航 xff0c 但是路由和页面已经变了 span class token operator lt
  • 左右联动-左侧点击相应的位置,右侧随之滚动

    第一步 xff1a npm下载 npm install better scroll save 第二步 xff1a 局部注册 xff08 当前组件 xff09 span class token keyword import span BScr
  • 杂技-各种css小技巧

    渐变字体 background image webkit linear gradient bottom 379ED7 0FE2EE webkit background clip text webkit text fill color tra
  • 深入理解Kotlin无参构造函数

    Unsafe 创建实例 在java中 创建一个对象 其实主要就是3种方法 通过new 关键字来创建 这种是最常见的 通过反射构造方法来创建对象 这种也不少见 很多框架中都有使用 Unsafe类来创建实例 xff0c 这种情况非常少见 这里先
  • VScode 快捷键

    一 VScode 快捷键 这里主要记录是 VScode开发工具常用的快捷键 xff0c 以便提高工作效率 xff0c 以及今后方便查阅 xff01 xff01 xff01 SHIFT 43 ALT 43 I 在选定的每行末尾插入光标CTRL
  • 结构体与共用体 链表 编译预处理

    结构图和共同体 单科成绩分析统计程序 题目要求 xff1a 1 输入学生个数 成绩 2 计算平均分 最高分 最低分 3 计算各个分数段人数并计算平均分 4 排序从高到低 刚开始计算各分段人数时是这样写的 排序是这样写的 发现case2 ca
  • 【已解决】terminate called after throwing an instance of ‘cv::Exception‘,已放弃 (核心已转储)

    这是运行高翔slambook2的代码出现的错误 terminate called after throwing an instance of cv Exception what OpenCV 3 4 15 home diyu opencv
  • C语言打印文件中指定位置所在行内容

    函数说明 void PrintFileOfPosition int position file char src file xff0c 参数1为指定位置 xff0c 参数2为文件名 文件读取方式为行读取 xff0c 所以读完一行要记录该行字
  • C语言中屏蔽空格和吐出getchar吃掉的字符实例

    屏蔽空格 新的改变功能快捷键合理的创建标题 xff0c 有助于目录的生成如何改变文本的样式插入链接与图片如何插入一段漂亮的代码片生成一个适合你的列表创建一个表格设定内容居中 居左 居右SmartyPants 创建一个自定义列表如何创建一个注
  • Object类(所有类的父类)

    文章目录 前言一 Object类1 1概述1 2 Object常用方法1 3 Object类型变量1 4 Objects类注意事项 总结 前言 提示 xff1a 常用类学习篇 xff0c 掌握节奏就变得简单易懂了 xff0c 没有甚么特别难

随机推荐