基本信息
源码名称:yuv编解码(2x2 YUV图像拼接)
源码大小:2.48KB
文件格式:.rar
开发语言:C/C++
更新时间:2018-01-23
   友情提示:(无需注册或充值,赞助后即可获取资源下载链接)

     嘿,亲!知识可是无价之宝呢,但咱这精心整理的资料也耗费了不少心血呀。小小地破费一下,绝对物超所值哦!如有下载和支付问题,请联系我们QQ(微信同号):813200300

本次赞助数额为: 2 元 
   源码介绍

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;
}