zoukankan      html  css  js  c++  java
  • iOS音频与视频的开发(一)-使用AVAudioPlayer播放音乐、使用AVPlayerViewController播放视频

      iOS的多媒体支持非常强大,它提供了多套支持多媒体的API,无论是音频、视频的播放,还是录制,iOS都提供了多种API支持。借助于这些API的支持,iOS应用既可以查看、播放手机相册中的照片、视频,也可以播放来自网络的视频.iOS也提供了对摄像头、麦克风的支持。

    1、使用AVAudioPlayer播放音乐

      AVAudioPlayer比较简单,当控制AVAudioPlayer对象装载音频完成后,就可以调用AVAudioPlayer的如下方法进行播放控制了。

      如:play/pause/stop/prepareToPlay.

      其中:如果调用play方法时,如果音频还没有准备好,程序会隐式先执行prepareToPlay方法。

      除此之外,AVAudioPlayer还提供了如下属性来访问音频文件的相关信息。

      playing:该属性(只读)返回播放器是否正在播放。

      pan:该属性用于设置或返回立体声平衡。如果该属性设为-1.0,则完全在左边播放;如果设为0.0则左右音量相同;如果设为1.0,则完全右边播放。

      enableRate:是否允许改边播放速率。

      numberOfLoops:设置循环次数。如果为-1标识无限循环。

      numberOfChannels:返回音频的声道数目。

      duration:音频的持续时间

      currentTime:获取音频的播放点。

      url:返回播放器关联的音频URL。

     案例代码:

    import UIKit
    import AVKit
    class NADiscoverViewController : UIViewController {
        
        lazy var audioPlayer = AVAudioPlayer.init()
        var durationTime:Float = 0.0 //播放时长
        var timer : Timer?
        
        lazy var startBtn : UIButton = {
            let startBtn = UIButton()
            startBtn.setImage(UIImage.init(named: "bofang"), for: .normal)
            startBtn.addTarget(self, action: #selector(playAction(sender:)), for: .touchUpInside)
            return startBtn
        }()
        
        lazy var finishBtn : UIButton = {
            let finishBtn = UIButton()
            finishBtn.setImage(UIImage.init(named: "jieshu"), for: .normal)
            finishBtn.addTarget(self , action: #selector(endAction(sender:)), for:.touchUpInside)
            return finishBtn
        }()
        
        lazy var progress : UIProgressView = {
            let progress = UIProgressView()
            return progress
        }()
        
        lazy var messageLabel : UILabel = {
            let messageLabel = UILabel()
            messageLabel.text = "时长"
            messageLabel.numberOfLines = 0
            return messageLabel
        }()
        
        override func viewDidLoad() {
            super.viewDidLoad()
            self.navigationItem.title = "发现"
            
            setSubViewConstraints()
            let fileURL : URL = Bundle.main.url(forResource: "a", withExtension: "mp3")!
            
            do {
                let player : AVAudioPlayer = try AVAudioPlayer.init(contentsOf: fileURL)
                audioPlayer = player
            }catch{}
            let str = String.init(format: "音频文件的声道数:%d
    音频文件的持续时间:%g", audioPlayer.numberOfChannels,audioPlayer.duration)
            messageLabel.text = str
            durationTime = Float(audioPlayer.duration)
            //将循环次数设为-1,用于指定该音频文件循环播放
            audioPlayer.numberOfLoops = -1
            audioPlayer.delegate = self
        }
        
        @objc func playAction(sender:UIButton) -> Void {
            if audioPlayer.isPlaying {
                audioPlayer.pause()
                startBtn.setImage(UIImage.init(named: "bofang"), for: .normal)
            } else {
                audioPlayer.play()
                startBtn.setImage(UIImage.init(named: "zanting"), for: .normal)
            }
            if timer == nil {
                timer = Timer.scheduledTimer(timeInterval: 0.1, target: self, selector: #selector(updateProge), userInfo: nil, repeats: true)
            }
        }
        @objc func endAction(sender:UIButton) -> Void {
            audioPlayer.stop()
            timer?.isValid
            timer = nil
        }
        
        @objc func updateProge() {
            progress.progress = Float(audioPlayer.currentTime) / durationTime
        }
        func setSubViewConstraints() -> Void {
            view.addSubview(startBtn)
            startBtn.snp.makeConstraints { (make) in
                make.top.equalTo(100)
                make.left.equalTo(50)
                make.width.height.equalTo(50)
            }
            
            view.addSubview(finishBtn)
            finishBtn.snp.makeConstraints { (make) in
                make.top.equalTo(startBtn)
                make.right.equalTo(-50)
                make.width.height.equalTo(50)
            }
            
            view.addSubview(progress)
            progress.snp.makeConstraints { (make) in
                make.top.equalTo(startBtn.snp_bottom).offset(30)
                make.left.equalTo(50)
                make.right.equalTo(-50)
            }
            view.addSubview(messageLabel)
            messageLabel.snp.makeConstraints { (make) in
                make.top.equalTo(progress.snp_bottom).offset(30)
                make.left.equalTo(50)
                make.right.equalTo(-50)
            }
        }
    }
    
    extension NADiscoverViewController : AVAudioPlayerDelegate {
        //当audioplayer播放完成后将会自动播放
        func audioPlayerDidFinishPlaying(_ player: AVAudioPlayer, successfully flag: Bool) {
            if player == audioPlayer && flag {
                print("播放完成")
                
            }
        }
        
        func audioPlayerBeginInterruption(_ player: AVAudioPlayer) {
            if player == audioPlayer {
                print("被中断了")
            }
        }
    }
    播放本地音乐

     效果图:

    2、使用AVPlayerViewController播放视频

      支持的视频编码格式很有限:H.264、MPEG-4,扩展名(压缩格式):.mp4、.mov、.m4v、.m2v、.3gp、.3g2等,如果是RMVB就不行了,需要借助第三方的框架来实现更多格式的支持。

      使用AVPlayerViewController之前先导入AVKit头文件

      AVPlayerViewController中集成了AVPlayer,AVPlayer提供了一些方法可以轻易实现对视频播放的控制

      如:play/pause/status

      AVPlayerViewController常用属性:

      showsPlaybackControls:是否显示回放控制

      entersFullScreenWhenPlaybackBegins:开启这个播放的时候支持(全屏)横竖屏

      exitsFullScreenWhenPlaybackEnds:开启这个播放结束的时候,可以退出全屏

      案例代码:

    import UIKit
    import AVKit
    class NAPublishViewController : UIViewController {
        var moviePlayer = AVPlayerViewController.init()
        override func viewDidLoad() {
            super.viewDidLoad()
            
            let movieUrl : URL = Bundle.main.url(forResource: "movie", withExtension: "mp4")!
            //使用指定的url创建MPMoviesPlayerController
            moviePlayer.player = AVPlayer.init(url: movieUrl)
            //是否显示回放控制
            moviePlayer.showsPlaybackControls = true
            //开启这个播放的时候支持(全屏)横竖屏
            if #available(iOS 11.0, *) {
                moviePlayer.entersFullScreenWhenPlaybackBegins = true
            }
            //开启这个播放结束的是否,可以退出全屏
            if #available(iOS 11.0, *) {
                moviePlayer.exitsFullScreenWhenPlaybackEnds = true
            }
            view.addSubview(moviePlayer.view)
            //判断moviePlayer已经准备好视频第一播放帧
            if moviePlayer.isReadyForDisplay {
                moviePlayer.player?.play()
            }
            
        }
        
        override func didReceiveMemoryWarning() {
            super.didReceiveMemoryWarning()
            // Dispose of any resources that can be recreated.
        }
    }
    AVPlayerViewController播放视频

      通过上面几行代码,就可以实现本地或网络视频的播放。

            

  • 相关阅读:
    jQuery Timer 实现的新邮件提醒
    在 jquery repeater 中添加设置日期,下拉,复选框等控件
    jquery repeater 完成 QQ 邮箱邮件分组显示功能
    Ajax 与 WebService 之间日期等数据类型的转换
    通过 Parameter 对象添加 Ajax 请求时的参数
    在 jQuery Repeater 进行验证更新等操作时提示消息
    jquery repeater 模仿 Google 展开页面预览子视图
    在 jQuery Repeater 中检索过滤数据
    功能完善的 jquery validator 完成用户注册的验证
    在 Repeater 中绑定转化 JSON 格式的字段
  • 原文地址:https://www.cnblogs.com/xjf125/p/10919477.html
Copyright © 2011-2022 走看看