Android深入系统完全讲解(43)

news2025/1/12 9:53:18

为什么要编码?这里主要是因为信息有甬余需要压缩,所以会出现各类算法。如果存储原始
数据,那就很大。
举例来说,BMP,压缩算法有 jpg,png 等等。
比如 PCM,压缩的 mp3
H.264 相关
这里我们看一下,关于 H264 的一些概念:
H.264 是国际标准化组织(ISO)和国际电信联盟(ITU)共同提出的继 MPEG4 之后的新一代
数字视频压缩格式。H.264 是 ITU-T 以 H.26x 系列为名称命名的视频编解码技术标准之一。
H.264 是 ITU-T 的 VCEG(视频编码专家组)和 ISO/IEC 的 MPEG(活动图像编码专家组)的联
合视频组(JVT:joint video team)开发的一个数字视频编码标准。该标准最早来自于 ITU-T
的称之为 H.26L 的项目的开发。H.26L 这个名称虽然不太常见,但是一直被使用着。H.264
是 ITU-T 以 H.26x 系列为名称命名的标准之一,AVC 是 ISO/IEC MPEG 一方的称呼。
具有的一些优势:
1.低码率(Low Bit Rate):和 MPEG2 和 MPEG4 ASP 等压缩技术相比,在同等图像质
量下,采用 H.264 技术压缩后的数据量只有 MPEG2 的 1/8,MPEG4 的 1/3。 [1]
2.高质量的图像:H.264 能提供连续、流畅的高质量图像(DVD 质量)。 [1]
3.容错能力强:H.264 提供了解决在不稳定网络环境下容易发生的丢包等错误的必要工具。
[1]
4.网络适应性强:H.264 提供了网络抽象层(Network Abstraction Layer),使得 H.264
的文件能容易地在不同网络上传输(例如互联网,CDMA,GPRS,WCDMA,CDMA2000
等)。 [1]
H.264 最大的优势是具有很高的数据压缩比率,在同等图像质量的条件下,H.264 的压缩比
是 MPEG-2 的 2 倍以上,是 MPEG-4 的 1.5~2 倍。举个例子,原始文件的大小如果为 88GB,
采用 MPEG-2 压缩标准压缩后变成 3.5GB,压缩比为 25∶1,而采用 H.264 压缩标准压缩
后变为 879MB,从 88GB 到 879MB,H.264 的压缩比达到惊人的 102∶1。低码率(Low Bit
Rate)对 H.264 的高的压缩比起到了重要的作用,和 MPEG-2 和 MPEG-4 ASP 等压缩技
术相比,H.264 压缩技术将大大节省用户的下载时间和数据流量收费。尤其值得一提的是,
H.264 在具有高压缩比的同时还拥有高质量流畅的图像,正因为如此,经过 H.264 压缩的
视频数据,在网络传输过程中所需要的带宽更少,也更加经济。 [1]具体参考这里,不粘贴了:
https://baike.baidu.com/item/H.264/1022230?fromtitle=H264&fromid=7338504&fr=aladdin
我们这里讲一些概念:
在 H.264 定义的结构中,一个视频图像编码后的数据叫做一帧。 一帧是由一个或多个片
(slice)组成的,一个片是由一个或多个宏块(MB)组成的(宏块是 H264 编码的基本单位),
一个宏块是由 16x16 的 yuv 数据组成的。
这里就是帧率,一秒多少帧,也就是有多个画面在一秒出现,默认的叫做 60 帧,现在有 120
帧,电视一般就是 23 帧就够了。
游戏类的默认需要 50-60 帧率,否则会出现卡顿现象。
在视频中,有三类帧,分别是 I 帧,P 帧和 B 帧 ,其中 I 帧就是画面帧。而 B 和 P 帧就是
做的运算,不是全部图像的帧。而 P 帧是参考前面的 I 帧生成,而 B 帧是参考前后的图像帧
生成的。
在视频画面播放过程中,若 I 帧丢失了,则后面的 P 帧也就随着解不出来,就会出现视频画
面黑屏的现象;若 P 帧丢失了,则视频画面会出现花屏、马赛克等现象。
GOP 是一组连续的画面。。GOP 结构一般有两个数字,其中一个是 GOP 的长度(即两个 I
帧之间的 B 帧和 P 帧数),另一个数字为 I 帧和 P 帧之间的间隔距离(即 B 帧数)。在一个
GOP 内 I 帧解码不依赖任何的其它帧,P 帧解码则依赖前面的 I 帧或 P 帧,B 帧解码依赖前
面的 I 帧或 P 帧及其后最近的一个 P 帧。
注意:在码率不变的前提下,GOP 值越大,P、B 帧的数量会越多,平均每个 I、P、B 帧所
占用的字节数就越多,也就更容易获取较好的图像质量;Reference 越大,B 帧的数量越多,
同理也更容易获得较好的图像质量。但是通过提高 GOP 值来提高图像质量是有限度的。H264
编码器在遇到场景切换的情况时,会自动强制插入一个 I 帧,此时实际的 GOP 值被缩短了。
另一方面,在一个 GOP 中,P、B 帧是由 I 帧预测得到的,当 I 帧的图像质量比较差时,会
影响到一个 GOP 中后续 P、B 帧的图像质量,直到下一个 GOP 开始才有可能得以恢复,所
以 GOP 值也不宜设置过大。同时,由于 P、B 帧的复杂度大于 I 帧,所以过多的 P、 B 帧会
影响编码效率,使编码效率降低。另外,过长的 GOP 还会影响 Seek 操作的响应速度,由于
P、B 帧是由前面的 I 或 P 帧预测得到的,所以 Seek 操作需要直接定位,解码某一个 P 或 B
帧时,需要先解码得到本 GOP 内的 I 帧及之前的 N 个预测帧才可以,GOP 值越长,需要解
码的预测帧就越多,seek 响应的时间也越长。
GOP 中的 I 帧又分为普通 I 帧和 IDR 帧,IDR 帧就是 GOP 的第一个 I 帧,这样区分是为了方
便控制编码和解码的流程。 IDR 帧一定是 I 帧,但是 I 帧不一定是 IDR 帧。
IDR 帧因为附带 SPS、PPS 等信息,解码器在收到 IDR 帧时,需要做的工作就是:把所有的 PPS和 SPS 参数进行更新。
可以看出来 IDR 帧的作用是让解码器立刻刷新相关数据信息,避免出现较大的解码错误问
题。
引入 IDR 帧机制是为了解码的重同步,当解码器解码到 IDR 帧时,立即将参考帧队列清空,
将已解码的数据全部输出或抛弃,重新查找参数集,开始一个新的序列。这样,如果前一个
序列出现错误,在这里可以获得重新同步的机会。IDR 帧之后的帧永远不会使用 IDR 帧之前
的数据来解码。
这里记住一点,引入的这些概念,值,信息都是为了解决所谓的纠错,处理数据,编解码
相关。它们引入都是为了解决一类问题。
我们在这里不会细究细节,因为这个要挖就偏离了我们的课程,太过繁琐,这类知识应该是
自行学习,遇到问题解决不了,一起来看。
我的微信 code_gg_boy 随时交流。
最后我们来看下音视频编解码这块,最为经典的一个库,市面大多数音视频软件,底层都是
用的这个库,可以看到它的强大。
在这里插入图片描述

这份文档里面,包含了如何编译,以及所用的所有工具,源码,同时提供了一个测试的 AS
工程。

使用 ubuntu 14.04
安装
apt-get install yasm
apt-get install pkg-config
安装 nasm 2.13 ,这个已经下载下来了,直接
./configure
make
sudo make install
然后进入 x264 编译
./build.sh
输出结果在当前目录的 android/armv7-a
然后进入 FFmpeg-n3.4.5,创建 x264 目录,把 android/armv7-a 目录放进去
编译./build.sh
最后说明下这个项目我使用的 api19,也就是 4.4,如果想更换自己的 api 值,修改 build.sh
里面的具体数字就可以了。
同时编译的时候,修改下文档中的 ndk 路径,build.sh 里面的 ndk 路径修改成自己的就可以
了。
编译完成,当前目录的 android 下面就是我们要的结果。
然后使用 android 项目进行处理就是了。

技术的学习关键点
是什么?思路。
而我这里分享一个学习的经典路线,先厘清总框架,找到思路,然后再逐步击破。
这里关于音视频的就是:
总体分为几部分:
1 绘制
2 编解码格式
3 Android 平台的 FFmpeg 开源移植
4 应用场景
概括成一句话就是,视频如果解析出来,视频如何显示画面,声音怎么播放。
然后这里面的
市场机会
在哪里?
1 支持格式扩展
2 特效画面 gpuimage 框架
3 倍速播放
4 格式转化,自动制作工具
5 移植到嵌入式板子
那么我们第二版就来完成这个任务,首先我们先说一个,就是绘制。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/182081.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

剑指 Offer 09. 用两个栈实现队列(力扣)

一:题目用两个栈实现一个队列。队列的声明如下,请实现它的两个函数 appendTail 和 deleteHead ,分别完成在队列尾部插入整数和在队列头部删除整数的功能。(若队列中没有元素,deleteHead 操作返回 -1 )示例 1:输入&…

小米万兆路由器里的Docker安装Alist

小米2022年12月份发布了万兆路由器,里面可以使用Docker。 今天尝试在小米的万兆路由器里安装Alist v3.9.2。 准备工作 请参考https://engchina.blog.csdn.net/article/details/128515422的准备工作。 创建存储 在第三方管理(SimpleDocker),单击"…

Scala-变量和数据类型

注释在Scala中注释和Java基本一样单行注释:// 多行注释:/* */ 文档注释:/****/变量和常量基本语法声明变量:var 变量名 [:变量类型] 初始值 如:var a:Int 10 声明常量:val 变量名 [:常量类型] 初始值 如…

深度卷积神经网络、池化层

目录1.深度卷积神经网络(a deep convolutional neural network)输入图像的维度是,如果,计算输出图像维度公式:。s表示步幅,p表示填充的层数。filters的通道数是和输入图像的通道数保持一致的。分析上图案例:第一层卷积…

《深入浅出计算机组成原理》学习笔记 Day13

数据通路(中)1. 时钟信号的硬件实现2. 通过 D 触发器实现存储功能参考1. 时钟信号的硬件实现 有些电路只要需要给定输入,就能得到固定的输出,这样的电路称为组合逻辑电路(Combination Logic Circuit)。 时…

如何使用自己的虚拟机(linux)做个RAID玩?

在虚拟机原有基础上添加两块磁盘(均20G),步骤如下:使用命令“lsblk”检查添加是否生效;使用命令“mdadm”进行linux的raid管理(先安装mdadm工具)创建RAID1,名字为md1,即使用mdadm命令…

虚拟机字节码执行引擎

------摘自周志明 《深入理解Java虚拟机》运行时栈帧结构Java虚拟机以方法作为最基本的执行单元,“栈帧”(Stack Frame)则是用于支持虚拟机进行方法调用和方法执行背后的数据结构,它也是虚拟机运行时数据区中的虚拟机栈&#xff…

C语言及算法设计课程实验三:最简单的C程序设计——顺序程序设计((一、二、三、四)的综合文章)

C语言及算法设计课程实验三:最简单的C程序设计——顺序程序设计((一、二、三、四)的综合文章)一、实验目的二、 实验内容2.1、实验内容1:通过下面的程序掌握各种格式转换符的正确使用方法2.2、实验内容2&am…

十年聚焦,巨杉数据库再获毕马威2022领先金融科技50企业殊荣

巨杉数据库凭借在金融科技与分布式数据库领域出色的市场表现与过硬的技术实力,成功入选“2022中国领先金融科技50企业”,成为本次榜单唯一入选的分布式数据库厂商。 1月16日,「2022毕马威中国金融科技企业双50榜单」(下简称榜单&a…

数组扁平化,操作方法

数组扁平化是指将一个多维数组变成一维数组。 [1, [[2, 3], 4]] --> [1, 2, 3, 4] 目录 方法1: Array.prototype.flat() 方法2:Array.prototype.toString() 和 Array.prototype.join() 方法3:递归 方法4:扩展运算符 方法5…

Centos下安装ActiveMQ消息中间件

记录一下在centos7.x下面安装activeMQ消息中间件在安装ActiveMQ之前必须保证服务器安装了java环境安装java环境的地址:安装java环境找到activeMQ的官网下载安装包https://activemq.apache.org/components/classic/download/java版本是java8从官网下载后(apache-activemq-5.16.5…

【Linux】题解:生产者与消费者模型(附源代码)

【Linux】题解:生产者与消费者模型(附源代码) 摘要:本文主要介绍生产者与消费者模型,其中主要内容分为对该模型的介绍及分析,阻塞队列实现该模型,并对其升级实现多生产者多消费者并行执行。其中…

Day14 基于AOP的声明式事务控制

1 Spring 事务编程概述PlatformTransactionManager TransactionDefinition TransactionStatus2 搭建环境数据库准备一个账户表tb account;dao层准备一个AccountMapper,包括incrMoney和decrMoney两个方法;service层准备一个transferMoney方法,分别调用in…

18行列式及其性质

从此课开始,就进入了这门课的第二部分。迄今为止,已经学习了很多关于长方矩阵的知识,现在,把注意力转向方阵,探讨两个大的话题:行列式和特征值,需要行列式的重要原因是求特征值。 行列式是跟每…

U3772频谱分析仪

18320918653 U3772 新的便携式频谱分析仪具有体积小,重量轻的特点,可以在微波和毫米波范围内测量无线信号日本株式会社爱德万测试是全球半导体测试系统的领先企业,于2005年7月6日发布了一种新的便携式频谱分析仪U3771(频率达到3…

[Java-多线程] 锁原理(轻量级锁、锁膨胀、自旋锁、偏向锁)

1.Java对象头 我们平时使用的对象都是由两部分组成, 第一部分是对象头, 第二部分是对象的成员变量, 这里我么主要讲解对象头, 以32为虚拟机为例 : Object Header (64 bits)Mark Word (32 bits)Klass Word (32 bits)Klass Word : 每个对象都有类型 通过Klass Word就可以找到对应…

离散数学与组合数学-07命题逻辑

文章目录离散数学与组合数学-07命题逻辑7.1 命题逻辑-什么是命题7.1.1 数理逻辑发展7.1.2 什么是命题7.1.3 复合命题7.2 命题逻辑-命题联结词7.2.1 否定联结词7.2.2 合取联结词7.2.3 析取联结词7.2.4 蕴涵联结词7.2.5 等价联结词7.3 命题逻辑-命题符号化及应用7.3.1 联结词总结…

什么是JMM模型

什么是JMM模型?Java内存模型(Java Memory Model简称JMM)是一种抽象的概念,并不真实存在,它描述的是一组规则或规范,通过这组规范定义了程序中各个变量(包括实例字段,静态字段和构成数组对象的元素&#xff…

11. 线程本地变量ThreadLocal的使用

1. 对ThreadLocal的理解 ThreadLocal,有人称它为线程本地变量,也有人称它为线程本地存储,其实表达的意思是一样的。ThreadLocal在每一个变量中都会创建一个副本,每个线程都可以访问自己内部的副本变量。 在多线程环境下&#xff…

tomcat 的并发能力分析

tomcat 参考:Tomcat的3个参数acceptCount、maxConnections、maxThreads Tomcat 的核心组件 Tomcat 由 2 大核心组件组成:Connector、Container Tomcat 处理请求的过程 请求在 tomcat 服务器的处理过程(BIO 模式) 客户端与服务…