http://www.2cto.com/kf/201208/145559.html

http://www.opencv.org.cn/forum.php?mod=viewthread&tid=645&extra=

第一个是很笨的办法:

yuv三个分量分别写在3个矩阵下,然后合并之后转换为rgb分量的图片格式就可以了;

代码如下:

[html] 
IplImage *image,*rgbimg,*yimg,*uimg,*vimg,*uuimg,*vvimg; 
     
    rgbimg = cvCreateImage(cvSize(nWidth, nHeight),IPL_DEPTH_8U,3); 
    image = cvCreateImage(cvSize(nWidth, nHeight),IPL_DEPTH_8U,3); 
     
    yimg = cvCreateImageHeader(cvSize(nWidth, nHeight),IPL_DEPTH_8U,1); 
    uimg = cvCreateImageHeader(cvSize(nWidth/2, nHeight/2),IPL_DEPTH_8U,1); 
    vimg = cvCreateImageHeader(cvSize(nWidth/2, nHeight/2),IPL_DEPTH_8U,1); 
     
    uuimg = cvCreateImage(cvSize(nWidth, nHeight),IPL_DEPTH_8U,1); 
    vvimg = cvCreateImage(cvSize(nWidth, nHeight),IPL_DEPTH_8U,1); 
     
    cvSetData(yimg,pBuf, nWidth); 
    cvSetData(uimg,pBuf+nWidth*nHeight, nWidth/2); 
    cvSetData(vimg,pBuf+long(nWidth*nHeight*1.25), nWidth/2); 
    cvResize(uimg,uuimg,CV_INTER_LINEAR); 
    cvResize(vimg,vvimg,CV_INTER_LINEAR); 
     
    cvMerge(yimg,uuimg,vvimg,NULL,image); 
    cvCvtColor(image,rgbimg,CV_YCrCb2BGR);

还有一个方法就比较负载
首先自己根据原理转换为rgb格式

然后利用cvSetData()函数写入数据生成IplImage格式的图片

首先定义转换的公式:

[html]
#define MR(Y,U,V) (Y + (1.403)*(V-128)) 
#define MG(Y,U,V) (Y - (0.344) * (U-128) - (0.714) * (V-128) )  
#define MB(Y,U,V) (Y + ((1.773) * (U-128)))

yuv转rgb的函数:
[html] 
void YUV420_C_RGB( char* pYUV, unsigned char* pRGB, int height, int width) 

    char* pY = pYUV; 
    char* pU = pYUV+height*width; 
    char* pV = pU+(height*width/4); 
 
 
    unsigned char* pBGR = NULL; 
    unsigned char R = 0; 
    unsigned char G = 0; 
    unsigned char B = 0; 
    char Y = 0; 
    char U = 0; 
    char V = 0; 
    double tmp = 0; 
    for ( int i = 0; i < height; ++i ) 
    { 
        for ( int j = 0; j < width; ++j ) 
        { 
            pBGR = pRGB+ i*width*3+j*3; 
 
            Y = *(pY+i*width+j); 
            U = *pU; 
            V = *pV; 
 
            //B 
            tmp = MB(Y, U, V); 
            //B = (tmp > 255) ? 255 : (char)tmp; 
            //B = (B<0) ? 0 : B; 
            B = (unsigned char)tmp; 
            //G 
            tmp = MG(Y, U, V); 
            //G = (tmp > 255) ? 255 : (char)tmp; 
           // G = (G<0) ? 0 : G; 
            G = (unsigned char)tmp; 
            //R 
            tmp = MR(Y, U, V); 
            //R = (tmp > 255) ? 255 : (char)tmp; 
            //R = (R<0) ? 0 : R; 
            R = (unsigned char)tmp; 
 
 
            *pBGR     = R;             
            *(pBGR+1) = G;         
            *(pBGR+2) = B; 
         
 
            if ( i%2 == 0 && j%2 == 0) 
            { 
                *pU++; 
                //*pV++; 
            } 
            else 
            { 
                if ( j%2 == 0 ) 
                { 
                    *pV++ ; 
                } 
            } 
        } 
     
    } 
}

最后是写入IplImage的代码:
[html] 
unsigned char* pRGB = NULL; 
 
pRGB = (unsigned char*)malloc(nSize*sizeof(unsigned char*)*2); 
     
YUV420_C_RGB(pBuf,pRGB,nWidth,nHeight); 
     
IplImage *image; www.2cto.com
image = cvCreateImageHeader(cvSize(nWidth, nHeight),IPL_DEPTH_8U,3); 
cvSetData(image,pRGB,nWidth*3); 
程序都运行过
编译环境为vs2008

作者:xuhongwei0411

最新文章

  1. Hystrix框架4--circuit
  2. cf201.div1 Number Transformation II 【贪心】
  3. Java进击C#——语法之ADO.NET
  4. SQL Server自动化运维系列——批量执行SQL脚本(Power Shell)
  5. 友盟ionic多渠道自动签名app
  6. Struts2 动态方法调用
  7. HBase预分区
  8. ubuntu nginx 安装以及配置文件详解
  9. mongodb3.x用户角色
  10. 微信公众号API返回不可打印字符的处理。
  11. 【原创】Junit4详解一:Junit总体介绍
  12. SQL增加、删除、更改表中的字段名
  13. (转载)shell日志分析常用命令
  14. Junit中常用的注解说明
  15. 设计模式24---设计模式之职责链模式(Chain of Responsibility)(行为型)
  16. 【转】Android源代码查看途径
  17. yum使用总结(转)
  18. eclipse中添加Java代码注释模板
  19. mac OS X 从无法同步互联网时间想到的
  20. [Android] Android 手机下 仿 今日头条 新闻客户端

热门文章

  1. stick footers布局
  2. 001windows已遇到一个关键性问题 一分钟后自动重启
  3. iOS类目
  4. linux oracle 配置监听器
  5. Javadoc生成html帮助文档
  6. [转]Linux进程通信之POSIX消息队列
  7. 【BZOJ2140】稳定婚姻 Tarjan
  8. EasyPlayer.js网页全终端播放器安装使用文档
  9. Unity字体文件放Resources和打成ab对比
  10. slf4j和log4j结合使用步骤