版权声明:本文为博主原创文章,未经博主允许不得转载。欢迎大家积极评论,博主会一一答复!

最近有人在网上问我,YUV的值对应的颜色是如何的

下面给出YUV值对应的颜色关系

256张图512x512,每张对应的Y为0~255   每4x4对应的是同一颜色区域  横坐标 U  纵坐标V

yuv下载地址

http://download.csdn.net/detail/cabbage2008/9314683

这里截取了Y=0,10,20,60,128,250,255几张

Y=0

Y=10

Y=20

Y=60

Y=128

Y=250

Y=255

生成代码:

  1. #include <stdlib.h>
  2. #include <stdio.h>
  3. #include <string.h>
  4. typedef       void                Void;
  5. typedef       bool                Bool;
  6. typedef       int                 Int;
  7. typedef       unsigned char       UChar;
  8. typedef       UChar               Pel;        ///< 16-bit pixel type
  9. class TComPicYuv
  10. {
  11. private:
  12. // ------------------------------------------------------------------------------------------------
  13. //  YUV buffer
  14. // ------------------------------------------------------------------------------------------------
  15. Pel*  m_apiPicBufY;           ///< Buffer (including margin)
  16. Pel*  m_apiPicBufU;
  17. Pel*  m_apiPicBufV;
  18. // ------------------------------------------------------------------------------------------------
  19. //  Parameter for general YUV buffer usage
  20. // ------------------------------------------------------------------------------------------------
  21. Int   m_iPicWidth;            ///< Width of picture
  22. Int   m_iPicHeight;           ///< Height of picture
  23. public:
  24. TComPicYuv         ();
  25. virtual ~TComPicYuv();
  26. // ------------------------------------------------------------------------------------------------
  27. //  Memory management
  28. // ------------------------------------------------------------------------------------------------
  29. Bool  create      ( Int iPicWidth, Int iPicHeight );
  30. Void  destroy     ();
  31. Void  setYuv      (Pel pixelY,Pel pixelU,Pel pixelV);
  32. Void  setPixel    (int posX, int posY, int width, Pel pixelY,Pel pixelU,Pel pixelV);
  33. // ------------------------------------------------------------------------------------------------
  34. //  Get information of picture
  35. // ------------------------------------------------------------------------------------------------
  36. Pel*  getPicBufY  ()     { return m_apiPicBufY ; }
  37. Pel*  getPicBufU  ()     { return m_apiPicBufU ; }
  38. Pel*  getPicBufV  ()     { return m_apiPicBufV ; }
  39. Int   getWidth    ()     { return  m_iPicWidth;    }
  40. Int   getHeight   ()     { return  m_iPicHeight;   }
  41. Int   getStride   ()     { return  m_iPicWidth ;    }
  42. Int   getCStride  ()     { return  (m_iPicWidth >> 1); }
  43. };// END CLASS DEFINITION TComPicYuv
  44. TComPicYuv::TComPicYuv()
  45. {
  46. m_apiPicBufY      = NULL;   // Buffer (including margin)
  47. m_apiPicBufU      = NULL;
  48. m_apiPicBufV      = NULL;
  49. }
  50. TComPicYuv::~TComPicYuv()
  51. {
  52. }
  53. Bool TComPicYuv::create( Int iPicWidth, Int iPicHeight )
  54. {
  55. m_iPicWidth       = iPicWidth;
  56. m_iPicHeight      = iPicHeight;
  57. m_apiPicBufY      = (Pel*)malloc(m_iPicWidth * m_iPicHeight * sizeof(Pel));
  58. m_apiPicBufU      = (Pel*)malloc((m_iPicWidth >>1) * (m_iPicHeight>>1) * sizeof(Pel));
  59. m_apiPicBufV      = (Pel*)malloc((m_iPicWidth >>1) * (m_iPicHeight>>1) * sizeof(Pel));
  60. return true;
  61. }
  62. Void TComPicYuv::destroy()
  63. {
  64. if( m_apiPicBufY ){ free( m_apiPicBufY );    m_apiPicBufY = NULL; }
  65. if( m_apiPicBufU ){ free( m_apiPicBufU );    m_apiPicBufU = NULL; }
  66. if( m_apiPicBufV ){ free( m_apiPicBufV );    m_apiPicBufV = NULL; }
  67. }
  68. Void TComPicYuv::setYuv(Pel pixelY,Pel pixelU,Pel pixelV)
  69. {
  70. if( m_apiPicBufY ){ memset(m_apiPicBufY, pixelY,m_iPicWidth * m_iPicHeight * sizeof(Pel)) ; }
  71. if( m_apiPicBufU ){ memset(m_apiPicBufU, pixelU,(m_iPicWidth >>1) * (m_iPicHeight>>1) * sizeof(Pel)) ; }
  72. if( m_apiPicBufV ){ memset(m_apiPicBufV, pixelV,(m_iPicWidth >>1) * (m_iPicHeight>>1) * sizeof(Pel)) ; }
  73. }
  74. Void TComPicYuv::setPixel(int posX, int posY, int width, Pel pixelY,Pel pixelU,Pel pixelV)
  75. {
  76. Pel *Y = m_apiPicBufY + posY*m_iPicWidth+posX;
  77. for(int h = 0; h<width; h++)
  78. {
  79. for(int w = 0; w<width;w++)
  80. {
  81. Y[h*m_iPicWidth + w] = pixelY;
  82. }
  83. }
  84. Pel *U = m_apiPicBufU + (posY>>1)*(m_iPicWidth>>1)+(posX>>1);
  85. Pel *V = m_apiPicBufV + (posY>>1)*(m_iPicWidth>>1)+(posX>>1);
  86. for(int h = 0; h<(width>>1); h++)
  87. {
  88. for(int w = 0; w<(width>>1);w++)
  89. {
  90. U[h*(m_iPicWidth>>1) + w] = pixelU;
  91. V[h*(m_iPicWidth>>1) + w] = pixelV;
  92. }
  93. }
  94. }
  95. int main()
  96. {
  97. TComPicYuv *frame = new TComPicYuv;
  98. TComPicYuv *clourMap = new TComPicYuv;
  99. frame->create(8,8);
  100. clourMap->create(512,512);
  101. FILE *FrameFile = fopen("D:\\clourFrame_8x8.yuv","wb");
  102. FILE *clourFile = fopen("D:\\clourMap_512x512.yuv","wb");
  103. for(int Y = 0; Y<256; Y++)
  104. {
  105. for(int U = 0; U<256; U++)
  106. {
  107. for(int V = 0; V<256; V++)
  108. {
  109. frame->setYuv((Pel)Y,(Pel)U,(Pel)V);
  110. fwrite(frame->getPicBufY(),1,frame->getWidth()*frame->getHeight(),FrameFile);
  111. fwrite(frame->getPicBufU(),1,(frame->getWidth()*frame->getHeight())>>2,FrameFile);
  112. fwrite(frame->getPicBufV(),1,(frame->getWidth()*frame->getHeight())>>2,FrameFile);
  113. int  count = Y*256*256 + U*256 + V;
  114. if(count%1000000==0)
  115. {
  116. printf("=");
  117. }
  118. }
  119. }
  120. }
  121. for(int Y = 0; Y<256; Y++)
  122. {
  123. for(int U = 0; U<256; U++)
  124. {
  125. for(int V = 0; V<256; V++)
  126. {
  127. clourMap->setPixel(U*2,V*2,2,Y,U,V);
  128. }
  129. }
  130. fwrite(clourMap->getPicBufY(),1,clourMap->getWidth()*clourMap->getHeight(),clourFile);
  131. fwrite(clourMap->getPicBufU(),1,(clourMap->getWidth()*clourMap->getHeight())>>2,clourFile);
  132. fwrite(clourMap->getPicBufV(),1,(clourMap->getWidth()*clourMap->getHeight())>>2,clourFile);
  133. printf("*");
  134. }
  135. fclose(clourFile);
  136. fclose(FrameFile);
  137. frame->destroy();
  138. clourMap->destroy();
  139. }

转载:http://blog.csdn.net/cabbage2008/article/details/50117671

【转】YUV值对应的颜色的更多相关文章

  1. 常用icon以及color颜色RGB值和对应颜色效果图

    Android谷歌官方扁平化设计常用icon集合   Android谷歌官方扁平化设计color颜色RGB值和对应颜色效果图.

  2. html根据下拉框选中的值修改背景颜色

    错误的写法 <!doctype html><html><head><meta charset="utf-8"><title&g ...

  3. .NET C#生成随机颜色,可以控制亮度,生成暗色或者亮色 基于YUV模式判断颜色明亮度

    .NET C#生成随机颜色,可以控制亮度,生成暗色或者亮色 基于YUV模式判断颜色明亮度   随机颜色在日常开发中很常用到,有时候要控制颜色明亮度,比如在白色背景网页上的随机颜色,一般要求颜色稍微暗一 ...

  4. 颜色的RGB值表示法

    颜色的RGB值表示法 从物理光学试验中得出:红.绿.蓝三种色光是其他色光所混合不出来的.而这三种色光以不同比例的混合几乎可以得出自然界所有的颜色. 如红光与不同比例的绿光混合可以得出橙.黄.黄绿等色: ...

  5. YUV格式介绍

    原文链接:http://www.cnblogs.com/azraelly/archive/2013/01/01/2841269.html YUV格式有两大类:planar和packed.对于plana ...

  6. 关于yuv格式

    首先,内存分布        1:YUV420          (1):I420:              YYYYYYYY UU VV    =>YUV420P          (2): ...

  7. 多媒体编程基础之RGB和YUV

    一.概念 1.什么是RGB? 对一种颜色进行编码的方法统称为“颜色空间”或“色域”.用最简单的话说,世界上任何一种颜色的“颜色空间”都可定义成一个固定的数字或变量.RGB(红.绿.蓝)只是众多颜色空间 ...

  8. iOS面向编码|iOSVideoToolbox:读写解码回调函数CVImageBufferRef的YUV图像

    iOS面向编码|iOSVideoToolbox:读写解码回调函数CVImageBufferRef的YUV图像 本文档基于H.264的解码,介绍读写Video Toolbox解码回调函数参数CVImag ...

  9. Video Toolbox:读写解码回调函数CVImageBufferRef的YUV图像

    本文档基于H.264的解码,介绍读写Video Toolbox解码回调函数参数CVImageBufferRef中的YUV或RGB数据的方法,并给出CVImageBufferRef生成灰度图代码.方便调 ...

随机推荐

  1. Ubuntu安装分区设置

    我的Ubuntu 安装分区 /boot   200M /          2000M /home  6000M swap    1000M /boot分区,它包含了操作系统的内核和在启动系统过程中所 ...

  2. ASP.NET MVC 文件异步上传问题处理

    最近在做一个网站,用asp.net MVC4.0来开发,今天遇到了个小问题,通过查找相关渠道解决了,在这里把这个问题写出来,问题非常简单,不喜勿喷,mark之希望可以给遇到相同问题的初学者一点帮助.我 ...

  3. VS2013配置文件常见问题解决方法

    1.C++ VS2013出现LINK : fatal error LNK1104: 无法打开文件“kernel32.lib,”错误,什么原因啊?原因:项目->XX(项目名称)属性->链接器 ...

  4. HDU -2546饭卡(01背包+贪心)

    这道题有个小小的坎,就是低于5块不能选,大于5块,可以任意选,所以就在初始条件判断一下剩余钱数,然后如果大于5的话,这时候就要用到贪心的思想,只要大于等于5,先找最大的那个,然后剩下的再去用背包去选择 ...

  5. mysql删除数据库报错及解决方法

    前几天在测试环境的数据库上创建了一个数据库,发现不能授权也不能删除. 最后经过排查发现,数据库名称不能出现中划线 " - " , 那么,怎么才能把带有特殊字符的数据库呢? 操作时需 ...

  6. WCF代理是怎么工作的?用代码说话

    1.WCF生成代理的方式 2.WCF代理原理 第一个问题引用 一篇Robin's博文[WCF生成客户端对象方式解析] 讲述了创建客户端服务对象的方法 1.代理构造法 a.开启服务后,添加服务引用 b. ...

  7. (三)Angularjs - 小实例

    AngularJS处理数据表格 使用 np-repeat 指令 <table> ... <!-- 这里使用ng-repeat指令来重复数据生成表格 --> <tr ng- ...

  8. 武汉科技大学ACM :1002: 零起点学算法66——反话连篇

    Problem Description 把输入的字符按照反着顺序输出 Input 多组测试数据  每组一行(每组数据不超过200个字符) Output 按照输入的顺序反着输出各个字符 Sample I ...

  9. 在MyEclipse中设置Source folders和output folder

    在一个项目中可能会有多个资源文件,它们共同编译输出到输出文件.那么除了默认的src以外,如何把其他文件设置成资源文件(Source folders)呢?

  10. CSS的力量

    CSS(Cascading Style Sheet)级联样式表,是一种美观网页设计的解决方案,也是W3C推荐的标准,他可以是我们的网页设计更灵活,更美观,使设计人员对内容的设计和样式的设计分离,使设计 ...