图像处理之基础---2个YUV视频 拼接技术
- /*************************************************
- * 主要功能:两路 YUV4:2:0拼接一路左右半宽格式YUV视频
- 参考资料:http://www.pudn.com/downloads271/sourcecode/multimedia/vfw/detail1237363.html
- U_size=V_size=Y_size/2
- *************************************************/
- #include<stdio.h>
- #include<stdlib.h>
- #include<string.h>
- #define PREWEIGHT 1920
- #define PREHEIGHT 1080
- #define RESWEIGHT 3840
- #define RESHEIGHT 1080
- #define PREYSIZE ((PREWEIGHT)*(PREHEIGHT))
- #define PREUSIZE ((PREWEIGHT/2)*(PREHEIGHT/2))
- #define PREVSIZE ((PREWEIGHT/2)*(PREHEIGHT/2))
- #define RESYSIZE ((RESWEIGHT)*(RESHEIGHT))
- #define RESUSIZE ((RESWEIGHT/2)*(RESHEIGHT/2))
- #define RESVSIZE ((RESWEIGHT/2)*(RESHEIGHT/2))
- #define PRESIZE ((PREYSIZE)+(PREUSIZE)+(PREVSIZE))
- #define RESSIZE ((RESYSIZE)+(RESUSIZE)+(RESVSIZE))
- int GetFrameNum(const char *File)
- {
- FILE *fp;
- int size=0;
- if (!(fp=fopen(File,"rb")))
- {
- printf("Open %s error !",File);
- exit(1);
- }
- else
- {
- fseek(fp,0,SEEK_END);/*将文件指针移到YUV文件的末尾*/
- size=ftell(fp);/*计算文件的总大小*/
- }
- return (size/PRESIZE);
- }
- void ReadYUV(char *ResBuf,char *PreBuf,int resstart,int prestart,int resoffset,int preoffset,int size,int height)
- {
- int k;
- for (k=0;k<height;k++)
- {
- memmove(ResBuf+resstart+k*(resoffset),PreBuf+prestart+k*(preoffset),size);//注意这里用memmov不用strncpy
- }
- }
- int main(int argc,char *argv[])
- {
- const char *FileName[]={"e:\BMX_L_1920x1080_240frms.yuv","e:\BMX_R_1920x1080_240frms.yuv"};/*两路YUV文件名*/
- FILE *FileResult;/*输出文件名*/
- FILE** fp_combine=(FILE**)malloc(sizeof(FILE *)*3);/*申请文件指针*/
- int *FileFrameNum=(int *)malloc(sizeof(int)*3);/*每个YUV的帧数*/
- char *PreBuf=(char *)malloc(sizeof(char)*(PRESIZE+1));/*处理前每一帧图像的大小*/
- char *ResBuf=(char*)malloc(sizeof(char)*(RESSIZE+1));/*处理后每一帧图像的大小*/
- int Y_start_section=0;/*预处理图片Y分量存入目标区域的起始区域*/
- int U_start_section = 0;/*预处理图片U分量存入目标区域的起始区域*/
- int V_start_section = 0;/*预处理图片V分量存入目标区域的起始区域*/
- int File_offset = 0;/*预处理文件偏移值*/
- int i_combine=0,j_combine=0,k_combine=0;/*控制循环*/
- /*判断申请内存是否成功*/
- if (!((fp_combine)&&(FileFrameNum)&&(PreBuf)&&(ResBuf)))
- {
- printf("Allocate memeroy Faile !");
- exit(1);
- }
- /*初始化申请空间*/
- memset(fp_combine,0,sizeof(FILE *)*2);
- memset(FileFrameNum,0,sizeof(int)*2);
- memset(PreBuf,0,sizeof(char)*PRESIZE);
- memset(ResBuf,0,sizeof(char)*RESSIZE);
- if (!(FileResult=fopen("hua_result.YUV","wb")))/*创建输出文件*/
- {
- printf("Creat File faile !");
- exit(1);
- }
- for (i_combine=0;i_combine<2;i_combine++)
- {
- if(!(fp_combine[i_combine]=fopen(FileName[i_combine],"rb")))/*打开输入文件*/
- {
- printf("Open File %s Faile !",FileName[i_combine]);
- exit(1);
- }
- else
- {
- FileFrameNum[i_combine]=GetFrameNum(FileName[i_combine]);/*存储每一个视频的帧数*/
- }
- }
- i_combine=0;
- k_combine=FileFrameNum[i_combine];
- while (i_combine<k_combine)
- {
- File_offset = i_combine*PRESIZE;
- j_combine=0;
- while (j_combine<2)
- {
- fseek(fp_combine[j_combine],File_offset,SEEK_SET);/*移动文件指针至需要处理的数据的位置*/
- fread(PreBuf,1,PRESIZE,fp_combine[j_combine]);/*读取一幅图像*/
- if (j_combine==0)
- {
- /*把读取预处理图片Y/U/V分量的起始位置放置目标对应位置*/
- Y_start_section=0;
- U_start_section=RESYSIZE;
- V_start_section=RESYSIZE+RESUSIZE;
- }
- else
- {
- /*把读取预处理图片Y/U/V分量的起始位置放置目标对应位置*/
- Y_start_section=PREWEIGHT;
- U_start_section=RESYSIZE+PREWEIGHT/2;
- V_start_section=RESYSIZE+RESUSIZE+PREWEIGHT/2;
- }
- /*分别读Y、U、V*/
- ReadYUV(ResBuf,PreBuf,Y_start_section,0, RESWEIGHT,PREWEIGHT,PREWEIGHT,PREHEIGHT);
- ReadYUV(ResBuf,PreBuf,U_start_section,PREYSIZE, RESWEIGHT/2,PREWEIGHT/2,PREWEIGHT/2,PREHEIGHT/2);
- ReadYUV(ResBuf,PreBuf,V_start_section,PREYSIZE+PREUSIZE, RESWEIGHT/2,PREWEIGHT/2,PREWEIGHT/2,PREHEIGHT/2);
- j_combine++;
- }
- fwrite(ResBuf,1,RESSIZE,FileResult);
- fflush(FileResult);
- i_combine++;
- }
- fclose(fp_combine[0]);
- fclose(fp_combine[1]);
- fclose(FileResult);
- return 0;
- }
http://blog.csdn.net/huahuahailang/article/details/9040847
图像处理之基础---2个YUV视频 拼接技术的更多相关文章
- 2个YUV视频拼接技术
http://blog.csdn.net/huahuahailang/article/details/9040847 2个YUV视频拼接技术 http://zhongcong386.blog.163. ...
- 基于SURF特征的图像与视频拼接技术的研究和实现(一)
基于SURF特征的图像与视频拼接技术的研究和实现(一) 一直有计划研究实时图像拼接,但是直到最近拜读西电2013年张亚娟的<基于SURF特征的图像与视频拼接技术的研究和实现>,条 ...
- 使用D3D渲染YUV视频数据
源代码下载 在PC机上,对于YUV格式的视频如YV12,YUY2等的显示方法,一般是采用DIRECTDRAW,使用显卡的OVERLAY表面显示.OVERLAY技术主要是为了解决在PC上播放VCD而在显 ...
- FFmpeg YUV视频序列编码为视频
上一篇已经写了如何配置好开发环境,这次就先小试牛刀,来个视频的编码.搞视频处理的朋友肯定比较熟悉YUV视频序列,很多测试库提供的视频数据都是YUV视频序列,我们这里就用用YUV视频序列来做视频.关于Y ...
- 使用D3D渲染YUV视频数据<转>
源代码下载 转载地址:http://blog.csdn.net/dengzikun/article/details/5824874 源码地址:http://download.csdn.net/down ...
- 基于 IJKPlayer-concat 协议的视频无缝拼接技术实现
一.前言 Hi,大家好,我是承香墨影! 开门见山,开篇名义.今天来聊聊如何将多段视频,拼接成一个完整而连续的视频,然后无缝进行播放. 这样的需求应该不算偏门吧? 最简单的就是一些视频 App,会将大段 ...
- avi视频格式转yuv格式与播放yuv视频
因为要用到yuv格式视频.而眼下仅仅有avi格式的视频,所以须要转换,而且opencv不支持yuv编码的视频播放.所以须要转换为rgb编码.而后播放.写了两个程序.以供參考: 1,avi格式视频转yu ...
- 一些yuv视频下载地址
因为测试需要下载一些yuv视频地址,现存一个可以下载yuv视频的地址以备后用 http://trace.eas.asu.edu/yuv/index.html ftp://ftp.ldv.e-techn ...
- YUV视频格式详解(翻译自微软文档)
原文: https://docs.microsoft.com/en-us/previous-versions/aa904813(v=vs.80) YUV视频格式详解(翻译自微软文档)https://b ...
随机推荐
- VisualStudio Shell简介 — 集成插件
Visual Studio Shell只是提供了一个内核,我们还需要在其基础上补充功能,从而实现我们自己的IDE.Visual Studio Shell的插件开发和Visual Studio插件开发是 ...
- sqlserver 巧用REVERSE和SUBSTRING实现lastindexof
原文:sqlserver 巧用REVERSE和SUBSTRING实现lastindexof select REVERSE(SUBSTRING(REVERSE(testFixtureNumber),0, ...
- ES里关于数组的拓展
一.静态方法 在ES6以前,创建数组的方式主要有两种,一种是调用Array构造函数,另一种是用数组字面量语法,这两种方法均需列举数组中的元素,功能非常受限.如果想将一个类数组对象(具有数值型索引和le ...
- 在windows上一键编译各种版本的protobuf(2017-12-05修改)
所需工具 : cmake for windows 和 git for windows 原理:protobuf 是google的一个开源项目,其源代码在github上可以下载到,并且源码都采用cm ...
- MySQL的四种变量类型
一.全局变量在系统运行期间动态更改其参数,重启后失效.SET GLOABL var=XXX;SET @@global.var=XXX;以上两种方式等效 查看系统的全局变量show global var ...
- eclipse显示包的层次关系
如何在eclipse中显示包的层次关系呢?如下图所示
- Java 基础,小数百分比两种方法
public static void main(String[] args) { System.out.println(getPercent(1, 2)); } public static Strin ...
- Linux终端:speedtest_cli检测你的实时带宽速度
你在家(或者办公室)的上传和下载速度如何?你能保证,你支付费用给ISP的同时得到了等价的回报? 要想测试我们因特网连接的速度,当下存在着一些因特网服务,比如说SpeedTest,这是一种可以通过Web ...
- python测试网页是否能正常登陆
#!/usr/bin/python #encoding:utf-8 ##实现网页的登陆检查 import HTMLParser import urlparse import cookielib imp ...
- vim 命令行使用技巧
1. <Ctrl-U> <Ctrl-K> 删除光标到开头的输入 2. <Ctrl-W> 删除最近输入的单词 3. <Ctrl-H> 删除光标之前的一个字 ...