iOS实现视频播放全屏和取消全屏功能

本文实例为大家分享了iOS实现视频播放和取消全屏功能具体代码,供大家参考,具体内容如下

iOS 视频播放全屏和取消全屏功能实现,所需全屏的视频所在的vc需要导航控制器控制
自定义 全屏vc VedioPlayerViewController 并定义属性

/// 自定义的那个视频类
///@property (nonatomic,strong) VedioPlayer *vedioPlayer;

在VedioPlayer中定义属性

///视频展示的view 的父视图
@property (nonatomic,strong) UIView *currentSuperView;

在视频类定义方法 全屏实现

///取消全屏
- (void)fullScreen:(UIBarButtonItem *)btnItem{
 ///视频展示的view 的父视图
 self.currentSuperView = self.superview;
 ///拿到window
 UIWindow *window = [UIApplication sharedApplication].keyWindow;
 ///全屏vc初始化
 VedioPlayerViewController *vc = [VedioPlayerViewController new];
 ///判断是否由导航控制器控制
 if ([window.rootViewController isKindOfClass:[UINavigationController class]]) {
  ///拿到导航控制器控制
  UINavigationController *nvc = (UINavigationController *)window.rootViewController;
  ///把全屏视频的vc推进去
  [nvc pushViewController:vc animated:NO];
  ///重新设置视频大小
  [self setFrame:CGRectMake(0, 0, vc.view.frame.size.width, vc.view.frame.size.height)];

  //全屏后 按钮绑定取消全屏方法
  [self.fullScreenItem setAction:@selector(cancelFullScreen:)];

  ///vc.conciseVedioPlayer = self;
  ///添加视频到全屏vc
  [vc.view addSubview:self];

 ///自动播放
 [vc.conciseVedioPlayer startOrStop];

 }

}

在视频类定义方法 取消全屏实现

- (void)cancelFullScreen:(UIBarButtonItem *)btnItem{

 ///拿到window
 UIWindow *window = [UIApplication sharedApplication].keyWindow;
 ///判断是否由导航控制器控制
 if ([window.rootViewController isKindOfClass:[UINavigationController class]]) {
  ///拿到导航控制器控制
  UINavigationController *nvc = (UINavigationController *)window.rootViewController;
  ///推出一个vc,自然就回到原来的视图了
  [nvc popViewControllerAnimated:NO];
  ///把视频添加到原本的视图
  [self.currentSuperView addSubview:self];
  ///重新设置视频大小
  [self setFrame:self.currentFrame];

  //取消全屏后 按钮重新绑定全屏方法
  [self.fullScreenItem setAction:@selector(fullScreen:)];
   ///自动播放
  [self startOrStop];
 }

}

ios视频下载到本地相册

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • iOS开发中音频视频播放的简单实现方法

    前言 我们在平时的iOS开发中,音视频的播放有很多种,目前系统的自带的都属于 AVFoundation 框架,更加接近于底层,所以灵活性很强,更加方便自定义 还有就是第三方音视频视频播放,特点是功能强大,实现简单,支持流媒体,下面来逐一介绍,给大家参考学习,下面来一起看看详细的介绍吧. 播放系统音效或者短音效 注意: 这里的资源长度最多30秒 资源必须在 Target --> Build Phases --> Copy Bundle Resources 引入资源文件,否则获取不到文件 if l

  • 详解iOS视频播放方式

    多媒体这整个系列的文章自己也准备好开始整理了,先从视频音频最简单也是最常用的播放出发慢慢的往下深究,探索到底层的编码解码等等,这篇文章就从视频的播放这个最简单的说起. iOS的视频播放方式有几种?其实要是只是简单的想播放一段视频并且对UI没什么要求的话的确比较简单,很容易搞定,但我相信这种情况除了你的Demo一般是不会出现的,对播放UI的定义以及可能有各种不同的需求对应着你是不能随便写个播放器就没事了的. 最原始的播放 要不是刚接触iOS开发的同学应该是知道MediaPlayer这个框架的,要是

  • 浅析iOS中视频播放的几种方案

    1.AVPlayer (1) 优缺点 优点:可以自定义 UI, 进行控制 缺点:单纯的播放,没有控制 UI(进度,暂停,播放等按钮),而且如果要显示播放界面, 需要借助AVPlayerLayer, 添加图层到需要展示的图层上 (2)实现远程视频播放 实现播放功能(只有声音) 1.导入框架 #import <AVFoundation/AVFoundation.h> 2.通过远程 URL 创建 AVPlayer 对象 NSURL *remoteURL = [NSURL URLWithString:

  • iOS实现视频播放全屏和取消全屏功能

    本文实例为大家分享了iOS实现视频播放和取消全屏功能具体代码,供大家参考,具体内容如下 iOS 视频播放全屏和取消全屏功能实现,所需全屏的视频所在的vc需要导航控制器控制 自定义 全屏vc VedioPlayerViewController 并定义属性 /// 自定义的那个视频类 ///@property (nonatomic,strong) VedioPlayer *vedioPlayer; 在VedioPlayer中定义属性 ///视频展示的view 的父视图 @property (nona

  • C#窗体程序实现全屏及取消全屏步骤

    由于项目需要,需要用vs窗体程序实现播放视频的窗口的全屏和取消全屏. 具体实现界面如图: 这是初始状态,视频框的右上角就是控制全屏的按钮 这是全屏后的状态,此时全屏按钮变成了取消全屏的样式 注:为了界面的美观我的全屏并没有把左边的那些控件也盖住,但是是可以设置的,下边代码部分我会进行讲解. 1.首先说明一下我所用的控件及我的项目中控件的名称,以便大家理解. 显示视频的黑框是一个picturebox即代码中的VideoPlayWnd,全屏/取消全屏是一个button即代码中的button4 2.具

  • 基于JavaScript实现复选框的全选和取消全选

    本文实例为大家分享了js复选框的全选和取消全选的具体代码,供大家参考,具体内容如下 效果图: 测试代码如下: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title></title> <style> li{list-style: none;} </style> </head>

  • Javascript实现CheckBox的全选与取消全选的代码

    本文介绍的方法,触发条件独立,可以全选或取消全选指定 name 的 CheckBox , 同一页面可以有多组供全选的 CheckBox ,功能健全,通用性较强. 效果图:运行查看效果: function checkAll(name) { var el = document.getElementsByTagName('input'); var len = el.length; for(var i=0; i 字母全选开关 a b c d e f g 数字全选开关 1 2 3 [Ctrl+A 全选 注

  • jquery操作checkbox实现全选和取消全选

    今天这样写了一个全选和取消全选的功能: 全选:$(":checkbox").attr("checked","checked"); 取消全选:$(":checkbox").removeAttr("checked"); 获取选中的:$(":checked[checked='checked']") 发现点全选可以,在点取消全选也可以,获取选中的失效,接下来再点任何按钮都没有效果了 这样行不通,

  • js实现复选框的全选和取消全选效果

    在很多网站都有这样的功能,当点击一个全选按钮之后,所有的复选框都会被选中,再点击之后会取消全选,功能非常的人性化,可以省却很多人力,下面就简单介绍一下JS如何实现此功能,代码实例如下: 以下是代码: <html> <head> <meta charset=" utf-8"> <meta name="author" content="http://hovertree.com/" /> <titl

  • vue 实现搜索的结果页面支持全选与取消全选功能

    演示地址,打开.搜索.随便点 http://msisliao.github.io/dem... npm i element-ui -S // main.js import ElementUI from 'element-ui' import 'element-ui/lib/theme-chalk/index.css' Vue.use(ElementUI) demo功能概览 默认没有全选,搜索时支持全选与取消全选, 将选择的数据添加到已选中,已选删除时改变当前搜索列表的状态与全选按钮的状态 全选时

  • 微信小程序实现多选框全选与取消全选功能示例

    本文实例讲述了微信小程序实现多选框全选与取消全选功能.分享给大家供大家参考,具体如下: js部分: page({ data: { select_all:false, listData: [{code: "111",text: "text1",typ: "type1",}, {code: "021",text: "text2",typ: "type2",}, {code: "11

  • JavaScript实现复选框全选和取消全选

    JS网页–全选和取消全选,供大家参考,具体内容如下 表格,初始状态下复选框都是未选中状态,选中表头的复选框后,下面几个复选框变为选中状态,取消表头复选框选中状态后,下面几个复选框选中状态也随之取消:下面的几个复选框同时选中时,表头的复选框也随之选中. <!DOCTYPE html> <html lang="zh-CN"> <head> <meta charset="UTF-8"> <meta name="

  • JS实现表单全选以及取消全选实例

    本文实例为大家分享了JS实现表单全选以及取消全选的具体代码,供大家参考,具体内容如下 实现效果: 全选按钮:点击全选按钮所有的小按钮都会被选中:点掉全选按钮,所有按钮取消选中: 小按钮:只有全部被选中,全选按钮才会被选中 思路分析: 1.全选和取消全选做法:让下面所有复选框的 checked属性(选中状态)跟随全选按钮即可 使用 this.checked 可以获得当前复选框的状态,如果是true就代表被选中,如果是false就代表没被选中. 注:<input>的 checked 属性是一个布尔

随机推荐