热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

3D视频上下转化左右交织格式YUV

3D视频中,有的是上下格式的,但是无论是裸眼3D还是3D眼镜都需要左右格式的,下面就是转换的算法,利用ffmpeg解码,进行YUV切割,实现左右视频交织,可以在裸眼3D手机或者pa

3D视频中,有的是上下格式的,但是无论是裸眼3D还是3D眼镜都需要左右格式的,下面就是转换的算法,利用ffmpeg解码,进行YUV切割,实现左右视频交织,可以在裸眼3D手机或者pad上观看3D效果。必须要先熟悉YUV数据格式。

        FILE *yuvFile = fopen("yuv_file_width.yuv","ab");
	if(!yuvFile)
		return 0;
	av_register_all();
	AVFormatContext *pFormat  = NULL;
	if (avformat_open_input(&pFormat ,SRC_FILE,NULL,NULL) <0)
	{
		return 0;
	}
	AVCodecContext * video_dec_ctx = NULL;
	AVCodec *video_dec = NULL;
	if (avformat_find_stream_info(pFormat,NULL) <0)
	{
		return 0;
	}
	av_dump_format(pFormat,0,SRC_FILE,0);
	int index = -1,i = 0;
	for (i=0;inb_streams;i++)
	{
		if (pFormat->streams[i]->codec->codec_type == AVMEDIA_TYPE_VIDEO)
		{
			index = i;
			break;
		}
	}
	if (-1 == index)
	{
		printf("can‘t find the codec\n");
		return -1;
	}
	video_dec_ctx = pFormat->streams[index]->codec;
	video_dec = avcodec_find_decoder(video_dec_ctx->codec_id);
	//源文件的格式上下文 解码器上下文  解码器 都已经找到 现在打开解码器
	if(avcodec_open2(video_dec_ctx,video_dec,NULL) <0)
	{
		return 0;
	}

	//需要读取一帧数据 放在包里 
	AVPacket *video_pkt =  new AVPacket;
	av_init_packet(video_pkt);
	
	while (1)
	{
		if(av_read_frame(pFormat,video_pkt)<0)
		{
			fclose(yuvFile);
			delete video_pkt;
			return 0;
		}
		if (pFormat->streams[video_pkt->stream_index]->codec->codec_type ==       AVMEDIA_TYPE_VIDEO)
		{
			AVFrame *frame =avcodec_alloc_frame();
			int got_pictrue = 0,ret = 0;
			ret = avcodec_decode_video2(video_dec_ctx,frame,&got_pictrue,video_pkt);
			if (ret <0)
			{
				continue;
			}
			if (got_pictrue)
			{
				printf("decode one frame is ok\n");
				int height = video_dec_ctx->height/2;
				int width = video_dec_ctx->width*2;
				char *buf = new char[height*width*3/2];
				memset(buf,0,height*width*3/2);
				int y_tmp=0,i=0;
				int u_tmp = width/2*height*2;
				int v_tmp = u_tmp + width/4*height/2*2;

				for (i=0;idata[0]+i*frame->linesize[0],width/2);
					y_tmp += width/2;
					tmp = i+height;
					memcpy(buf+y_tmp,frame->data[0]+tmp*frame->linesize[0],width/2);
					y_tmp += width/2;
					if (idata[1]+i*frame->linesize[1],width/4);
						u_tmp += width/4;
						tmp = i+height/2;
						memcpy(buf+u_tmp,frame->data[1]+tmp*frame->linesize[1],width/4);
						u_tmp += width/4;

						memcpy(buf+v_tmp,frame->data[2]+i*frame->linesize[2],width/4);
						v_tmp += width/4;
						tmp = i+height/2;
						memcpy(buf+v_tmp,frame->data[2]+tmp*frame->linesize[2],width/4);
						v_tmp += width/4;
					}
				}
			
				int frame_height = height;
				int frame_width = width/2;
				char *frame_buf = new char[frame_height*frame_width*3/2];
				memset(frame_buf,0,frame_height*frame_width*3/2);
				int tmp=0;
				for (i=0;idata[0]+i*frame->linesize[0],width);
				a += width;
				}
				for (i=0;idata[1]+i*frame->linesize[1],width/2);
				a += width/2;
				}
				for (i=0;idata[2]+i*frame->linesize[2],width/2);
				a += width/2;
				}
				fwrite(frame_buf,1,frame_height*frame_width*3/2,yuvFile);
				delete[] frame_buf;
				delete[] buf;
				frame_buf = NULL;
				buf = NULL;
			}
			avcodec_free_frame(&frame);
		}
	}
	fclose(yuvFile);
	delete video_pkt;    

3D视频上下转化左右交织格式YUV


推荐阅读
  • 《数据结构》学习笔记3——串匹配算法性能评估
    本文主要讨论串匹配算法的性能评估,包括模式匹配、字符种类数量、算法复杂度等内容。通过借助C++中的头文件和库,可以实现对串的匹配操作。其中蛮力算法的复杂度为O(m*n),通过随机取出长度为m的子串作为模式P,在文本T中进行匹配,统计平均复杂度。对于成功和失败的匹配分别进行测试,分析其平均复杂度。详情请参考相关学习资源。 ... [详细]
  • 后台获取视图对应的字符串
    1.帮助类后台获取视图对应的字符串publicclassViewHelper{将View输出为字符串(注:不会执行对应的ac ... [详细]
  • 1,关于死锁的理解死锁,我们可以简单的理解为是两个线程同时使用同一资源,两个线程又得不到相应的资源而造成永无相互等待的情况。 2,模拟死锁背景介绍:我们创建一个朋友 ... [详细]
  • 本文介绍了如何使用php限制数据库插入的条数并显示每次插入数据库之间的数据数目,以及避免重复提交的方法。同时还介绍了如何限制某一个数据库用户的并发连接数,以及设置数据库的连接数和连接超时时间的方法。最后提供了一些关于浏览器在线用户数和数据库连接数量比例的参考值。 ... [详细]
  • 本文介绍了C#中数据集DataSet对象的使用及相关方法详解,包括DataSet对象的概述、与数据关系对象的互联、Rows集合和Columns集合的组成,以及DataSet对象常用的方法之一——Merge方法的使用。通过本文的阅读,读者可以了解到DataSet对象在C#中的重要性和使用方法。 ... [详细]
  • Mac OS 升级到11.2.2 Eclipse打不开了,报错Failed to create the Java Virtual Machine
    本文介绍了在Mac OS升级到11.2.2版本后,使用Eclipse打开时出现报错Failed to create the Java Virtual Machine的问题,并提供了解决方法。 ... [详细]
  • 在说Hibernate映射前,我们先来了解下对象关系映射ORM。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现。这样开发人员就可以把对数据库的操作转化为对 ... [详细]
  • 本文介绍了在SpringBoot中集成thymeleaf前端模版的配置步骤,包括在application.properties配置文件中添加thymeleaf的配置信息,引入thymeleaf的jar包,以及创建PageController并添加index方法。 ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • 本文详细介绍了Linux中进程控制块PCBtask_struct结构体的结构和作用,包括进程状态、进程号、待处理信号、进程地址空间、调度标志、锁深度、基本时间片、调度策略以及内存管理信息等方面的内容。阅读本文可以更加深入地了解Linux进程管理的原理和机制。 ... [详细]
  • 本文介绍了通过ABAP开发往外网发邮件的需求,并提供了配置和代码整理的资料。其中包括了配置SAP邮件服务器的步骤和ABAP写发送邮件代码的过程。通过RZ10配置参数和icm/server_port_1的设定,可以实现向Sap User和外部邮件发送邮件的功能。希望对需要的开发人员有帮助。摘要长度:184字。 ... [详细]
  • 动态规划算法的基本步骤及最长递增子序列问题详解
    本文详细介绍了动态规划算法的基本步骤,包括划分阶段、选择状态、决策和状态转移方程,并以最长递增子序列问题为例进行了详细解析。动态规划算法的有效性依赖于问题本身所具有的最优子结构性质和子问题重叠性质。通过将子问题的解保存在一个表中,在以后尽可能多地利用这些子问题的解,从而提高算法的效率。 ... [详细]
  • 在project.properties添加#Projecttarget.targetandroid-19android.library.reference.1..Sliding ... [详细]
  • PDF内容编辑的两种小方法,你知道怎么操作吗?
    本文介绍了两种PDF内容编辑的方法:迅捷PDF编辑器和Adobe Acrobat DC。使用迅捷PDF编辑器,用户可以通过选择需要更改的文字内容并设置字体形式、大小和颜色来编辑PDF文件。而使用Adobe Acrobat DC,则可以通过在软件中点击编辑来编辑PDF文件。PDF文件的编辑可以帮助办公人员进行文件内容的修改和定制。 ... [详细]
  • CentOS 6.5安装VMware Tools及共享文件夹显示问题解决方法
    本文介绍了在CentOS 6.5上安装VMware Tools及解决共享文件夹显示问题的方法。包括清空CD/DVD使用的ISO镜像文件、创建挂载目录、改变光驱设备的读写权限等步骤。最后给出了拷贝解压VMware Tools的操作。 ... [详细]
author-avatar
芋荌源
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有