音视频相关及地图

音视频相关:

1.语音合成器

let synthesizer = AVSpeechSynthesizer()
let utterance = AVSpeechUtterance(string:”需要读的内容”)
synthesizer.speakUtterance(utterance)

2.音频播放器

需要在类中声明一个属性
var player:AVAudioPlayer!
a.获取音频的路径
let url = NSBundle.mainBundle().URLForResource("月半小夜曲", withExtension: ".mp3")

b. player = try! AVAudioPlayer(contentsOfURL: url)

c.其他设置
  // 缓冲音乐文件(播放音乐之前先缓冲)
   player.prepareToPlay()
        
  // 设置播放音量(0~1,可以调大于1,但是声音也有可能失真)
    player.volume = 0.5
        
  // 指定从200开始播放
  // player.currentTime = 200
        
   // 允许变速播放
    player.enableRate = true
        
    // 设置倍速()
     player.rate = 1.2
        
    // 设置无限循环播放(负数为无限)
    player.numberOfLoops = -1
        
    // 播放
     player.play()
    //当前播放时间点
     print(player.currentTime)
    // 音乐的时长
    print(player.duration)
  

2.1、想要设置后台播放的话,必须设置会话还有设置Xcode中Capabilities中BackgrounndModes这一选项,在第一行打钩

   创建一个音频会话对象设置支持后台播放(Xcode的设置和这个代码缺一不可)
        //创建会话
        let session = AVAudioSession()
        // 支持后台播放
        do {
         //激活会话
            try session.setActive(true)
            //设置音频会话的类别(支持后台播放的类别)
            try session.setCategory(AVAudioSessionCategoryPlayback, withOptions: [])
        } catch {

            print("不支持后台播放")

        }

2.2、 显示音频的内容

 if let url = NSBundle.mainBundle().URLForResource("月半小夜曲", withExtension: ".mp3"{

    //通过创建AVURLAsset对象用来获取音视频文件的元数据

    let assets = AVURLAsset(URL: url)

    //dataItem元数据项
    print(assets.metadata)

            for dataItem in assets.metadata

            {

                if let key = dataItem.commonKey

                {

                    switch key

                    {

                    case "artist":

                        artistLabel.text = dataItem.value as? String

                    case "title":

                        titleLabel.text = dataItem.value as?String

                    case "albumName":

                        albumLabel.text = dataItem.value as? String

                    case "artwork":

                        if let data = dataItem.value as? NSData

                        {

                            coverImageView.image = UIImage(data: data)

                        }

                    default: break

                    }

                }

   
        

3.录音

import UIKit

import AVFoundation



class ViewController: UIViewController {
    //不能放到方法里,,不然没人接管他的生命周期
    var recorder:  AVAudioRecorder?
    
    override func viewDidLoad() {
        super.viewDidLoad()
        
        
    }
    @IBAction func startRecordd(sender: UIButton) {
        
        //
        //如果为空就创建recorder
        if recorder == nil
        {
            sender.setTitle("结束录音", forState: .Normal)
            //字典
            let mySettings: [String:AnyObject] = [
                //设置录音质量
                AVEncoderAudioQualityKey:AVAudioQuality.Low.rawValue,
                //比特率(16为字符串常量)
                AVEncoderBitRateKey: 16,
                //声道数
                AVNumberOfChannelsKey:2,
                //采样频率
                AVSampleRateKey:44100
            ]
            
            // 拿到沙盒路径(把当前路径存到沙盒中)
            let filePath = NSHomeDirectory().stringByAppendingString("/Documents/test.caf")
            print(filePath)
            // 创建URL
            let url = NSURL(fileURLWithPath: filePath)
            
            self.recorder = try! AVAudioRecorder(URL: url, settings: mySettings)
            //开始录音
            recorder?.record()

        } else {
            
            sender.setTitle("开始录音", forState: .Normal)
            recorder?.stop()
            recorder = nil
        }
       
        
       
        
        
       
    }

}

4.播放视频


import UIKit
import AVFoundation
import AVKit

class ViewController: UIViewController {

//    var player:AVPlayer!
    var timer:NSTimer?
    var isPlaying  = false
    
    override func viewDidLoad() {
        super.viewDidLoad()
        
        //添加通知观察者(观察视频播放完就停止播放)
        //参数2:选择器接受到通知,就会停止播放
        //参数3:通知
        //参数4:nil接受所有的对象
        NSNotificationCenter.defaultCenter().addObserver(self, selector: "stop:", name: AVPlayerItemDidPlayToEndTimeNotification, object: nil)
       
        //显示出来视频
        //方式1:
//        let layer = AVPlayerLayer(player: player)
//        layer.frame = self.view.bounds
//        //不能直接加到self.view
//        self.view.layer.addSublayer(layer)
//        player.play()

  }
    func stop(sender:NSNotification)
    {
        //播放完后自动停止
       self.dismissViewControllerAnimated(true, completion: nil)
        isPlaying = false
        
    }
    //点击屏幕开始播放
    override func touchesBegan(touches: Set<UITouch>, withEvent event: UIEvent?) {
        
        //一个视图控制器中不能模态多个视图控制器,,模态出来第一个之后就不会模态的第二个了(程序不会崩溃,)
        //方式2:
        if let url =  NSBundle.mainBundle().URLForResource("birds.mp4", withExtension: nil) {
            
            //player已经被playerVC接管了,不会被释放掉了
             let player = AVPlayer(URL: url)
            
            // AVPlayerViewController可以简化AVPlayer的使用
            // AVPlayer负责控制视频的播放停止等
            // AVPlayerViewController负责显示和提供播放控件
            // AVPlayerViewController是MPMoviePlayerController的替代品,AVPlayerViewController针对iPad还提供了画中画功能,,他们是AVKit框架下高度封装的工具类
            // 如果希望自己定制播放控件那么可以直接使用AVPlayer
            // 先用AVPlayer将视频显示出来,
            // 然后用按钮,滑条,进度条之类的东西来自己的定制播放控件
            
            let playerVC = AVPlayerViewController()
            playerVC.player  = player
            //
            self.presentViewController(playerVC
                , animated: true,completion: {
                    //出来之后就自动播放
                   player.play()
                    
                    
            })
        }

    }
    deinit {
        
        
        //手动移除观察者
        //移除观察者后一定要记得手动移除通知观察者否则有 内存泄漏的风险
        NSNotificationCenter.defaultCenter().removeObserver(self)
        //使用计时器的对象后一定要在deinit中使其失效以避免内存泄漏
        timer?.invalidate()
        timer = nil
        
    }
    
}


5.地图

import UIKit
import MapKit
class ViewController: UIViewController,CLLocationManagerDelegate {

    //苹果原生的地图
    var mapView: MKMapView!
    //核心定位(定位管理器)
    var locationManager: CLLocationManager!
    
    @IBOutlet weak var mapTypeSeg: UISegmentedControl!
    
    override func viewDidLoad() {
        super.viewDidLoad()
        
        // 创建定位管理器
        locationManager = CLLocationManager()
        // 绑定事件委托
        locationManager.delegate = self
        
        // 设置精确度(精度越高耗电越大 )
        // 设置导航使用kCLLocationAccuracyBestForNavigation最佳
        locationManager.desiredAccuracy = kCLLocationAccuracyBestForNavigation
        // 距离过滤器(十米之内不用重新定位)
        locationManager.distanceFilter = 10
        
       /*
        case Standard
        case Satellite
        case Hybrid  混合地图
        @available(iOS 9.0, *)
        case SatelliteFlyover
        @available(iOS 9.0, *)
        case HybridFlyover
      */
  
        
        // 地图已经显示出来
        mapView = MKMapView(frame: self.view.bounds)
        //
        mapView.mapType = .SatelliteFlyover  //混合地图
        //显示交通状况
        mapView.showsTraffic = true
        self.view.addSubview(mapView)
        
        //将分段控件放置到整个视图层次结构的最顶层
        self.view.bringSubviewToFront(mapTypeSeg)

        // 创建坐标(经度和纬度)
        // 参数1:纬度  参数2:经度
        let coordinate = CLLocationCoordinate2DMake(30.6621, 104.041367)
        // 设置跨度
        let span = MKCoordinateSpanMake(0.01, 0.01)
        // 参数1:地图中心点的经纬度坐标
        // 参数2:地图跨度(经纬度跨度)
        // 设置地图的中心点(设置区域)
        let region = MKCoordinateRegionMake(coordinate, span)
        // 设置地图中心点地区
        mapView.setRegion(region, animated: true)
        
        // 判断请求授权
        // 获取定位服务的授权状态
        let status = CLLocationManager.authorizationStatus()
        // 尚未没有授权
        if status == .NotDetermined {
            
            // 请求授权一直使用定位服务(可以在后台使用定位服务)
            locationManager.requestAlwaysAuthorization()
            // 请求授权在应用程序使用期间开启定位服务
            // locationManager.requestWhenInUseAuthorization()
     
        //之前已拒绝授权
        } else if status == .Denied {
            //提示用户跳转设置开启定位服务
            
            
        } else {
            //开始更新位置信息
            locationManager.startUpdatingLocation()
            //在地图上显示用户当前位置
            mapView.showsUserLocation = true

        }
    }
    
    @IBAction func segAction(sender: UISegmentedControl) {
        
        //Standard:标准地图, Satellite:卫星地图  Hybrid:混合地图
        let typeArray = [MKMapType.Standard,.Satellite,.Hybrid]
        mapView.mapType = typeArray[sender.selectedSegmentIndex]
    }

}


extension ViewController
{
    //定位授权状态被改变时要执行的方法
    func locationManager(manager: CLLocationManager, didChangeAuthorizationStatus status: CLAuthorizationStatus) {
        
        //如果请求定位授权成功就开始更新位置信息并 在地图上显示用户位置
        if status == .AuthorizedAlways || status == .AuthorizedWhenInUse
        {
            manager.startUpdatingLocation()
            mapView.showsUserLocation = true
        }
    }
    
    //更新位置信息后要执行的方法
    func locationManager(manager: CLLocationManager, didUpdateLocations locations: [CLLocation]) {
        
        //
        if let location = locations.first
        {
            let span = MKCoordinateSpanMake(0.01, 0.01)
            // 参数1:地图中心点的经纬度坐标
            // 参数2:地图跨度(经纬度跨度)
            let region = MKCoordinateRegionMake(location.coordinate, span)
            //设置地区
            mapView.setRegion(region, animated: true)

            
        }
       
        
    }
}

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 159,835评论 4 364
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,598评论 1 295
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 109,569评论 0 244
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,159评论 0 213
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,533评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,710评论 1 222
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,923评论 2 313
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,674评论 0 203
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,421评论 1 246
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,622评论 2 245
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,115评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,428评论 2 254
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,114评论 3 238
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,097评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,875评论 0 197
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,753评论 2 276
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,649评论 2 271

推荐阅读更多精彩内容