YUV420p旋转代码

 从网上找的一团乱糟糟 索性自己写个吧 其实也很简单的

 

很多人对YUV数据格式不清楚,以至于在做视频的时候出现了一些不可预知的错误(比如说图像带有点、颜色不对等)。今晚是周末放假,我就抽点时间来给大家介绍一下。

       提示: 读下面的文字时,希望大家结合图片看,这样更易理解
       在YUV420中,一个像素点对应一个Y,一个2X2的小方块对应一个U和V。对于所有YUV420图像,它们的Y值排列是完全相同的,因为只有Y的图像就是灰度图像。YUV420sp与YUV420p的数据格式它们的UV排列在原理上是完全不同的。420p它是先把U存放完后,再存放V,也就是说UV它们是连续的。而420sp它是UV、UV这样交替存放的。(见下图)
有了上面的理论,我就可以准确的计算出一个YUV420在内存中存放的大小。
width * hight =Y(总和)
U = Y / 4  
V = Y / 4


所以YUV420 数据在内存中的长度是 width * hight * 3 / 2,

假设一个分辨率为8X4的YUV图像,它们的格式如下图:


                                   YUV420sp格式如下图                                                                    YUV420p数据格式如下图

       YUV420p旋转代码_第1张图片                  YUV420p旋转代码_第2张图片

[cpp]  view plain copy print ?
  1. class yuv420_rotate  
  2. {  
  3. public:  
  4.     yuv420_rotate(void);  
  5.     ~yuv420_rotate(void);  
  6.   
  7. public:  
  8.     //rotate clockwise  
  9.     static void yuv_rotate_90(BYTE *des,BYTE *src,int width,int height);  
  10.     static void yuv_rotate_180(BYTE *des,BYTE *src,int width,int height);  
  11.     static void yuv_rotate_270(BYTE *des,BYTE *src,int width,int height);  
  12.   
  13.     //flip  
  14.     static void yuv_flip_horizontal(BYTE *des,BYTE *src,int width,int height);  
  15.     static void yuv_flip_vertical(BYTE *des,BYTE *src,int width,int height);  
  16.   
  17. };  


 

[cpp]  view plain copy print ?
  1. yuv420_rotate::yuv420_rotate(void)  
  2. {  
  3. }  
  4.   
  5. yuv420_rotate::~yuv420_rotate(void)  
  6. {  
  7. }  
  8.   
  9. void yuv420_rotate::yuv_rotate_90(BYTE *des,BYTE *src,int width,int height)  
  10. {  
  11.     int n = 0;  
  12.     int hw = width / 2;  
  13.     int hh = height / 2;  
  14.     //copy y  
  15.     for(int j = 0; j < width;j++)  
  16.     {  
  17.         for(int i = height - 1; i >= 0; i--)  
  18.         {  
  19.             des[n++] = src[width * i + j];  
  20.         }  
  21.     }  
  22.   
  23.     //copy u  
  24.     BYTE *ptemp = src + width * height;  
  25.     for(int j = 0;j < hw;j++)  
  26.     {  
  27.         for(int i = hh - 1;i >= 0;i--)  
  28.         {  
  29.             des[n++] = ptemp[ hw*i + j ];  
  30.         }  
  31.     }  
  32.   
  33.     //copy v  
  34.     ptemp += width * height / 4;  
  35.     for(int j = 0; j < hw; j++)  
  36.     {  
  37.         for(int i = hh - 1;i >= 0;i--)  
  38.         {  
  39.             des[n++] = ptemp[hw*i + j];  
  40.         }  
  41.     }  
  42. }  
  43.   
  44. void yuv420_rotate::yuv_rotate_180(BYTE *des,BYTE *src,int width,int height)  
  45. {  
  46.     int n = 0;  
  47.     int hw = width / 2;  
  48.     int hh = height / 2;  
  49.     //copy y  
  50.     for(int j = height - 1; j >= 0; j--)  
  51.     {  
  52.         for(int i = width; i > 0; i--)  
  53.         {  
  54.             des[n++] = src[width*j + i];  
  55.         }  
  56.     }  
  57.   
  58.     //copy u  
  59.     BYTE *ptemp = src + width * height;  
  60.     for(int j = hh - 1;j >= 0; j--)  
  61.     {  
  62.         for(int i = hw; i > 0; i--)  
  63.         {  
  64.             des[n++] = ptemp[hw * j + i];  
  65.         }  
  66.     }  
  67.   
  68.     //copy v  
  69.     ptemp += width * height / 4;  
  70.     for(int j = hh - 1;j >= 0; j--)  
  71.     {  
  72.         for(int i = hw; i > 0; i--)  
  73.         {  
  74.             des[n++] = ptemp[hw * j + i];  
  75.         }  
  76.     }  
  77. }  
  78.   
  79. void yuv420_rotate::yuv_rotate_270(BYTE *des,BYTE *src,int width,int height)  
  80. {  
  81.     int n = 0;  
  82.     int hw = width / 2;  
  83.     int hh = height / 2;  
  84.     //copy y  
  85.     for(int j = width; j > 0; j--)  
  86.     {  
  87.         for(int i = 0; i < height;i++)  
  88.         {  
  89.             des[n++] = src[width*i + j];  
  90.         }  
  91.     }  
  92.   
  93.     //copy u  
  94.     BYTE *ptemp = src + width * height;  
  95.     for(int j = hw; j > 0;j--)  
  96.     {  
  97.         for(int i = 0; i < hh;i++)  
  98.         {  
  99.             des[n++] = ptemp[hw * i + j];  
  100.         }  
  101.     }  
  102.   
  103.     //copy v  
  104.     ptemp += width * height / 4;  
  105.     for(int j = hw; j > 0;j--)  
  106.     {  
  107.         for(int i = 0; i < hh;i++)  
  108.         {  
  109.             des[n++] = ptemp[hw * i + j];  
  110.         }  
  111.     }  
  112. }  
  113.   
  114. void yuv420_rotate::yuv_flip_horizontal(BYTE *des,BYTE *src,int width,int height)  
  115. {  
  116.     int n = 0;  
  117.     int hw = width / 2;  
  118.     int hh = height / 2;  
  119.     //copy y  
  120.     for(int j = 0; j < height; j++)  
  121.     {  
  122.         for(int i = width - 1;i >= 0;i--)  
  123.         {  
  124.             des[n++] = src[width * j + i];  
  125.         }  
  126.     }  
  127.   
  128.     //copy u  
  129.     BYTE *ptemp = src + width * height;  
  130.     for(int j = 0; j < hh; j++)  
  131.     {  
  132.         for(int i = hw - 1;i >= 0;i--)  
  133.         {  
  134.             des[n++] = ptemp[hw * j + i];  
  135.         }  
  136.     }  
  137.       
  138.     //copy v  
  139.     ptemp += width * height / 4;  
  140.     for(int j = 0; j < hh; j++)  
  141.     {  
  142.         for(int i = hw - 1;i >= 0;i--)  
  143.         {  
  144.             des[n++] = ptemp[hw * j + i];  
  145.         }  
  146.     }  
  147. }  
  148.   
  149. void yuv420_rotate::yuv_flip_vertical(BYTE *des,BYTE *src,int width,int height)  
  150. {  
  151.     int n = 0;  
  152.     int hw = width / 2;  
  153.     int hh = height / 2;  
  154.     //copy y  
  155.     for(int j = 0; j < width;j++)  
  156.     {  
  157.         for(int i = height - 1; i >= 0;i--)  
  158.         {  
  159.             des[n++] = src[width * i + j];  
  160.         }  
  161.     }  
  162.   
  163.     //copy u  
  164.     BYTE *ptemp = src + width * height;  
  165.     for(int j = 0; j < hw; j++)  
  166.     {  
  167.         for(int i = hh - 1; i >= 0;i--)  
  168.         {  
  169.             des[n++] = ptemp[ hw * i + j];  
  170.         }  
  171.     }  
  172.   
  173.     //copy v  
  174.     ptemp += width * height / 4;  
  175.     for(int j = 0; j < hw; j++)  
  176.     {  
  177.         for(int i = hh - 1; i >= 0; i--)  
  178.         {  
  179.             des[n++] = ptemp[ hw * i + j];  
  180.         }  
  181.     }  
  182. }  



http://blog.csdn.net/codefoxtiger/article/details/23549553

你可能感兴趣的:(YUV420p旋转代码)