FSA全栈行动 FSA全栈行动
首页
  • 移动端文章

    • Android
    • iOS
    • Flutter
  • 学习笔记

    • 《Kotlin快速入门进阶》笔记
    • 《Flutter从入门到实战》笔记
    • 《Flutter复习》笔记
前端
后端
  • 学习笔记

    • 《深入浅出设计模式Java版》笔记
  • 逆向
  • 分类
  • 标签
  • 归档
  • LinXunFeng
  • GitLqr

公众号:FSA全栈行动

记录学习过程中的知识
首页
  • 移动端文章

    • Android
    • iOS
    • Flutter
  • 学习笔记

    • 《Kotlin快速入门进阶》笔记
    • 《Flutter从入门到实战》笔记
    • 《Flutter复习》笔记
前端
后端
  • 学习笔记

    • 《深入浅出设计模式Java版》笔记
  • 逆向
  • 分类
  • 标签
  • 归档
  • LinXunFeng
  • GitLqr
  • AndroidUI

  • Android第三方SDK

  • Android混淆

  • Android仓库

  • Android新闻

  • Android系统开发

  • Android源码

  • Android注解AOP

  • Android脚本

  • AndroidTv开发

  • AndroidNDK

  • Android音视频

  • Android热修复

  • Android性能优化

  • Android云游戏

  • Android插件化

  • iOSUI

  • iOS工具

  • iOS底层原理与应用

  • iOS组件化

  • iOS音视频

    • iOS - 给高仿微信添加直播聊天功能
      • 推流
      • 拉流
      • 将IJKPlayer打包
    • iOS - 采集音视频及写入文件
    • iOS - 视频采集详解
  • iOS疑难杂症

  • iOS之Swift

  • iOS之RxSwift

  • iOS开源项目

  • iOS逆向

  • Flutter开发

  • 移动端
  • iOS音视频
LinXunFeng
2017-09-12
目录

iOS - 给高仿微信添加直播聊天功能

欢迎关注微信公众号:[FSA全栈行动 👋]

抽空给之前做的开源项目【高仿微信】 (opens new window)添加直播功能,由于时间有限,做得不是很完美,有空再去完善吧,能用就好~~

在此提供存放于百度云的完整项目【高仿微信】- 百度云 (opens new window) 希望各位能在我的GitHub上献出一个宝贵的Star 【高仿微信】- GitHub (opens new window) 谢谢

注意:直播功能的使用(对方需要先进入到对应的聊天界面)

两个测试账号: lxf lqr 密码都是123456

直播聊天

# 推流

首先第一件事当然就是搭建一个推流服务器,这里请跳转参考我之前写好的文章吧【Ubuntu安装nginx来搭建推流服务器】,这里我的服务器的ip地址是:192.168.123.191

APP上推流我使用的是第三方的库 LFLiveKit (opens new window),这个第三方库已经帮我们处理了很多事情,而且还包括美颜~~。当然,有时间我们还是要去了解一下底层的东西,这里就先不赘述,过几天抽空再做总结。

关键代码如下

// 初始化配置
let audioConfiguration = LFLiveAudioConfiguration.default()
let videoConfiguration = LFLiveVideoConfiguration.defaultConfiguration(for: .low2, outputImageOrientation: .portrait)
// 初始化session
let session = LFLiveSession(audioConfiguration: audioConfiguration, videoConfiguration: videoConfiguration)
// 设置代理
// session?.delegate = self
// 设置展示的View
session?.preView = self.view
let stream = LFLiveStreamInfo()
stream.url = "rtmp://192.168.123.191:1935/rtmplive/lxf"; // 服务器地址
session.startLive(stream)
// 开始推流
session.running = true

# 拉流

这里我使用的是B站的开源库 ijkplayer (opens new window)

为了方便可以用这个 编译好的B站开源库 (opens new window)

需要注意的是:IJKPlayer默认使用的是软解码(FFMpeng),如果需要使用硬解码需要我们进行相应的设置

// 设置"videotoolbox"的值为0为软解码(默认),设置为1则是硬解码
let options = IJKFFOptions.byDefault()
options?.setOptionIntValue(1, forKey: "videotoolbox", of: kIJKFFOptionCategoryPlayer)

let ijkPlayer = IJKFFMoviePlayerController(contentURLString: "rtmp://192.168.123.191:1935/rtmplive/lxf", with: options)
// 需保存起来
self.ijkPlayer = ijkPlayer
ijkPlayer?.view.frame = view.bounds
view.addSubview(ijkPlayer!.view)

// 准备播放,当视频准备好的时候会自动进行播放
ijkPlayer?.prepareToPlay()

# 将IJKPlayer打包

从B站的gitHub上下载的 ijkplayer (opens new window) 需要手动编译出来,跟着说明走就可以了,这里就不赘述咯,接下来我们将它打包,方便使用

如果你不跟着说明走的话会提示找不到 avformat.h 这个头文件

avformat.h

这时你需要在终端cd到ijkplayer这个目录,然后执行 init-ios.sh文件,如图

目录

init-ios.sh

然后经过一段漫长的时间之后,在ios目录下就多出了这些ffmpeg相关的目录

ffmpeg相关目录

这个操作是在下载ffmpeg源码,然缺失的avformat.h就在里面

avformat.h

打开项目 IJKMediaPlayer

打开项目

设置为 release,这样打出来的包会小些

Edit Scheme

release

选择真机和模拟器,各Command+B编译一次

真机

模拟器

右击,Show in Finder

如图,就有两个文件夹,里面存放着的就是我们编译出来的库

Paste_Image.png

可以使用如下命令查看信息

lipo -info IJKMediaFramework

查看所支持的处理器

默认模拟器编译出来的包是不支持i386,如果希望支持的话 进入项目的 Build Settings,将 Build Active Architecture Only 设置为NO

Build Active Architecture Only

好,现在对编译出来的包进行合并,这样就即支持真机,也支持模拟器

// 格式
// lipo -create  path1  path2  -output  frameName

lipo -create Release-iphoneos/IJKMediaFramework.framework/IJKMediaFramework Release-iphonesimulator/IJKMediaFramework.framework/IJKMediaFramework -output IJKMediaFramework

合并

将合并出来的IJKMediaFramework替换 IJKMediaFramework.framework中的IJKMediaFramework,最后将替换好的 IJKMediaFramework.framework 拖入到项目中使用即可。

替换

最后,附上编译好的IJKMediaFramework

链接:https://pan.baidu.com/s/1eRYlJ7W 密码:9iaw

#iOS#Swift
iOS-组件化开发(四):fastlane实现pod自动化
iOS - 采集音视频及写入文件

← iOS-组件化开发(四):fastlane实现pod自动化 iOS - 采集音视频及写入文件→

最近更新
01
Flutter - Xcode16 还原编译速度
04-05
02
AI - 免费的 Cursor 平替方案
03-30
03
Android - 2025年安卓真的闭源了吗
03-28
更多文章>
Theme by Vdoing | Copyright © 2020-2025 FSA全栈行动
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式
×