Audio/Movie/Image
Audio
1. 引入AVFoundation 库,此库用于处理音频的播放。
> 使用AVAudioPlayer 播放音频,此类只能播放本地音频文件。对于流媒体(边下边播)的播放使用第三方框架实现,比较优秀的有:AudioStreamer, FreeStreamer
[[AVAudioPlayer alloc] initWithContentsOfURL: error:nil]; // 此处的url是指本地文件的位置,以file:// 开头
> AVAudioPlayer 方法及属性
// 准备播放
[player prepareToPlay];
// 播放
[player play];
// 暂停
[player pause];
// 停止
[player stop];
// 是否在播放
player.playing
// 音频的总时长
player.duration
// 音频的音量
player.volume
// 音频播放的当前时间
player.currentTime
// 音频播放时的循环次数
player.numberOfLoops // 0 表示播放一次,1 表示播放两次,依次类推。任何负数表示无限循环播放。
// 代理对象
player.delegate 协议名称:AVAudioPlayerDelegate
// 协议方法
// 一个音频播放完毕时触发此方法
- (void)audioPlayerDidFinishPlaying:(AVAudioPlayer *)player successfully:(BOOL)flag
> *若音频需支持后台播放,需以下两步操作:
— 在工程 Info.plist 在根级添加 Required background modes, 再在此项下添加子项:App plays audio or streams audio/video using AirPlay
— 在代码里配置音频会话 AVAudioSession
// 每个ios应用都有一个音频会话
[AVAudioSession sharedInstance]; // 获取唯一实例
// 设置音频会话类别
[[AVAudioSession sharedInstance] setCategory:AVAudioSessionCategoryPlayback error:nil]; // 告知系统静止其他应用的音频回放,在锁屏或后台时,仍然可以播放。
// 激活会话
[[AVAudioSession sharedInstance] setActive:YES error:nil];
> *若音频需要远程控制,即由设备下方经滑动弹出显示的控制界面
- 在播放音频的控制器视图将要显示时,开始接收远程控制事件
- (void)viewWillAppear:(BOOL)animated {
[super viewWillAppear:animated];
[[UIApplication sharedApplication] beginReceivingRemoteControlEvents];
[self becomeFirstResponder]; // 使当前视图成为第一响应者
}
- 在播放音频的控制器视图将要消失时,结束接收远程控制事件
- (void)viewWillDisappear:(BOOL)animated {
[super viewWillDisappear:animated];
[[UIApplication sharedApplication] endReceivingRemoteControlEvents];
[self resignFirstResponder];
}
- 实现父类方法
- (BOOL)canBecomeFirstResponder {
return YES;
} // 此方法默认返回NO
- 实现父类方法,远程事件接收后的处理
- (void)remoteControlReceivedWithEvent:(UIEvent *)event {
if (event.type == UIEventTypeRemoteControl) {
switch (event.subtype) {
case UIEventSubtypeRemoteControlPlay:
case UIEventSubtypeRemoteControlPause:
// 播放,暂停音频播放
break;
case UIEventSubtypeRemoteControlPreviousTrack:
// 播放上一首
break;
case UIEventSubtypeRemoteControlNextTrack:
// 播放下一首
break;
default:
break;
}
}
}
2.音频录音 AVAudioRecorder ,使用方式类似AVAudioPlayer,录音保存的路径需设置到沙盒目录下。
Movie
1. iOS 视频播放 MediaPlayer 库中的MPMoviePlayerController, 支持本地视频和网络视频播放. .
> 使用MPMoviePlayerController
// 初始化
[MPMoviePlayerController alloc] initWithContentURL:]
// 设置播放器视图的frame
moviePlayer.view.frame
// *将播放视图添加的父视图上
[superview addSubview:moviePlayer.view]
> MPMoviePlayerController 视频播放时,播放状态等信息不是通过代理来与外界交互,而是通过通知中心。
// 注册通知
// 播放状态改变
[NSNotificationCenter defaultCenter] addObserver: 观察者 selector: 方法 name:MPMoviePlayerPlaybackStateDidChangeNotification object:通知的附加内容 ]
// 播放完成
[NSNotificationCenter defaultCenter] addObserver: 观察者 selector: 方法 name:MPMoviePlayerPlaybackDidFinishNotification object:通知的附加内容 ]
[扩展] 若想定制播放控制,则需设置player.controlStyle = MPMovieControlStyleNone;
2. 除此之外,iOS中还可以使用视频视图控制器播放视频MPMoviePlayerViewController
一般以模态的方式弹出全屏播放。
> 使用 MPMoviePlayerViewController
// 初始化
[[MPMoviePlayerViewController alloc] initWithContentURL:]
// 注册通知
// 播放状态改变,播放完成是暂停
[NSNotificationCenter defaultCenter] addObserver: 观察者 selector: 方法 name:MPMoviePlayerPlaybackStateDidChangeNotification object:通知的附加内容 ]
// 播放完成
[NSNotificationCenter defaultCenter] addObserver: 观察者 selector: 方法 name:MPMoviePlayerPlaybackDidFinishNotification object:通知的附加内容 ]
// 模态方式弹出显示视频播放,不直接将播放起放到父视图控制器上
[self presentMoviePlayerViewControllerAnimated:moviePlayerViewController]
/* 此方法是MPMoviePlayerViewController 对UIViewControler 扩展的模态展示方法,增加了一种下拉展示动画效果。仍然可以使用原来的presentViewController: animated: completion:] */
3. 以上两个播放视频的类,自iOS9开始被弃用,替换使用自iOS8开始的AVKit 下的AVPlayerViewController
Image
1. 使用UIImagePickerController (图片选择器) 选择单个图片
> 初始化
[[UIImagePickerController alloc] init]
> 指定代理对象
imagePicker.delegate 协议名字<UINavigationControllerDelegate,UIImagePickerControllerDelegate>
> 设置资源类型/图片来源
imgPicker.sourceType
— UIImagePickerControllerSourceTypePhotoLibrary // 来自设备图片库
— UIImagePickerControllerSourceTypeCamera // 来自照相机
— UIImagePickerControllerSourceTypeSavedPhotosAlbum // 来自相机保存的相册
> 显示图片选择器
[self presentViewController:imgPicker animated: completion:]
> 实现协议方法获取图片数据
- (void)imagePickerController:(UIImagePickerController *)picker didFinishPickingMediaWithInfo:(NSDictionary<NSString *,id> *)info
/* info 参数中存储了所选择的图片,注意这里只能是单选的。可通过info中的土资源类型UIImagePickerControllerMediaType判断是否是图片,通过UIImagePickerControllerOriginalImage 获取所选图片的原始图片。
在获取图片后,要压缩图片,UIImageJPEGRepresentation(imgData, 0.1)一般采用此种方式,第二个参数“压缩因子”,越小,图片就越小。也可采用UIImagePNGRepresentation(imgData) 方式,这种方式比前者压缩后要大些。 */
2.[扩展] 使用AssetsLibrary或者PhotoLibrary 实现多选图片,也可借助第三方库实现
Audio/Movie/Image的更多相关文章
- html5 audio总结
前言 html5中对音频,视频播放原生支持.最近做了一个音乐播放器,得益于快过年了,才能抽出一点时间来总结一下.总的来说,html5对audio的支持非常强大, 难怪flash要死.浏览器上装播放插件 ...
- 《HTML5》 Audio/Video全解
一.标签解读 <audio> 标签属性 <audio id="media" src="http://www.abc.com/test.mp3" ...
- video/audio在ios/android上播放兼容
1.audio自动播放 <audio src='xxx.mp3' autoplay></audio> 上面是audio标签autoplay属性是自动播放,但是在安卓部分浏览器和 ...
- audio 基本功能实现(audio停止播放,audio如何静音,audio音量控制等)
audio最简单原始的播放.暂停.停止.静音.音量大小控制的功能,注意某些浏览器会有权限无法自动播放噢(video也会如此) <!doctype html> <html> &l ...
- h5自定义audio(问题及解决)
h5活动需要插入音频,但又需要自定义样式,于是自己写咯 html <!-- cur表示当前时间 max表示总时长 input表示进度条 --> <span class='cur'&g ...
- Your app declares support for audio in the UIBackgroundModes key in your Info.plist 错误
提交AppStore时候被拒绝 拒绝原因:Your app declares support for audio in the UIBackgroundModes key in your Info.p ...
- HTML5的Audio标签打造WEB音频播放器
目前,WEB页面上没有标准的方式来播放音频文件,大多数的音频文件是使用插件来播放,而众多浏览器都使用了不同的插件.而HTML5的到来,给我们提供了一个标准的方式来播放WEB中的音频文件,用户不再为浏览 ...
- 微信的audio无法自动播放的问题
一.问题 最近做了一个html5的项目,里面涉及到音乐播放,项目要求音乐进入页面就自动播放,于是我就想到了html5的audio标签,将mp3引入进去. 1.在audio标签里引入了autoplay属 ...
- HTML5 audio与video标签实现视频播放,音频播放
随着互联网的飞速发展以及HTML5的应用,越来越多的项目中用到video,audio当常用标签. <audio> 标签属性 <audio src="song.mp3&quo ...
- android audio无法自动播放
audio无法在android4.4+和ios6以上的版本自动播放,因为他们出于安全考虑,做了限制.必须用户自己手工点击才能播放,程序是控制不了播放的. 整死我了,整整搞了2天,查不出所以然,原来就这 ...
随机推荐
- JVM虚拟机—JVM的垃圾回收机制(转载)
1.前言 理解JVM的垃圾回收机制(简称GC)有什么好处呢?作为一名软件开发者,满足自己的好奇心将是一个很好的理由,不过更重要的是,理解GC工作机制可以帮助你写出更好的Java程序. 在学习GC前,你 ...
- ansible应用
前言: 假如让你在一组服务器安装某个软件,服务器少的话还可以接受,但如果有上百台服务器的话,这样会耗费大量时间,在这时候Ansible就由此而生:总之Ansible提供的很多模块十分强大. 一.关于a ...
- 图形数据库 Neo4j 开发实战【转载】
简介: Neo4j 是一个高性能的 NoSQL 图形数据库.Neo4j 使用图(graph)相关的概念来描述数据模型,把数据保存为图中的节点以及节点之间的关系.很多应用中数据之间的关系,可以很直接地使 ...
- Matplot相关(一)
——————————缩写定义—————————— import matplotlib.pyplot as plt import matplotlib as mpl ——————————函数解析———— ...
- some words
For we meet in an hour of change and challenge, in a dacade of hope and fear, in an a ...
- spring与memcached整合[转]
1, 开始肯定是下载需要的文件了,这里就下载附件里的文件就好,我也是在网上down的,放这好找.然后我们安装一下Memcache服务器,找到解压的memcached-1.2.1-win32,启动cmd ...
- idea通过springboot初始化器新建项目
1.通过初始化器新建项目,勾选后 对应生成的pom文件 以及生成的包路径 2.生成项目后点击稍后弹出的自动自动导入maven工程的改变,当pom中有依赖改变时会自动刷新导入依赖 3.删除自动生成项目的 ...
- Select the JavaScript graphing libraries you would like to compare
Select the JavaScript graphing libraries you would like to compare: Overview Summary Fus ...
- dedecms 织梦利用arcpagelist标签实现首页arclist分页
DedeCMS首页arclist分页可以利用arcpagelist标签来实现,这里说一下调用方法:首先必须在首页的<head></head>标签里面引入如下js代码: < ...
- 大家来聊聊如何PASS 360
真正做到PASS 360,启动项什么的.我觉得还是有可能的把? 虽然它就是一个流氓,但是我们要想办法比它更流氓. 只是有一个点:那就是行为监控,那既然行为监控(云分析抛开).那就找一个可信任的程序来调 ...