博客
关于我
Android原生MediaPlayer调用时序图
阅读量:374 次
发布时间:2019-03-05

本文共 727 字,大约阅读时间需要 2 分钟。

一、引言

在Android系统中,MediaPlayer作为一个“壳”,负责接收上层应用的调用,而实际的音视频播放逻辑则主要依赖于底层的native层实现。由于MediaPlayer同时涉及apk和native层的调用逻辑,且通常通过mediaplayerservice(Binder服务)进行通信,因此了解其调用时序对于优化音视频播放性能尤为重要。以下将基于一个最简单的MediaPlayer调用流程,详细阐述其调用时序,并做一些简要分析。

二、MediaPlayer调用时序图解析

在本文中,基于一个最简单的MediaPlayer调用流程绘制了一个调用时序图。图中红色虚线框表示Binder服务,而右边蓝色虚线框则表示mediaplayerfactory最终评分并选择的播放器。需要注意的是,图中部分关键函数以蓝色字体标注。以下是需要特别注意的几点:

  • apk调用setdatasource接口后,会通过mediaplayerservice创建MediaPlayer的Binder服务。在MediaPlayerService类中,client字段已经实现了Binder的Bn端接口,不要误解为Bp端。
  • setdatasource接口的调用不仅负责创建Binder服务,还会负责mediaplayerfactory的评分和下层播放器的创建。
  • 渲染相关的初始化操作通常在apk调用prepare接口时完成,此时会实例化surface,用于后续的音视频播放渲染。
  • 从start到reset的接口调用中,MediaPlayer仅充当一个“传令兵”角色,主要用于传递控制命令。
  • 调用release接口时,native层会进行渲染资源的释放,并进行一些初始化工作。
  • 转载地址:http://dbwwz.baihongyu.com/

    你可能感兴趣的文章
    Objective-C实现Julia集算法(附完整源码)
    查看>>
    Objective-C实现jump search跳转搜索算法(附完整源码)
    查看>>
    Objective-C实现jumpSearch跳转搜索算法(附完整源码)
    查看>>
    Objective-C实现k nearest neighbours k最近邻分类算法(附完整源码)
    查看>>
    Objective-C实现k-means clustering均值聚类算法(附完整源码)
    查看>>
    Objective-C实现k-Means算法(附完整源码)
    查看>>
    Objective-C实现k-nearest算法(附完整源码)
    查看>>
    Objective-C实现KadaneAlgo计算给定数组的最大连续子数组和算法(附完整源码)
    查看>>
    Objective-C实现kadanes卡达内斯算法(附完整源码)
    查看>>
    Objective-C实现kahns algorithm卡恩算法(附完整源码)
    查看>>
    Objective-C实现karatsuba大数相乘算法(附完整源码)
    查看>>
    Objective-C实现karger算法(附完整源码)
    查看>>
    Objective-C实现KMP搜索算法(附完整源码)
    查看>>
    Objective-C实现Knapsack problem背包问题算法(附完整源码)
    查看>>
    Objective-C实现knapsack背包问题算法(附完整源码)
    查看>>
    Objective-C实现knapsack背包问题算法(附完整源码)
    查看>>
    Objective-C实现knight tour骑士之旅算法(附完整源码)
    查看>>
    Objective-C实现knight Tour骑士之旅算法(附完整源码)
    查看>>
    Objective-C实现KnightTour骑士巡回赛问题算法(附完整源码)
    查看>>
    Objective-C实现KNN算法(附完整源码)
    查看>>