常用YUV转RGB代码
常用YUV转RGB
- public class YuvToRGB {
- private static int R = 0;
- private static int G = 1;
- private static int B = 2;
- //I420是yuv420格式,是3个plane,排列方式为(Y)(U)(V)
- public static int[] I420ToRGB(byte[] src, int width, int height){
- int numOfPixel = width * height;
- int positionOfV = numOfPixel;
- int positionOfU = numOfPixel/4 + numOfPixel;
- int[] rgb = new int[numOfPixel*3];
- for(int i=0; i<height; i++){
- int startY = i*width;
- int step = (i/2)*(width/2);
- int startU = positionOfV + step;
- int startV = positionOfU + step;
- for(int j = 0; j < width; j++){
- int Y = startY + j;
- int U = startU + j/2;
- int V = startV + j/2;
- int index = Y*3;
- RGB tmp = yuvTorgb(src[Y], src[U], src[V]);
- rgb[index+R] = tmp.r;
- rgb[index+G] = tmp.g;
- rgb[index+B] = tmp.b;
- }
- }
- return rgb;
- }
- private static class RGB{
- public int r, g, b;
- }
- private static RGB yuvTorgb(byte Y, byte U, byte V){
- RGB rgb = new RGB();
- rgb.r = (int)((Y&0xff) + 1.4075 * ((V&0xff)-128));
- rgb.g = (int)((Y&0xff) - 0.3455 * ((U&0xff)-128) - 0.7169*((V&0xff)-128));
- rgb.b = (int)((Y&0xff) + 1.779 * ((U&0xff)-128));
- rgb.r =(rgb.r<0? 0: rgb.r>255? 255 : rgb.r);
- rgb.g =(rgb.g<0? 0: rgb.g>255? 255 : rgb.g);
- rgb.b =(rgb.b<0? 0: rgb.b>255? 255 : rgb.b);
- return rgb;
- }
- //YV16是yuv422格式,是三个plane,(Y)(U)(V)
- public static int[] YV16ToRGB(byte[] src, int width, int height){
- int numOfPixel = width * height;
- int positionOfU = numOfPixel;
- int positionOfV = numOfPixel/2 + numOfPixel;
- int[] rgb = new int[numOfPixel*3];
- for(int i=0; i<height; i++){
- int startY = i*width;
- int step = i*width/2;
- int startU = positionOfU + step;
- int startV = positionOfV + step;
- for(int j = 0; j < width; j++){
- int Y = startY + j;
- int U = startU + j/2;
- int V = startV + j/2;
- int index = Y*3;
- //rgb[index+R] = (int)((src[Y]&0xff) + 1.4075 * ((src[V]&0xff)-128));
- //rgb[index+G] = (int)((src[Y]&0xff) - 0.3455 * ((src[U]&0xff)-128) - 0.7169*((src[V]&0xff)-128));
- //rgb[index+B] = (int)((src[Y]&0xff) + 1.779 * ((src[U]&0xff)-128));
- RGB tmp = yuvTorgb(src[Y], src[U], src[V]);
- rgb[index+R] = tmp.r;
- rgb[index+G] = tmp.g;
- rgb[index+B] = tmp.b;
- }
- }
- return rgb;
- }
- //YV12是yuv420格式,是3个plane,排列方式为(Y)(V)(U)
- public static int[] YV12ToRGB(byte[] src, int width, int height){
- int numOfPixel = width * height;
- int positionOfV = numOfPixel;
- int positionOfU = numOfPixel/4 + numOfPixel;
- int[] rgb = new int[numOfPixel*3];
- for(int i=0; i<height; i++){
- int startY = i*width;
- int step = (i/2)*(width/2);
- int startV = positionOfV + step;
- int startU = positionOfU + step;
- for(int j = 0; j < width; j++){
- int Y = startY + j;
- int V = startV + j/2;
- int U = startU + j/2;
- int index = Y*3;
- //rgb[index+R] = (int)((src[Y]&0xff) + 1.4075 * ((src[V]&0xff)-128));
- //rgb[index+G] = (int)((src[Y]&0xff) - 0.3455 * ((src[U]&0xff)-128) - 0.7169*((src[V]&0xff)-128));
- //rgb[index+B] = (int)((src[Y]&0xff) + 1.779 * ((src[U]&0xff)-128));
- RGB tmp = yuvTorgb(src[Y], src[U], src[V]);
- rgb[index+R] = tmp.r;
- rgb[index+G] = tmp.g;
- rgb[index+B] = tmp.b;
- }
- }
- return rgb;
- }
- //YUY2是YUV422格式,排列是(YUYV),是1 plane
- public static int[] YUY2ToRGB(byte[] src, int width, int height){
- int numOfPixel = width * height;
- int[] rgb = new int[numOfPixel*3];
- int lineWidth = 2*width;
- for(int i=0; i<height; i++){
- int startY = i*lineWidth;
- for(int j = 0; j < lineWidth; j+=4){
- int Y1 = j + startY;
- int Y2 = Y1+2;
- int U = Y1+1;
- int V = Y1+3;
- int index = (Y1>>1)*3;
- RGB tmp = yuvTorgb(src[Y1], src[U], src[V]);
- rgb[index+R] = tmp.r;
- rgb[index+G] = tmp.g;
- rgb[index+B] = tmp.b;
- index += 3;
- tmp = yuvTorgb(src[Y2], src[U], src[V]);
- rgb[index+R] = tmp.r;
- rgb[index+G] = tmp.g;
- rgb[index+B] = tmp.b;
- }
- }
- return rgb;
- }
- //UYVY是YUV422格式,排列是(UYVY),是1 plane
- public static int[] UYVYToRGB(byte[] src, int width, int height){
- int numOfPixel = width * height;
- int[] rgb = new int[numOfPixel*3];
- int lineWidth = 2*width;
- for(int i=0; i<height; i++){
- int startU = i*lineWidth;
- for(int j = 0; j < lineWidth; j+=4){
- int U = j + startU;
- int Y1 = U+1;
- int Y2 = U+3;
- int V = U+2;
- int index = (U>>1)*3;
- RGB tmp = yuvTorgb(src[Y1], src[U], src[V]);
- rgb[index+R] = tmp.r;
- rgb[index+G] = tmp.g;
- rgb[index+B] = tmp.b;
- index += 3;
- tmp = yuvTorgb(src[Y2], src[U], src[V]);
- rgb[index+R] = tmp.r;
- rgb[index+G] = tmp.g;
- rgb[index+B] = tmp.b;
- }
- }
- return rgb;
- }
- //NV21是YUV420格式,排列是(Y), (VU),是2 plane
- public static int[] NV21ToRGB(byte[] src, int width, int height){
- int numOfPixel = width * height;
- int positionOfV = numOfPixel;
- int[] rgb = new int[numOfPixel*3];
- for(int i=0; i<height; i++){
- int startY = i*width;
- int step = i/2*width;
- int startV = positionOfV + step;
- for(int j = 0; j < width; j++){
- int Y = startY + j;
- int V = startV + j/2;
- int U = V + 1;
- int index = Y*3;
- RGB tmp = yuvTorgb(src[Y], src[U], src[V]);
- rgb[index+R] = tmp.r;
- rgb[index+G] = tmp.g;
- rgb[index+B] = tmp.b;
- }
- }
- return rgb;
- }
- //NV12是YUV420格式,排列是(Y), (UV),是2 plane
- public static int[] NV12ToRGB(byte[] src, int width, int height){
- int numOfPixel = width * height;
- int positionOfU = numOfPixel;
- int[] rgb = new int[numOfPixel*3];
- for(int i=0; i<height; i++){
- int startY = i*width;
- int step = i/2*width;
- int startU = positionOfU + step;
- for(int j = 0; j < width; j++){
- int Y = startY + j;
- int U = startU + j/2;
- int V = U + 1;
- int index = Y*3;
- RGB tmp = yuvTorgb(src[Y], src[U], src[V]);
- rgb[index+R] = tmp.r;
- rgb[index+G] = tmp.g;
- rgb[index+B] = tmp.b;
- }
- }
- return rgb;
- }
- //NV16是YUV422格式,排列是(Y), (UV),是2 plane
- public static int[] NV16ToRGB(byte[] src, int width, int height){
- int numOfPixel = width * height;
- int positionOfU = numOfPixel;
- int[] rgb = new int[numOfPixel*3];
- for(int i=0; i<height; i++){
- int startY = i*width;
- int step = i*width;
- int startU = positionOfU + step;
- for(int j = 0; j < width; j++){
- int Y = startY + j;
- int U = startU + j/2;
- int V = U + 1;
- int index = Y*3;
- RGB tmp = yuvTorgb(src[Y], src[U], src[V]);
- rgb[index+R] = tmp.r;
- rgb[index+G] = tmp.g;
- rgb[index+B] = tmp.b;
- }
- }
- return rgb;
- }
- //NV61是YUV422格式,排列是(Y), (VU),是2 plane
- public static int[] NV61ToRGB(byte[] src, int width, int height){
- int numOfPixel = width * height;
- int positionOfV = numOfPixel;
- int[] rgb = new int[numOfPixel*3];
- for(int i=0; i<height; i++){
- int startY = i*width;
- int step = i*width;
- int startV = positionOfV + step;
- for(int j = 0; j < width; j++){
- int Y = startY + j;
- int V = startV + j/2;
- int U = V + 1;
- int index = Y*3;
- RGB tmp = yuvTorgb(src[Y], src[U], src[V]);
- rgb[index+R] = tmp.r;
- rgb[index+G] = tmp.g;
- rgb[index+B] = tmp.b;
- }
- }
- return rgb;
- }
- //YVYU是YUV422格式,排列是(YVYU),是1 plane
- public static int[] YVYUToRGB(byte[] src, int width, int height){
- int numOfPixel = width * height;
- int[] rgb = new int[numOfPixel*3];
- int lineWidth = 2*width;
- for(int i=0; i<height; i++){
- int startY = i*lineWidth;
- for(int j = 0; j < lineWidth; j+=4){
- int Y1 = j + startY;
- int Y2 = Y1+2;
- int V = Y1+1;
- int U = Y1+3;
- int index = (Y1>>1)*3;
- RGB tmp = yuvTorgb(src[Y1], src[U], src[V]);
- rgb[index+R] = tmp.r;
- rgb[index+G] = tmp.g;
- rgb[index+B] = tmp.b;
- index += 3;
- tmp = yuvTorgb(src[Y2], src[U], src[V]);
- rgb[index+R] = tmp.r;
- rgb[index+G] = tmp.g;
- rgb[index+B] = tmp.b;
- }
- }
- return rgb;
- }
- //VYUY是YUV422格式,排列是(VYUY),是1 plane
- public static int[] VYUYToRGB(byte[] src, int width, int height){
- int numOfPixel = width * height;
- int[] rgb = new int[numOfPixel*3];
- int lineWidth = 2*width;
- for(int i=0; i<height; i++){
- int startV = i*lineWidth;
- for(int j = 0; j < lineWidth; j+=4){
- int V = j + startV;
- int Y1 = V+1;
- int Y2 = V+3;
- int U = V+2;
- int index = (U>>1)*3;
- RGB tmp = yuvTorgb(src[Y1], src[U], src[V]);
- rgb[index+R] = tmp.r;
- rgb[index+G] = tmp.g;
- rgb[index+B] = tmp.b;
- index += 3;
- tmp = yuvTorgb(src[Y2], src[U], src[V]);
- rgb[index+R] = tmp.r;
- rgb[index+G] = tmp.g;
- rgb[index+B] = tmp.b;
- }
- }
- return rgb;
- }
- }
常用YUV转RGB代码的更多相关文章
- 【视频处理】YUV与RGB格式转换
YUV格式具有亮度信息和色彩信息分离的特点,但大多数图像处理操作都是基于RGB格式. 因此当要对图像进行后期处理显示时,需要把YUV格式转换成RGB格式. RGB与YUV的变换公式如下: YUV(25 ...
- YUV到RGB的转换
以下内容来源于网络,下面三个链接里的内容是比较好的,感谢博主的分享. http://blog.csdn.net/housisong/article/details/1859084 http://blo ...
- YUV和RGB格式分析
做嵌入式项目的时候,涉及到YUV视频格式到RGB图像的转换,虽然之前有接触到RGB到都是基于opencv的处理,很多东西并不需要我们过多深入的去探讨,现在需要完全抛弃现有的算法程序,需要从内存中一个字 ...
- 图像色彩空间YUV和RGB的差别
http://blog.csdn.net/scg881008/article/details/7168637 假如是200万像素的sensor,是不是RGB一个pixel是2M,YUV是1M? 首先, ...
- 最简单的视音频播放演示样例3:Direct3D播放YUV,RGB(通过Surface)
===================================================== 最简单的视音频播放演示样例系列文章列表: 最简单的视音频播放演示样例1:总述 最简单的视音频 ...
- YUV和RGB格式分析【转】
转自:http://www.cnblogs.com/silence-hust/p/4465354.html 做嵌入式项目的时候,涉及到YUV视频格式到RGB图像的转换,虽然之前有接触到RGB到都是基于 ...
- YUV与RGB格式转换
YUV格式具有亮度信息和色彩信息分离的特点,但大多数图像处理操作都是基于RGB格式. 因此当要对图像进行后期处理显示时,需要把YUV格式转换成RGB格式. RGB与YUV的变换公式如下: YUV(25 ...
- 【图像处理与医学图像处理】YUV与RGB格式转换速度几种方法对比
[视频处理]YUV与RGB格式转换 YUV格式具有亮度信息和色彩信息分离的特点,但大多数图像处理操作都是基于RGB格式. 因此当要对图像进行后期处理显示时,需要把YUV格式转换成RGB格式. RGB与 ...
- 【DSP开发】【VS开发】YUV与RGB格式转换
[视频处理]YUV与RGB格式转换 YUV格式具有亮度信息和色彩信息分离的特点,但大多数图像处理操作都是基于RGB格式. 因此当要对图像进行后期处理显示时,需要把YUV格式转换成RGB格式. RGB与 ...
随机推荐
- SDP(4):ScalikeJDBC- JDBC-Engine:Updating
在上一篇博文里我们把JDBC-Engine的读取操作部分分离出来进行了讨论,在这篇准备把更新Update部分功能介绍一下.当然,JDBC-Engine的功能是基于ScalikeJDBC的,所有的操作和 ...
- Spark Streaming编程指南
Overview A Quick Example Basic Concepts Linking Initializing StreamingContext Discretized Streams (D ...
- BZOJ 4195: [Noi2015]程序自动分析 [并查集 离散化 | 种类并查集WA]
题意: 给出若干相等和不等关系,判断是否可行 woc NOI考这么傻逼的题飞快打了一个种类并查集交上了然后爆零... 发现相等和不等看错了异或一下再叫woc90分 然后发现md$a \neq b, a ...
- 洛谷 P3672 小清新签到题 [DP 排列]
传送门 题意:给定自然数n.k.x,你要求出第k小的长度为n的逆序对对数为x的1~n的排列 $n \le 300, k \le 10^13$ 一下子想到hzc讲过的DP 从小到大插入,后插入不会对前插 ...
- HDU 4333 [SAM WRONG!!!]
题意:给一个数字,每一次把它的最后一位拿到最前面,一直那样下去,分别求形成的数字小于,等于和大于原来数的个数. SAM上就是走n步 相等好好做啊,但是大于小于不好做啊,用类似弦论的思想也不能处理出怎样 ...
- BZOJ 3040: 最短路(road) [Dijkstra + pb_ds]
3040: 最短路(road) Time Limit: 60 Sec Memory Limit: 200 MBSubmit: 2476 Solved: 814[Submit][Status][Di ...
- HibernateTemplate#setMaxResults()的坑
如题所示,因为maxResults为实例属性,一经修改,则会应用于所有查询! 不是很清楚,Spring为什么要挖这个坑? 我的解决方案:如需设置返回结果集的大小,则通过HibernateCallbac ...
- 自己动手实践 spring retry 重试框架
前序 马上过年了,预祝大家,新年快乐,少写bug 什么是spring retry? spring retry是从spring batch独立出来的一个能功能,主要实现了重试和熔断. 什么时候用? 远程 ...
- SDN第四次上机作业
1.建立以下拓扑,并连接上ODL控制器. 2.利用ODL下发流表,使得h3在10s内ping不通h1,10s后恢复. 3.借助Postman通过ODL的北向接口下发流表,再利用ODL北向接口查看已下发 ...
- linux内核链表的使用
linux内核链表:链表通常包括两个域:数据域和指针域.struct list_head{struct list_head *next,*prev;};include/linux/list.h中实现了 ...
