在好例子网,分享、交流、成长!
您当前所在位置:首页C/C++ 开发实例常规C/C++编程 → yuv编解码(2x2 YUV图像拼接)

yuv编解码(2x2 YUV图像拼接)

常规C/C++编程

下载此实例
  • 开发语言:C/C++
  • 实例大小:2.48KB
  • 下载次数:11
  • 浏览次数:486
  • 发布时间:2018-01-23
  • 实例类别:常规C/C++编程
  • 发 布 人:coffeecn
  • 文件格式:.rar
  • 所需积分:2
 相关标签: 解码 yu

实例介绍

yuv编解码C语言代码

【实例简介】

【实例截图】

【核心代码】

/*************************************************
* Copyright (c) 2010,深圳茁壮网络股份有限公司技术研究部 
* All rights reserved.
* 
* 文件名称:YUVSplice.c
* 主要功能:2x2 YUV图像拼接
* 
* 取代版本:1.0 
* 原作者  :谢光辉 
* 完成日期:2010年7月9日
*************************************************/


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

/*预处理图片宽、高及大小*/
#define WIDTH  176
#define HEIGHT 144
#define IMAGE_SIZE (((WIDTH)*(HEIGHT)*3)>>1)

/*预处理图像YUV宽高的各分量*/
#define Y_WIDTH_PREP  176
#define Y_HEIGHT_PREP 144
#define U_WIDTH_PREP  88
#define U_HEIGHT_PREP 72
#define V_WIDTH_PREP  88
#define V_HEIGHT_PREP 72

/*预处理图片U、V分量在码流的相对起始位置*/
#define U_OFFSET_PREP (WIDTH * HEIGHT)
#define V_OFFSET_PREP (U_OFFSET_PREP   WIDTH/2 * HEIGHT/2)

/*处理后图像YUV宽高的各分量*/
#define Y_WIDTH   352
#define Y_HEIGHT  288
#define U_WIDTH   176
#define U_HEIGHT  144
#define V_WIDTH   176
#define V_HEIGHT  144

/*处理后U、V分量在码流的相对起始位置*/
#define U_OFFSET (Y_WIDTH * Y_HEIGHT)
#define V_OFFSET (U_OFFSET   U_WIDTH * U_HEIGHT)

/*文件帧读完后,需要填充数组的默认值*/
#define FILL_VALUE 127

typedef unsigned char UByte;
typedef int INT;

/*************************
*Function: GetFileSize 
*Description: 获取文件大小  
*Input: 
*	fp:文件指针  
*Return: 文件大小 
*************************/
INT GetFileSize(FILE *fp)
{
	
	INT iSize = 0; 	/*存储文件大小*/
	               
	if (NULL == fp)
	{
		printf("Don't open file\n");
	}
	else
	{
		fseek(fp, 0, SEEK_END);
		iSize = ftell(fp);	
	}

	return iSize;
}


/*************************
*Function: GetSizeOfFrame 
*Description: 获取文件帧数  
*Input: 
	fp:文件指针  
*Return: 返回文件帧数 
*************************/
INT GetSizeOfFrame(FILE *fp)
{
	return GetFileSize(fp)/IMAGE_SIZE;
}


/*************************
*Function: MaxOfArray 
*Description: 返回数组中最大值  
*Input: 
	arr: 数组名
	num: 数组大小  
*Return: 数组中最大值
*************************/
INT MaxOfArray(INT arr[], int num)
{
	if (num <= 0)
	{
		printf("argument is error");
		exit(1);
	}
	INT iMax = arr[0];     /*存储数组最大值*/
	int i = 1;
	for (i = 1; i < num;   i)
	{
		if (arr[i] > iMax)
		{
			iMax = arr[i];
		}
	}
	
	return iMax;
}

/*************************
*Function: ReadImage 
*Description: 返回数组中最大值  
*Input: 
	arr: 数组名
	num: 数组大小  
*Return: 数组中最大值
*************************/
void ReadImage(UByte *pResultBuf, UByte *pBuf, INT iStartDest, INT iStartSource, 
               INT iDestOffset, INT iSourceOffset,INT iSize, INT iCount)
{
		/*计数功能*/
		int k = 0;
		
    	for (k = 0; k < iCount;   k)
   		{
  			strncpy(pResultBuf   iStartDest    iDestOffset * k, 
     			pBuf   iStartSource   iSourceOffset * k, iSize);    		
   		}           	
}


int main(int argc, char *argv[])
{
	/*待处理文件名*/
	const char *pFileName[] = {"dfws.yuv", "france.yuv", "mobile.yuv", "nxss.yuv"};
	/*待处理文件个数*/
	INT iNum = sizeof(pFileName) / sizeof (const char*);  
	/*申请存储文件指针的空间*/
	FILE* *fp = (FILE**)malloc(sizeof(FILE*) * iNum);
	/*存储文件帧数*/
	INT *iFrame = (INT*)malloc(sizeof(INT) * iNum);
	/*存储文件最大帧数*/
	INT iMaxFrame = 0;
		
	/*申请存储一张预处理图片大小的空间*/ 
	UByte *pBuf = (UByte*)malloc(IMAGE_SIZE);
	/*申请存储处理后图片大小的空间*/ 
	UByte *pResultBuf = (UByte*)malloc(Y_WIDTH*Y_HEIGHT   U_WIDTH*U_HEIGHT   V_WIDTH*V_HEIGHT); 
	
	/*计数功能*/
	INT i = 0, j = 0, k = 0; 
	/*预处理图片Y分量存入目标区域的起始区域*/
	INT iYStartDest = 0;
	/*预处理图片U分量存入目标区域的起始区域*/
	INT iUStartDest = 0;
	/*预处理图片V分量存入目标区域的起始区域*/
 	INT iVStartDest = 0;
	/*预处理文件偏移值*/ 
	INT iOffset = 0;   
	
	/*输出文件*/
	FILE *fpResult = fopen("result.yuv", "wb");
	
	if (NULL == fpResult)	/*创建或者打开失败,程序结束*/ 
	{
		printf("Can't not open result.yuv\n");
		exit(1);
	}
	      
	/*初始化申请空间*/
	memset(fp, 0, sizeof(FILE*) * iNum);
	memset(iFrame, 0, sizeof(INT) * iNum);
	memset(pBuf, 0, IMAGE_SIZE);
	memset(pResultBuf, 0, Y_WIDTH*Y_HEIGHT   U_WIDTH*U_HEIGHT   V_WIDTH*V_HEIGHT);
	
	
	/*打开所有预处理文件*/	        
	for (i = 0; i < iNum;   i)
	{
		fp[i] = fopen(pFileName[i], "rb");
	   
		if (NULL == fp[i])        /*文件打开失败*/       
		{
			printf("Don't open file\n");
			exit(1);
		}
		else                     /*打开成功,存储文件帧数*/ 
		{
			iFrame[i] = GetSizeOfFrame(fp[i]);
		}	
	}
	
	/*获取预处理文件中的最大帧数*/
	iMaxFrame = MaxOfArray(iFrame, iNum);	
	
/*************************************************/

	/*循环处理每帧*/
    for (i = 0; i < iMaxFrame;   i)
    {
    	/*要处理的数据在文件的偏移量*/ 
    	iOffset = i * IMAGE_SIZE;
    	
    	/*循环处理每个文件的一帧*/ 
    	for (j = 0; j < iNum;   j)
    	{
    		 
    		if (i < iFrame[j])    /*文件帧数未处理完*/
			{
				/*移至要处理数据的起始位置*/ 
				fseek(fp[j], iOffset, SEEK_SET);
				
				/*读取一幅图片的数据*/ 
	    		fread(pBuf, 1, IMAGE_SIZE, fp[j]);
	    		
	    		if (j < iNum/2)
	    		{
    					//ReadImage(pResultBuf, pBuf, Y_WIDTH_PREP * j, 0, 
//						          Y_WIDTH, Y_WIDTH_PREP,Y_WIDTH_PREP, Y_HEIGHT_PREP);
//						          
//         				ReadImage(pResultBuf, pBuf, U_OFFSET   U_WIDTH_PREP * j, U_OFFSET_PREP,
//						 U_WIDTH, U_WIDTH_PREP, U_WIDTH_PREP, HEIGHT/2);
//						 /*循环把预处理图片U、V分量放置目标数组对应位置*/ 
//   						ReadImage(pResultBuf, pBuf, V_OFFSET   U_WIDTH_PREP * j, V_OFFSET_PREP,
//						 V_WIDTH, V_WIDTH_PREP, V_WIDTH_PREP, HEIGHT/2);
			    		iYStartDest = Y_WIDTH_PREP * j;
						iUStartDest = U_OFFSET   U_WIDTH_PREP * j;
						iVStartDest = V_OFFSET   U_WIDTH_PREP * j; 			
	    		}
	    		else
	    		{
	    				iYStartDest = Y_WIDTH * HEIGHT   Y_WIDTH_PREP * (j-iNum/2);
						iUStartDest = U_OFFSET   U_WIDTH * U_HEIGHT_PREP   U_WIDTH_PREP * (j-iNum/2);
						iVStartDest = V_OFFSET   V_WIDTH * V_HEIGHT_PREP   V_WIDTH_PREP * (j-iNum/2);  		
	    		}/*end of inner if*/ 	
				ReadImage(pResultBuf, pBuf, iYStartDest, 0, 
						          Y_WIDTH, Y_WIDTH_PREP,Y_WIDTH_PREP, Y_HEIGHT_PREP);
						          
    			ReadImage(pResultBuf, pBuf, iUStartDest, 
						 U_OFFSET_PREP,U_WIDTH, U_WIDTH_PREP, U_WIDTH_PREP, HEIGHT/2);
						 /*循环把预处理图片U、V分量放置目标数组对应位置*/ 
				ReadImage(pResultBuf, pBuf, iVStartDest, 
						   V_OFFSET_PREP, V_WIDTH, V_WIDTH_PREP, V_WIDTH_PREP, HEIGHT/2);    	
			}
			else                /*文件帧数处理完*/
			{
				if (j < iNum/2)
				{
					for (k = 0; k < Y_HEIGHT_PREP;   k)
		    		{
		    			memset(pResultBuf   Y_WIDTH_PREP * j    Y_WIDTH * k, FILL_VALUE, Y_WIDTH_PREP);    		
		    		}
		    		for (k = 0; k < HEIGHT/2;   k)
		    		{
		   				memset(pResultBuf   U_OFFSET   U_WIDTH_PREP * j   U_WIDTH * k, 
						   FILL_VALUE, U_WIDTH_PREP);
	        				
		   				memset(pResultBuf   V_OFFSET   V_WIDTH_PREP * j   V_WIDTH * k, 
						   FILL_VALUE, V_WIDTH_PREP);
		    		}	
				}
				else
				{
					for (k = 0; k < Y_HEIGHT_PREP;   k)
		    		{
		    			memset(pResultBuf   Y_WIDTH * HEIGHT   Y_WIDTH_PREP * (j-iNum/2)    Y_WIDTH * k, 
					  		FILL_VALUE, Y_WIDTH_PREP);    		
		    		}
		    		for (k = 0; k < HEIGHT/2;   k)
		    		{
		   				memset(pResultBuf   U_OFFSET   U_WIDTH * U_HEIGHT_PREP   U_WIDTH_PREP * (j-iNum/2)   U_WIDTH * k, 
	        				FILL_VALUE, U_WIDTH_PREP);
	        				
		   				memset(pResultBuf   V_OFFSET   V_WIDTH * V_HEIGHT_PREP   V_WIDTH_PREP * (j-iNum/2)   V_WIDTH * k, 
						   	FILL_VALUE, V_WIDTH_PREP);
		    		}	
				}/*end of inner if*/
			}/*end of outer if*/
    	}	/*end of inner for*/
    	fwrite(pResultBuf, 1, Y_WIDTH*Y_HEIGHT   U_WIDTH*U_HEIGHT   V_WIDTH*V_HEIGHT, fpResult);
    }/*end of outer for*/
    
 
    for (i = 0; i < iNum;   i)
    {
    	fclose(fp[i]);
    }
    fclose(fpResult);
	return 0;
}


标签: 解码 yu

实例下载地址

yuv编解码(2x2 YUV图像拼接)

不能下载?内容有错? 点击这里报错 + 投诉 + 提问

好例子网口号:伸出你的我的手 — 分享

网友评论

发表评论

(您的评论需要经过审核才能显示)

查看所有0条评论>>

小贴士

感谢您为本站写下的评论,您的评论对其它用户来说具有重要的参考价值,所以请认真填写。

  • 类似“顶”、“沙发”之类没有营养的文字,对勤劳贡献的楼主来说是令人沮丧的反馈信息。
  • 相信您也不想看到一排文字/表情墙,所以请不要反馈意义不大的重复字符,也请尽量不要纯表情的回复。
  • 提问之前请再仔细看一遍楼主的说明,或许是您遗漏了。
  • 请勿到处挖坑绊人、招贴广告。既占空间让人厌烦,又没人会搭理,于人于己都无利。

关于好例子网

本站旨在为广大IT学习爱好者提供一个非营利性互相学习交流分享平台。本站所有资源都可以被免费获取学习研究。本站资源来自网友分享,对搜索内容的合法性不具有预见性、识别性、控制性,仅供学习研究,请务必在下载后24小时内给予删除,不得用于其他任何用途,否则后果自负。基于互联网的特殊性,平台无法对用户传输的作品、信息、内容的权属或合法性、安全性、合规性、真实性、科学性、完整权、有效性等进行实质审查;无论平台是否已进行审查,用户均应自行承担因其传输的作品、信息、内容而可能或已经产生的侵权或权属纠纷等法律责任。本站所有资源不代表本站的观点或立场,基于网友分享,根据中国法律《信息网络传播权保护条例》第二十二与二十三条之规定,若资源存在侵权或相关问题请联系本站客服人员,点此联系我们。关于更多版权及免责申明参见 版权及免责申明

;
报警