iOS-ijkplayer框架的集成

2024-01-31 07:38
文章标签 框架 ios 集成 ijkplayer

本文主要是介绍iOS-ijkplayer框架的集成,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

ijkplayer 是一个基于 ffplay 的轻量级 Android/iOS 视频播放器。实现了跨平台功能,API易于集成;编译配置可裁剪,方便控制安装包大小;支持硬件加速解码,更加省电,此方案目前已用于美拍和斗鱼 APP,说明ijkplayer是经得起考验的,当然用第三方SDK是最方便的,如七牛、腾讯、阿里都很好。

第一步 :到git上面下载 ijkplayer-master

1.手动到github下载,直接点击上面的链接下载即可
2.终端命令行下载

cd desktop
git clone https://github.com/Bilibili/ijkplayer.git

第二步 :打开 ijkplayer-master --> ios --> IJKMediaDemo

开始编译的时候发现报错
这里写图片描述

别急,看看报错原因发现是因为缺少文件引起的。 原来 libavformat 是 ffmpeg 中的库,而 ijkplayer 是基于 ffmpeg 这个库的,因此需要导入 ffmpeg。下面要导入ffmpeg:

  1. 输入命令 cd 到 ijkplayer-master 目录中
  2. 输入命令 ./init-ios.sh 执行脚本

注意:这里说一下,最好在网速好的环境下操作,不然可能会少下载东西!
要下载一会,文件挺大的,下载完成之后,你会发现在ios目录下就有了ffmpeg文件:
这里写图片描述

第三步 :这时候我们的 ffmpeg 就下载好了,再次运行 IJKMediaDemo

发现还是报上面的错误,因为执行init-ios.sh,只是下载ffmpeg源码,但是源码并没有参与编译,需要把源码编译成.a文件:

在 IJKMediaDemo 中我们会发现它是依赖于IJKMediaPlayer库

这里写图片描述

那好我们就打开 IJKMediaPlayer 库,看看里面是什么:

好吧,打开之后首先是看到一个上面的错误,还有就是发现 ffmpeg 有关的库不存在,真么办呢?

这里写图片描述

查看 ijkplayer-master 的 README.md,里面有说明,我们按照他的说明来操作
在这里插入图片描述

1.编译 ffmpeg 库,进入 ios 文件的目录中,如下
在这里插入图片描述

2.执行 ./compile-ffmpeg.sh clean ,目的是删除一些文件和文件夹,为编译ffmpeg.sh做准备,在编译ffmpeg.sh的时候,会自动创建刚刚删除的那些文件,为避免文件名冲突,因此在编译ffmpeg.sh之前先删除等会会自动创建的文件夹或者文件
在这里插入图片描述

3.执行 ./compile-ffmpeg.sh all 目的是编译各个平台的ffmpeg库,并生成所以平台的通用库

执行compile-ffmpeg.sh all可能会报错:
在这里插入图片描述
解决方法:

compile-ffmpeg.sh脚本中删除armv7, 修改如下:

FF_ALL_ARCHS_IOS8_SDK="arm64 i386 x86_64"

在这里插入图片描述

如果执行compile-ffmpeg.sh all后,一切顺利会出现下图:

这里写图片描述

再次运行Demo,就能成功了,因为IJKMediaPlayer库获取到ffmpeg库了

这里写图片描述

第四步 :集成ijkplayer到自己的项目中

方法一:README给出了方法
这里写图片描述

类似IJKMediaDemo工程中那样, 直接导入工程IJKMediaPlayer.xcodeproj,在这里不做介绍

方法二:把 ijkplayer 打包成 framework 导入工程中使用

下面开始介绍如何打包IJKMediaFramework.framework,按下面步骤开始一步一步做,将IJKMediaPlayer打包成静态库。在打包之前,要将刚才打开的IJKMediaDemo项目关闭,因为IJKMediaDemo中包含IJKMediaPlayer,直接打开IJKMediaPlayer是会报错的

1.打开工程IJKMediaPlayer.xcodeproj

2.打开后,选择IJKMediaFramework,如果是IJKMediaFrameworkWithSSL的话会报错的。

3.工程打开后设置工程的 scheme

这里写图片描述

4.设置好 scheme 后, 分别选择真机和模拟器进行编译, 编译完成后, 进入 Finder

注意:进入Finder后你需要在真机和模拟器两个环境下都编译一下,这里我把 Debug 和 Release 都编译了,所以出现了四个文件,我们以 Debug为例

5.开始合并两个版本的framework,合并的是下面的文件

打开终端, 进行合并, 命令行具体格式为:

lipo -create "真机版本路径" "模拟器版本路径" -output "合并后的文件路径"

我们命名为 IJKMediaFramework
这里写图片描述

回车后生成新的 IJKMediaFramework 库
这里写图片描述

下面很重要, 需要用合并后的IJKMediaFramework把原来的IJKMediaFramework替换掉

上图中的1、2两步完成后, 绿色框住的那个IJKMediaFramework.framework文件就是我们需要的框架了, 可以复制出来,稍后我们需要导入工程使用。

第五步、集成ijkplayer到iOS工程中

新建工程, 导入合并后的IJKMediaFramework.framework以及相关依赖框架以及相关依赖框架

- (void)viewDidLoad {[super viewDidLoad];self.view.backgroundColor = [UIColor whiteColor];// 拉流地址NSURL *url = [NSURL URLWithString:@"http://120.25.226.186:32812/resources/videos/minion_01.mp4"];
#ifdef DEBUG[IJKFFMoviePlayerController setLogReport:YES];[IJKFFMoviePlayerController setLogLevel:k_IJK_LOG_DEBUG];
#else[IJKFFMoviePlayerController setLogReport:NO];[IJKFFMoviePlayerController setLogLevel:k_IJK_LOG_INFO];
#endif[IJKFFMoviePlayerController checkIfFFmpegVersionMatch:YES];IJKFFOptions *options = [IJKFFOptions optionsByDefault];//    [options setOptionIntValue:2 forKey:@"videotoolbox" ofCategory:kIJKFFOptionCategoryPlayer];//    [options setPlayerOptionIntValue:1 forKey:@"videotoolbox"];options.showHudView = YES;self.player = [[IJKFFMoviePlayerController alloc] initWithContentURL:url withOptions:options];self.player.view.autoresizingMask = UIViewAutoresizingFlexibleWidth|UIViewAutoresizingFlexibleHeight;self.player.view.frame = self.view.bounds;self.player.scalingMode = IJKMPMovieScalingModeAspectFit;self.player.shouldAutoplay = YES;self.view.autoresizesSubviews = YES;[self.view addSubview:self.player.view];
}
- (void)viewWillAppear:(BOOL)animated
{[super viewWillAppear:animated];[self.player prepareToPlay];[self.player play];
}
- (void)viewWillDisappear:(BOOL)animated
{[super viewWillDisappear:animated];// 界面消失,一定要记得停止播放[self.player pause];[self.player stop];[self.player shutdown];
}

至此, ijkplayer 集成完毕!

但是我集成之后发现播放网络视频的时候只有声音没有画面,很尴尬,到官方讨论区上找答案,发现有个答案都说可以https://github.com/Bilibili/ijkplayer/issues/3643,但是我亲自按照他说的做,还是没有画面,不知道什么原因,继续研究,发现问题的同学可以在评论区说下哈!!

了解更多的知识可以看看这篇博客,写的挺好的。

Demo下载地址:https://github.com/MichaelSSY/ijkplayerTest

官方讨论区:https://github.com/Bilibili/ijkplayer/issues.有问题可以在这里进行查找与提问.

这篇关于iOS-ijkplayer框架的集成的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/663016

相关文章

Spring 框架之Springfox使用详解

《Spring框架之Springfox使用详解》Springfox是Spring框架的API文档工具,集成Swagger规范,自动生成文档并支持多语言/版本,模块化设计便于扩展,但存在版本兼容性、性... 目录核心功能工作原理模块化设计使用示例注意事项优缺点优点缺点总结适用场景建议总结Springfox 是

在Spring Boot中集成RabbitMQ的实战记录

《在SpringBoot中集成RabbitMQ的实战记录》本文介绍SpringBoot集成RabbitMQ的步骤,涵盖配置连接、消息发送与接收,并对比两种定义Exchange与队列的方式:手动声明(... 目录前言准备工作1. 安装 RabbitMQ2. 消息发送者(Producer)配置1. 创建 Spr

如何在Spring Boot项目中集成MQTT协议

《如何在SpringBoot项目中集成MQTT协议》本文介绍在SpringBoot中集成MQTT的步骤,包括安装Broker、添加EclipsePaho依赖、配置连接参数、实现消息发布订阅、测试接口... 目录1. 准备工作2. 引入依赖3. 配置MQTT连接4. 创建MQTT配置类5. 实现消息发布与订阅

SpringBoot集成LiteFlow工作流引擎的完整指南

《SpringBoot集成LiteFlow工作流引擎的完整指南》LiteFlow作为一款国产轻量级规则引擎/流程引擎,以其零学习成本、高可扩展性和极致性能成为微服务架构下的理想选择,本文将详细讲解Sp... 目录一、LiteFlow核心优势二、SpringBoot集成实战三、高级特性应用1. 异步并行执行2

Python的端到端测试框架SeleniumBase使用解读

《Python的端到端测试框架SeleniumBase使用解读》:本文主要介绍Python的端到端测试框架SeleniumBase使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全... 目录SeleniumBase详细介绍及用法指南什么是 SeleniumBase?SeleniumBase

SpringBoot3应用中集成和使用Spring Retry的实践记录

《SpringBoot3应用中集成和使用SpringRetry的实践记录》SpringRetry为SpringBoot3提供重试机制,支持注解和编程式两种方式,可配置重试策略与监听器,适用于临时性故... 目录1. 简介2. 环境准备3. 使用方式3.1 注解方式 基础使用自定义重试策略失败恢复机制注意事项

SpringBoot集成LiteFlow实现轻量级工作流引擎的详细过程

《SpringBoot集成LiteFlow实现轻量级工作流引擎的详细过程》LiteFlow是一款专注于逻辑驱动流程编排的轻量级框架,它以组件化方式快速构建和执行业务流程,有效解耦复杂业务逻辑,下面给大... 目录一、基础概念1.1 组件(Component)1.2 规则(Rule)1.3 上下文(Conte

使用vscode搭建pywebview集成vue项目实践

《使用vscode搭建pywebview集成vue项目实践》:本文主要介绍使用vscode搭建pywebview集成vue项目实践,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录环境准备项目源码下载项目说明调试与生成可执行文件核心代码说明总结本节我们使用pythonpywebv

Maven项目中集成数据库文档生成工具的操作步骤

《Maven项目中集成数据库文档生成工具的操作步骤》在Maven项目中,可以通过集成数据库文档生成工具来自动生成数据库文档,本文为大家整理了使用screw-maven-plugin(推荐)的完... 目录1. 添加插件配置到 pom.XML2. 配置数据库信息3. 执行生成命令4. 高级配置选项5. 注意事

Java集成Onlyoffice的示例代码及场景分析

《Java集成Onlyoffice的示例代码及场景分析》:本文主要介绍Java集成Onlyoffice的示例代码及场景分析,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要... 需求场景:实现文档的在线编辑,团队协作总结:两个接口 + 前端页面 + 配置项接口1:一个接口,将o