欢迎来到皮皮网网首页

【返攻源码公式】【中九源码】【工长app源码】avplayer源码分析

来源:JAVA开发erp项目源码 时间:2024-11-24 22:36:27

1.iOS多模式&富交互视频播放器TTAVPlayer(附源码)
2.如何开发一个 AVPlayer iPad 程序

avplayer源码分析

iOS多模式&富交互视频播放器TTAVPlayer(附源码)

       源码可见:[直接点击]

       为了提升播放器的源码交互友好性与适应多样化业务需求,决定对播放器进行优化。分析

       本次优化主要目标是源码实现四个播放模式:普通模式、竖屏模式、分析返攻源码公式横屏模式、源码静音模式。分析

       普通模式用于商品内容和文章内容的源码嵌套播放,H5桥接播放。分析竖屏模式提供沉浸式体验,源码用于H5桥接播放与静音播放时的分析点击查看详情场景,如微博、源码中九源码手淘微淘。分析横屏模式追求最佳播放体验,源码提供丰富的分析交互操作,如快捷音量调节、源码播放进度调整和屏幕亮度控制。工长app源码静音模式适用于列表自动播放场景,如手淘微淘列表。

       最终实现效果包括不同模式的支持,以及基础功能和自定义模式的扩展性设计。

       设计思路强调“最小接入成本与最大扩展性”。ios afn源码在API和Framework层面,提供简单易用的接口,同时为自定义需求提供强大的能力。

       播放器设计包含五种模式,基于AVPlayer实现基本播放功能,png解压源码同时创建TTAVPlayerView用于展示视频及UI控件。

       TTAVPlayer负责播放控制与状态回调,TTAVPlayerView面向上层调用者,提供界面渲染和业务逻辑。

       实现中,设计确保TTAVPlayerView代码的纯净性,与业务代码解耦,专注于视频播放。

       播放器提供丰富功能,包括手势识别、自动横竖屏切换、网络切换检测、静音播放等。

       优化成果旨在提升播放器的交互体验与适应性,欢迎提供反馈、报告Bug或提出新功能需求。

       获取源码、Demo与****:

       知乎:[直接点击]

       GitHub:[直接点击]

       简书:[直接点击]

如何开发一个 AVPlayer iPad 程序

       AirPlay 并不是新东西,它在 iOS 4.3 SDK 中就存在了。但AirPlay API 中不断有新的东西加入。其中一个有趣新特性是 iPad 程序能通过 Apple TV 2 播放来自 iOS 设备上的内容,或者镜像iPad 2 上的屏幕内容。

       ç®€è€Œè¨€ä¹‹ï¼ŒAirPlay 就是将媒体内容投放到高清显示器(电视)或高清音效系统上。Apple TV 2 则是用于连接 iOS 设备或 iTunes与高清设备之间的桥梁。

       éšç€ iOS 5 的出现,任何使用 AV Foundation 类的程序都能从程序中投放音视频内容到 Apple TV。你可以用MPMoviewPlayerController 通过 AirPlay 将当前正在播放的内容投影到高清电视或其它高清显示设备上。另一个进步是从UIWebView 投放视频,这是激动人心的改进,因为这意味着我们可以直接从 web 上将在线的音视频投影到电视或者 Apple TV 2 上。

       ä½¿ç”¨ AVFoundation 投影视频内容

       è¦åœ¨åº”用程序中使用 AVFoundation,需要实现 AVPlayer 并设置 allowsAirPlayVideo 为 YES 以开启 AirPlay,或者设置为NO 以关闭 AirPlay,如以下代码所示:

       -(BOOL)setAirPlay:(BOOL)airplayMode{

       return self.player.allowsAirPlayVideo=airplayMode;

       }

       ç¼–写应用程序

       ä¸ºäº†æ¼”示如何创建 AVPlayer 应用程序以及实现 AirPlay,我们将创建一个 Single View Application(注意勾选 UseStoryboards),新建一个 AVPlayer 类并实现 AirPlay 特性。

       åˆ›å»ºä¸€ä¸ª Single View Application。目标类型可以选择 iPhone、iPod 或者 iPad。创建项目之后,再导入 AV Foundation 框架。

       æŽ¥ç€åˆ›å»ºä¸€ä¸ªæ–° class,命名为 Player,并继承 UIView 类。在头文件中,加入 AVPlayer 类并增加一个 AVPlayer 属性。如下列代码所示。

       @class AVPlayer;

       @interface Player : UIView

       @property(nonatomic, strong) AVPlayer * player;

       æŽ¥ä¸‹æ¥å°±æ˜¯å®žçŽ° Player 类。

       æˆ‘们实现了最基本的 AVPlayer 需要实现的最起码的 4 个方法,同时还提供了一个方法作为我们的 AirPlay 开关。

       é¦–先我们需要一个 AVLayer 类的包装类。该类是一个 CALayer 子类,用于对媒体的可视内容进行管理。创建包装类的代码如下:

       + (Class)layerClass {

       return [AVPlayerLayer class];

       }

       ç„¶åŽä¸ºéœ€è¦ä¸€ä¸ªæ–¹æ³•ï¼Œå®žä¾‹åŒ–一个 AVPlayer 对象(我们在头文件中定义的)。如下列代码所示。

       -(AVPlayer *) player{

       return [(AVPlayerLayer *)[self layer] player];

       }

       åœ¨ setPlayer 方法中,如下列代码所示,有一个 AVPlayer 参数,用于将一个 AVPlayer 实例添加到 UIView。这个 UIView 子类,将用在主 View Controller 中。

       - (void)setPlayer:(AVPlayer*)player {

       [(AVPlayerLayer*)[self layer] setPlayer:player];

       }

       è¿™ä¸ªç±»çš„最后一个方法是 setAirPlay 方法。其参数将用于指定 AVPlayer UIView (Player)的allowsAirPlayVideo 属性。如以下代码所示。

       -(BOOL)setAirPlay:(BOOL)airplayMode{

       return self.player.allowsAirPlayVideo=airplayMode;

       }

       ä¸ºè§†é¢‘的输出指定图层(AVPLayerLayer)时,可以指定任意数量的图层,只要能方便控制内容显示。比如说处理音频和视频之间的时间同步。通过setDisplayMode,你可以设置用于显示的图层,先创建一个 AVPlayerLayer 对象作为显示图层,然后修改它的属性。默认是AVLayerVideoGravityResizeAspect 属性,另外也可以设置 AVLayerVideoGravityResizeAspectFill 属性和AVLayerVideoGravityResize 属性。 AVLayerVideoGravityResizeAspect 保持视频的宽高比并使播放内容自动适应播放窗口的大小。AVLayerVideoGravityResizeAspectFill 和前者类似,但它是以播放内容填充而不是适应播放窗口的大小。最后一个值会拉伸播放内容以适应播放窗口。

       Player 类的完整代码如下:

       #import <UIKit/UIKit.h>

       #import <AVFoundation/AVFoundation.h>

       @class AVPlayer;

       @interface Player : UIView

       @property(nonatomic, strong) AVPlayer * player;

       -(BOOL) setAirPlay:(BOOL) airplayMode;

       @end

       #import "Player.h"

       #import <AVFoundation/AVFoundation.h>

       @implementation Player

       + (Class)layerClass {

       return [AVPlayerLayer class];

       }

       -(AVPlayer *) player{

       return [(AVPlayerLayer *)[self layer] player];

       }

       - (void)setPlayer:(AVPlayer*)player {

       [(AVPlayerLayer*)[self layer] setPlayer:player];

       }

       //Enable or disable AirPlay mode

       -(BOOL)setAirPlay:(BOOL)airplayMode{

       return self.player.allowsAirPlayVideo=airplayMode;

       }

       @end

       åœ¨ç¨‹åºä¸­ä½¿ç”¨ Player (UIView子类)

       ä¸Šè¿°ä»£ç åŒ…括了Player (AVPlayer 的 UIView 子类)的.h文件和.m 文件。

       è¦åœ¨ä¸€ä¸ª UIViewController 中使用这个 AVPlayer 视图,打开 Xcode 的故事板(storyboard,前提是创建项目时使用了“useStoryboard”选项)。选中UIView(不是 UIViewController)并将它的类修改为 Player。你可以在 Identity 面板的 customeclass 字段输入,也可以从它的下拉列表中选择。

       æ‰“å¼€ Assistant Editor ,为 UIView 子类 Player 创建一个 IBOutlet,从 view 用右键拖到右边的头文件中即可。如下图所示。

       åˆ›å»ºIBActions 和 IBOutlets 连接

       åˆ›å»ºä¸€ä¸ªå§”托到 klViewController 。在 Player 上右键,从 IBOutlet 拖一个连接线到 klViewController (dock 上的黄色方块) ,如下图所示。

       æ·»åŠ å§”托连接 klViewController

       åœ¨æ•…事版中,加一个 Toolbar 。在 Toolbar 是加入两个按钮,分别将标签文本设置为 Play 和 Pause。然后加一个 Switch,用于切换AirPlay 开关状态。为这 3 个控件创建相应的 IBAction(可以用 Assistant Editor)。剩下的事情在 klViewController 类中进行。

       æ‰“å¼€ klViewController.h 文件,加入 @class Player 和 @class AVPlayer 语句并导入 AVFoundation 框架和 Player.h。源代码见下:

       #import <UIKit/UIKit.h>

       #import <AVFoundation/AVFoundation.h>

       #import "Player.h"

       @class Player;

       @class AVPlayer;

       @interface klViewController : UIViewController

       å£°æ˜Žä¸€ä¸ª AVPlayer 属性,用于加载到 Palyer 视图中。

       å£°æ˜Žä¸€ä¸ª NSURL 属性。然后是 Switch 控件的 IBOutlet(用 Assistant Editor创建)。

       kvLiewController.h 文件代码如下:

       #import <UIKit/UIKit.h>

       #import <AVFoundation/AVFoundation.h>

       #import Player.h

       @class Player;

       @class AVPlayer;

       @interface klViewController : UIViewController

       @property(nonatomic, strong) AVPlayer * myPlayer;

       @property(nonatomic, strong) NSURL * avContentUrl;

       @property (strong, nonatomic) IBOutlet Player *airPlayView;

       @property (nonatomic, retain) IBOutlet UISwitch * AirPlaySwitch;

       - (IBAction)PlayVideo:(id)sender;

       - (IBAction)PauseVideo:(id)sender;

       - (IBAction)isAirPlayOn:(id)sender;

       @end

       æŽ¥ä¸‹æ¥æ˜¯ç±»çš„实现文件。在 viewDidLoad 方法中,用一个视频文件的 URL 地址初始化 avContentUrl:

       avContentUrl = [[NSURL alloc] initWithString

       ç„¶åŽç”¨ avContentUrl 初始化一个 AVPlayer ,用于给头文件中定义的 myPlayer 属性赋值。将 myPlayer 赋给 airPlayView 的 player 属性,airPlayerView 是一个 Player 对象。如下列代码所示:

       self.myPlayer = [AVPlayer playerWithURL:avContentUrl];

       [airPlayView setPlayer:[self myPlayer]];

       çŽ°åœ¨ï¼Œè¦å®žçŽ°ä¸¤ä¸ªæŒ‰é’®çš„视频播放和暂停功能,以及 Switch 控件的 AirPlay 开关功能。播放按钮的 action 方法代码如下所示:

       - (IBAction)PlayVideo:(id)sender {

       [self.myPlayer play];

       }

       æš‚停按钮的 action 方法代码如下所示:

       - (IBAction)PauseVideo:(id)sender {

       [self.myPlayer pause];

       }

       Switch 控件的 action 方法代码如下所示:

       - (IBAction)isAirPlayOn:(id)sender {

       AirPlaySwitch = (UISwitch *) sender;

       if (AirPlaySwitch.on) {

       [airPlayView setAirPlay:NO];

       }else

       {

       [airPlayView setAirPlay:YES];

       }

       }

       ç»“å°¾

       å¦ä¸€ä¸ªä¸Ž AirPlay 有关的属性是 usesAirPlayVideoWhileAirPlayScreenIsActive ,它用于自动在在播放期间将 AVPlayer 切换到 AirPlay,当然仅仅是在 AirPlay 已开启的情况下。默认是 false 的。

       è¦è¿è¡Œæœ¬ç¤ºä¾‹ç¨‹åºï¼Œéœ€è¦åœ¨ iPad 上进行,并将 iPad 连接至 Apple TV 同一 wifi 网络,然后视频资源的 URL 必须是有效的。在模拟器中AirPlay 是无效的。

       klViewController.h 文件

       #import <UIKit/UIKit.h>

       #import <AVFoundation/AVFoundation.h>

       #import "Player.h"

       @class Player;

       @class AVPlayer;

       @interface klViewController : UIViewController

       @property(nonatomic, strong) AVPlayer * myPlayer;

       @property(nonatomic, strong) NSURL * avContentUrl;

       @property (strong, nonatomic) IBOutlet Player *airPlayView;

       @property (nonatomic, retain) IBOutlet UISwitch * AirPlaySwitch;

       - (IBAction)PlayVideo:(id)sender;

       - (IBAction)PauseVideo:(id)sender;

       - (IBAction)isAirPlayOn:(id)sender;

       @end

       klViewController.m 文件

       #import "klViewController.h"

       @implementation klViewController

       @synthesize airPlayView;

       @synthesize avContentUrl, myPlayer, AirPlaySwitch;

       - (void)didReceiveMemoryWarning

       {

       [super didReceiveMemoryWarning];

       // Release any cached data, images, etc that aren't in use.

       }

       #pragma mark - View lifecycle

       - (void)viewDidLoad

       {

       [super viewDidLoad];

       //This is an Apple sample video

       avContentUrl = [[NSURL alloc] initWithString:@" self.myPlayer = [AVPlayer playerWithURL:avContentUrl];

       [airPlayView setPlayer:[self myPlayer]];

       [self.myPlayer play];

       }

       - (void)viewDidUnload

       {

       [self setAirPlayView:nil];

       [super viewDidUnload];

       // Release any retained subviews of the main view.

       // e.g. self.myOutlet = nil;

       }

       - (void)viewWillAppear:(BOOL)animated

       {

       [super viewWillAppear:animated];

       }

       - (void)viewDidAppear:(BOOL)animated

       {

       [super viewDidAppear:animated];

       }

       - (void)viewWillDisappear:(BOOL)animated

       {

       [super viewWillDisappear:animated];

       }

       - (void)viewDidDisappear:(BOOL)animated

       {

       [super viewDidDisappear:animated];

       }

       - (BOOL)shouldAutorotateToInterfaceOrientation:(UIInterfaceOrientation)interfaceOrientation

       {

       // Return YES for supported orientations

       return (interfaceOrientation != UIInterfaceOrientationPortraitUpsideDown);

       }

       - (IBAction)PlayVideo:(id)sender {

       [self.myPlayer play];

       }

       - (IBAction)PauseVideo:(id)sender {

       [self.myPlayer pause];

       }

       - (IBAction)isAirPlayOn:(id)sender {

       AirPlaySwitch = (UISwitch *) sender;

       if (AirPlaySwitch.on) {

       [airPlayView setAirPlay:NO];

       }else

       {

       [airPlayView setAirPlay:YES];

       }

       }

       @end