10v转16v_nv12和nv21区别

10v转16v_nv12和nv21区别摘要关于像素格式转换,搜到的帖子基本是NV16转RGB24或NV12转RGB24,对于NV16转NV12并没太多资料,因此我打算参照这两个像素格式的结构,实现这个转换接口。NV16像素格式介绍NV16可以理解为yuyv像素格式的变种,属于YUV422SP类型。整帧图像的大小为Width*Height*2。其像素格式如下:start+00: Y’00 Y’01 Y’02 …

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

摘要

关于像素格式转换,搜到的帖子基本是NV16转RGB24 或 NV12转RGB24,对于NV16转NV12并没太多资料,因此我打算参照这两个像素格式的结构,实现这个转换接口。

NV16像素格式介绍

NV16可以理解为yuyv像素格式的变种,属于YUV422SP类型。整帧图像的大小为 Width * Height * 2。其像素格式如下:

  • start + 00: Y00 Y01 Y02 Y03
  • start + 04: Y10 Y11 Y12 Y13
  • start + 08: Y20 Y21 Y22 Y23
  • start + 12: Y30 Y31 Y32 Y33
  • start + 16: Cb00 Cr00 Cb01 Cr01
  • start + 20: Cb10 Cr10 Cb11 Cr11
  • start + 24: Cb20 Cr20 Cb21 Cr21
  • start + 28: Cb30 Cr30 Cb31 Cr31

NV12像素格式介绍

NV12则属于YUV420SP类型,整帧图像的大小为 Width * Height * 3 / 2。其像素格式如下:

  • start + 00: Y00 Y01 Y02 Y03
  • start + 04: Y10 Y11 Y12 Y13
  • start + 08: Y20 Y21 Y22 Y23
  • start + 12: Y30 Y31 Y32 Y33
  • start + 16: Ub00 Ur00 Ub01 Ur01
  • start + 20: Ub10 Ur10 Ub11 Ur11

转换规则介绍

  • Y数据直接拷贝。
  • NV12的 Ubxx取值NV16奇数行的Cbxx
  • NV12的 Urxx取值NV16偶数行的Crxx

例如:

NV16              NV12
Cb00 Cb01  ----> Ub00 Ub01
Cr10 Cr11  ----> Vr00 Vr01
Cb20 Cb21  ----> Ub10 Ub11
Cr30 Cr31  ----> Vr10 Vr11

代码

#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <errno.h>

/** * 功能:nv16像素格式转换为nv12像素格式 * 参数介绍: * nv16_buff:NV16格式一帧数据,大小为 w * h * 2,作为函数输入。 * nv12_buff:NV12格式的一帧数据,大小为 w * h * 3 / 2,作为函数输出。 * w:图像的宽度。 * h:图像高度。 */
int pixel_format_nv16_to_nv12(char *nv16_buff, char *nv12_buff, int w, int h)
{ 
   
	unsigned char *nv16_y = NULL;
	unsigned char *nv16_uv = NULL;
	unsigned char *nv12_y = NULL;
	unsigned char *nv12_u = NULL;
	unsigned char *nv12_v = NULL;
	int i, j, offset;

	if (!nv16_buff || !nv12_buff || ((w*h) <= 0)) { 
   
		printf("ERROR: %s input args invalid!\n", __func__);
		return -EINVAL;
	}

	/* get the right point */
	nv16_y = (unsigned char *)nv16_buff;
	nv16_uv = (unsigned char *)nv16_buff + w * h;
	nv12_y = (unsigned char *)nv12_buff;
	nv12_u = (unsigned char *)nv12_buff + w * h;
	nv12_v = nv12_u + 1;

	/* copy y dates directly */
	memcpy(nv12_y, nv16_y, w * h);
	/* get nv12_uv dates from nv16_uv * * >>>> nv16 pix formate: * start + 0: Y'00 Y'01 Y'02 Y'03 * start + 4: Y'10 Y'11 Y'12 Y'13 * start + 8: Y'20 Y'21 Y'22 Y'23 * start + 12: Y'30 Y'31 Y'32 Y'33 * start + 16: Cb00 Cr00 Cb01 Cr01 * start + 20: Cb10 Cr10 Cb11 Cr11 * start + 24: Cb20 Cr20 Cb21 Cr21 * start + 28: Cb30 Cr30 Cb31 Cr31 * * >>>> nv12 pix formate: * start + 0: Y'00 Y'01 Y'02 Y'03 * start + 4: Y'10 Y'11 Y'12 Y'13 * start + 8: Y'20 Y'21 Y'22 Y'23 * start + 12: Y'30 Y'31 Y'32 Y'33 * start + 16: Ub00 Vr00 * start + 18: Ub01 Vr01 * start + 20: Ub10 Vr10 * start + 22: Ub11 Vr11 * * nv16的uv分量与 nv12的uv分量对于关系: * 偶数行取Cb值,奇数行取Cr值 * Cb00 Cb01 ----> Ub00 Ub01 * Cr10 Cr11 ----> Vr00 Vr01 * Cb20 Cb21 ----> Ub10 Ub11 * Cr30 Cr31 ----> Vr10 Vr11 */

	/* 奇数行取Cb */
	offset = 0;
	for (i = 0; i < h; i+=2) { 
   
		offset = i * w;
		for (j = 0; j < w; j+=2) { 
   
			*nv12_u = *(nv16_uv + offset + j);
			nv12_u += 2;
		}
	}

	/* 偶数行取Cr */
	offset = 0;
	for (i = 1; i < h; i+=2) { 
   
		offset = i * w;
		for (j = 1; j < w; j+=2) { 
   
			*nv12_v = *(nv16_uv + offset + j);
			nv12_v += 2;
		}
	}

	return 0;
}

工程下载地址

工程地址:https://download.csdn.net/download/lyy901135/11458140

完整工程,包含main函数,以及测试输入的nv16图片,只需执行make编译后即可运行。

运行命令:./nv16_to_nv12 test.nv16 test.nv12

查看输出图片(nv12):ffplay -f rawvideo -video_size 1920x1080 -pixel_format nv12 test.nv12
由图可见,转换后色度都是正确的。
在这里插入图片描述

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/189897.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • LSTM详解 反向传播公式推导[通俗易懂]

    LSTM详解 反向传播公式推导[通俗易懂]部分参考:http://colah.github.io/posts/2015-08-Understanding-LSTMs/1.结构1.1比较RNN:LSTM:其中的notation:1.2核心思想:LSTM在原来的隐藏层上增加了一个ThekeytoLSTMsisthecellstate,thehorizont…

  • accept-encoding导致乱码问题

    accept-encoding导致乱码问题Accept-Encoding:gzip,deflate这个头信息是告诉服务器客户端所支持的压缩方式(然而数据压缩了但没有自动转,就会导致乱码)没有这个头信息说明客户端不支持压缩,要求不压缩直接返回文本

  • 河北对口计算机专业一分一档6,600分以上830人!河北一市中考一分一档表出炉!…

    河北对口计算机专业一分一档6,600分以上830人!河北一市中考一分一档表出炉!…出分啦!承德市2021年中考成绩公布6月30日,承德市教育考试招生信息平台公布2021年承德市中考成绩一分一档表!今年承德中考文化和体育是630分,理化实验20分,总计是650分。据一分一档表显示今年承德中考600分以上是830人2021年承德市中考成绩一分一档表除承德外河北其他地市什么时候能查分呢?有粉丝在后台问,衡水什么时候可以查分,这不,衡水市中考成绩发布时间也来啦~衡水市一、中考成绩发布时…

  • javascript性能优化_javascript框架是什么

    javascript性能优化_javascript框架是什么即使是循环中最快的代码,累计迭代上千次也会慢下来。此外,循环体运行时也会带来小性能开销,不仅仅是增加了总体运行时间。减少迭代次数能获得更加显著的性能提升,最广为人知的一种限制循环迭代次数的模式被称为“达夫设备(Duff’sDevice)”。Duff’sDevice是一种循环体展开技术,它使得一次迭代中实际执行了多次迭代的操作。一个典型的实现如下:

  • python selenium清除浏览器缓存[通俗易懂]

    python selenium清除浏览器缓存[通俗易懂]最近在做自动化测试的时候,由于重复进入登录页面多次,并且此页面在第一次进入的时候才会出现输入用户名和密码,之后进入时候由于登录过了就不会出现用户名和密码框了,所以没登录一次就清除一次浏览器的缓存,下面是清除浏览器缓存的代码fromseleniumimportwebdriverfromselenium.webdriver.common.keysimportKeysdriver=webdriver.Chrome()driver.get(‘chrome://settings/cl

  • 从零开始安装pytorch,并在pycharm中使用

    从零开始安装pytorch,并在pycharm中使用pytorch安装与使用步骤简述anaconda下载与安装anaconda环境配置anaconda安装pytorch包pycharm运行pytorch环境理解环境步骤简述pytorch是基于torch和Python语言的机器学习库。anaconda是环境与包的管理工具,pytorch的下载需要借助anaconda来完成。另外,安装的anaconda自带Python,因此没安装过Python的小伙伴也不必要再安装Python了。最后anaconda为我们提供了运行环境,为了编写程序的方便,我们还需要一款

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号