先上效果图
实现思路
主要思路就是用一个控制器来作为播放视频的载体,然后在让这个控制器作为根视图,视频播放完成之后那就该干嘛干嘛了。
话不多说了,下面就放代码好了
先新建一个控制器animationviewcontroller
在控制器中新建一个属性movieplayer
,记得要先引入系统库<mediaplayer/mediaplayer.h>
1
|
@property (nonatomic, strong) mpmovieplayercontroller *movieplayer; |
设置movieplayer
我是在懒加载中直接设置的
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
-(mpmovieplayercontroller *)movieplayer{ if (!_movieplayer) { _movieplayer = [[mpmovieplayercontroller alloc]init]; [_movieplayer.view setframe:self.view.bounds]; //设置自动播放 [_movieplayer setshouldautoplay:no]; //设置源类型 因为新特性一般都是播放本地的小视频 所以设置源类型为file _movieplayer.moviesourcetype = mpmoviesourcetypefile; //取消控制视图 如:播放暂停等 _movieplayer.controlstyle = mpmoviecontrolstylenone; [self.view addsubview:_movieplayer.view]; //监听播放完成 [[nsnotificationcenter defaultcenter]addobserver:self selector:@selector(playfinsihed) name:mpmovieplayerplaybackdidfinishnotification object:nil]; } return _movieplayer; } |
然后在.h
中公开一个moviepath
视频的路径,还有一个结束播放的blockplayfinished
等下需要。
animationviewcontroller
中也算差不多了,毕竟也没什么东西,接下来我们去appdelegate
中声明一个animationviewcontroller
属性
1
2
3
4
5
6
7
8
9
10
11
12
|
- (animationviewcontroller *)animationviewcontroller{ if (!_animationviewcontroller) { _animationviewcontroller = [[animationviewcontroller alloc]init]; //设置本地视频路径 _animationviewcontroller.moviepath = [[nsbundle mainbundle] pathforresource:@ "v" oftype:@ "mp4" ]; _animationviewcontroller.playfinished = ^{ uinavigationcontroller *rootnav = [[uinavigationcontroller alloc] initwithrootviewcontroller:[[viewcontroller alloc] init]]; [uiapplication sharedapplication].keywindow.rootviewcontroller = rootnav; }; } return _animationviewcontroller; } |
然后在appdelegate
的启动方法把这个控制器设为根视图
1
2
3
4
5
6
|
- ( bool )application:(uiapplication *)application didfinishlaunchingwithoptions:(nsdictionary *)launchoptions { self.window = [[uiwindow alloc]initwithframe:[uiscreen mainscreen].bounds]; self.window.rootviewcontroller = self.animationviewcontroller; [self.window makekeyandvisible]; return yes; } |
总结
这里要说一句,刚开始我用这个路径但是一直为空,后来我添加了一个名字为resource的文件夹把mp4放进去就好了,以上就是这篇文章的全部内容了,有需要的朋友们可以参考借鉴。