data mp3转 swift_swift 图片转data data转图片 - CSDN
  • iOS实时语音文字,以及录音文件文字
  • 我的需求是可以录制多个文件,最后生成的文件格式为mp3形式,查了下各种资料,因为swift无法直接将音频录制为mp3格式,所以最后我采取的解决方案为先将每个单独的文件转为mp3,最后逐一合并形成一个mp3文件 ...

    我的需求是可以录制多个文件,最后生成的文件格式为mp3形式,查了下各种资料,因为swift无法直接将音频录制为mp3格式,所以最后我采取的解决方案为先将每个单独的文件转为mp3,最后逐一合并形成一个mp3文件

    首先第一步录制 简单说明下:

      参考:  http://www.jianshu.com/p/09af208a5663(感谢) http://www.hangge.com/blog/cache/detail_772.html(感谢)

      1. 音频配置,我尝试了下尽可能多加各种配置最后有问题,测试成功的配置如下  

     recorderSeetingsDic: [String: Any] = [
            AVSampleRateKey: NSNumber(value: 16000),//采样率
            AVFormatIDKey: NSNumber(value: kAudioFormatLinearPCM),//音频格式
            AVNumberOfChannelsKey: NSNumber(value: 2),//通道数
            AVEncoderAudioQualityKey: NSNumber(value: AVAudioQuality.min.rawValue)//录音质量
     ]
    

      2,录制实现(部分代码)

    //音频路径
    let audioPath = (NSSearchPathForDirectoriesInDomains(.documentDirectory, .userDomainMask, true).first?.appending("/test.caf"))!
    

      

    let session:AVAudioSession = AVAudioSession.sharedInstance()
    
    try! session.setCategory(AVAudioSessionCategoryPlayAndRecord)
    
    try! session.setActive(true)
    
    do {
                    recorder = try AVAudioRecorder(url: URL(string: audioPath)!, settings: recorderSeetingsDic)
                    
                    //开启仪表计数功能
                    recorder!.isMeteringEnabled = true
                    //准备录音
                    recorder!.prepareToRecord()
    
                    recorder?.record()
                } catch let err {
                    print("录音失败:\(err.localizedDescription)")
    }
    

      第二步将录制的多个caf格式音频转为一个mp3文件,(最初采用的方式是将多个.caf文件合成为m4a文件的 但是找不到m4a转为mp3的解决方法,用lame也行不通,很郁闷)

      1.首先要编译lame 这是将.caf转为mp3第一步,有很多可以参考的方式

        我参考的编译方式:http://blog.csdn.net/cating1314/article/details/46046497(感谢)

        我们需要编译过后的libmp3lame.a与lame.h两个文件,都在编译过后的thin-lame与fat-lame文件中。根据自己的需求选取,我采用的是fat-lame中的两个文件

        不想编译的话可以采用我的,应该也不会有啥问题 https://pan.baidu.com/s/1dFepCIl 提取密码:reck

      2转换以及合成方法 (转换与合成均采用OC写的)

      参考: https://github.com/CharmingLee/RecordingDemo(感谢)

      定义了两个文件convertMp3.h与convertMp3.m

      convertMp3.h文件

      

    #import <UIKit/UIKit.h>
    
    @interface convertMp3: NSObject
    
    - (void) audioPCMtoMP3:(NSString *)audioFileSavePath mp3File:(NSString *)mp3FilePath mergeFile:(NSString *)mergeFilePath;
    
    @end
    

      convertMp3.m文件

    #import "convertMp3.h"
    #import "lame.h"
    
    #define KFILESIZE (1 * 1024 * 1024)
    
    @interface convertMp3()
    
    @end
    
    @implementation convertMp3
    
    - (void)audioPCMtoMP3 :(NSString *)audioFileSavePath mp3File:(NSString *)mp3FilePath mergeFile:(NSString *)mergeFilePath
    {
        
        @try {
            int read, write;
            
            FILE *pcm = fopen([audioFileSavePath cStringUsingEncoding:1], "rb");  //source 被转换的音频文件位置
            fseek(pcm, 4*1024, SEEK_CUR);                                   //skip file header
            FILE *mp3 = fopen([mp3FilePath cStringUsingEncoding:1], "wb");  //output 输出生成的Mp3文件位置
            
            const int PCM_SIZE = 8192;
            const int MP3_SIZE = 8192;
            short int pcm_buffer[PCM_SIZE*2];
            unsigned char mp3_buffer[MP3_SIZE];
            
            lame_t lame = lame_init();
            lame_set_in_samplerate(lame, 16000);
            lame_set_VBR(lame, vbr_off);
            lame_init_params(lame);
            
            do {
                read = (int)fread(pcm_buffer, 2*sizeof(short int), PCM_SIZE, pcm);
                
                if (read == 0)
                    write = lame_encode_flush(lame, mp3_buffer, MP3_SIZE);
                else
                    write = lame_encode_buffer_interleaved(lame,pcm_buffer, read, mp3_buffer, MP3_SIZE);
                
                fwrite(mp3_buffer, write, 1, mp3);
            } while (read != 0);
            
            lame_close(lame);
            fclose(mp3);
            fclose(pcm);
        }
        @catch (NSException *exception) {
            NSLog(@"%@",[exception description]);
        }
        @finally {
            //从第二个文件才开始合并 第一个文件mergeFilePath与mp3FilePath相同 即第一个转换后的文件地址就是最终合成的完整的mp3文件地址
            if([mergeFilePath isEqualToString:mp3FilePath] == NO) {
                [self pieceFileA:mergeFilePath withFileB:mp3FilePath];
            }
        }
        
    }
    
    - (BOOL)pieceFileA:(NSString *)filePathA withFileB:(NSString *)filePathB {
        //合成过后的文件路径 之后不管多少文件 都是在这个filePathA文件之后继续写入的
        NSString *synthesisFilePath = filePathA;
        
        // 更新的方式读取文件A
        NSFileHandle *handleA = [NSFileHandle fileHandleForUpdatingAtPath:synthesisFilePath];
        [handleA seekToEndOfFile];
        
        NSDictionary *fileBDic =
        [[NSFileManager defaultManager] attributesOfItemAtPath:filePathB
                                                         error:nil];
        long long fileSizeB = fileBDic.fileSize;
        
        // 大于xM分片拼接xM
        if (fileSizeB > KFILESIZE) {
            
            // 分片
            long long pieces = fileSizeB / KFILESIZE; // 整片
            long long let = fileSizeB % KFILESIZE;    // 剩余片
            
            long long sizes = pieces;
            // 有余数
            if (let > 0) {
                // 加多一片
                sizes += 1;
            }
            
            NSFileHandle *handleB = [NSFileHandle fileHandleForReadingAtPath:filePathB];
            for (int i = 0; i < sizes; i++) {
                
                [handleB seekToFileOffset:i * KFILESIZE];
                NSData *tmp = [handleB readDataOfLength:KFILESIZE];
                [handleA writeData:tmp];
            }
            
            [handleB synchronizeFile];
            
            // 大于xM分片读xM(最后一片可能小于xM)
        } else {
            
            [handleA writeData:[NSData dataWithContentsOfFile:filePathB]];
        }
        
        [handleA synchronizeFile];
         NSLog(@"合并完成");
        // 将B文件删除
        //    [[NSFileManager defaultManager] removeItemAtPath:filePathB error:nil];
        
        return YES;
    }
    
    @end
    

      在桥接文件中加入头文件 #import "convertMp3.h"

      3.调用OC文件开始合并

     

    //合并
        func transferAudio(num: Int) {
            
            let documentDirectoryURL = FileManager.default.urls(for: .documentDirectory, in: .userDomainMask).first! as NSURL
            let stringDate = BaseController().getCurrentTimeMillisecond()
            let mp3Path: URL = (documentDirectoryURL.appendingPathComponent(BaseController().randomMD5(str: stringDate) + ".mp3")! as URL as NSURL) as URL!
            
            if num == 0 {
                self.audioPath = mp3Path.path
            }
            
            convertMp3().audioPCMtoMP3(self.audioLocalUrls[num],mp3File: mp3Path.path,mergeFile: self.audioPath)
            
            if num == self.audioLocalUrls.count - 1{
                self.uploadAudio()//上传
            }else{
                let order = num + 1
                transferAudio(num: order)
            }
        }
    

     调用transferAudio(num:0) 开始一个一个caf文件转换合并 这样流程走通了  录制多个caf文件 逐个将其转为mp3 在合并为一个完整mp3文件,刚接触swift没多长时间 东拼西凑实现的功能 如果有哪里不对 希望及时告诉我  谢谢,希望对其它有次需求的人有个参考,毕竟折磨我很长时间

      

    转载于:https://www.cnblogs.com/kunH/p/7326602.html

    展开全文
  • iOS音视频采集以及写入文件

    iOS音视频采集以及写入文件(swift)


    注意:配置允许访问相机与麦克风参考这里

    1.初始化文件属性
    class ViewController: UIViewController {
        
        fileprivate lazy var session: AVCaptureSession = AVCaptureSession()
        //视频输出
        fileprivate var videoOutPut: AVCaptureVideoDataOutput?
        //预览层
        fileprivate var previewLayer: AVCaptureVideoPreviewLayer?
        //视频输入
        fileprivate var videoInput: AVCaptureDeviceInput?
        //文件输出
        fileprivate var fileOutPut: AVCaptureMovieFileOutput?
    
        override func viewDidLoad() {
            super.viewDidLoad()
            //MARK: 视频采集
            initVideoInputOutput()
            //MARK: 音频采集
            initAudioInputOutput()
            //MARK: 创建预览层
            initPreViewLayer()
        }
        
    }
    
    

    2.音视频进行采集
    extension ViewController {
        //视频采集
        fileprivate func initVideoInputOutput(){
            //视频输入
            guard let devices = AVCaptureDevice.devices() as? [AVCaptureDevice] else{return}
            guard let device = devices.filter({ $0.position == .front }).first else {return}
            guard let input = try? AVCaptureDeviceInput(device: device) else {return}
            self.videoInput = input
            //视频输出
            let output = AVCaptureVideoDataOutput()
            output.setSampleBufferDelegate(self, queue: DispatchQueue.global())
            self.videoOutPut = output
            //添加输入输出
            addInputOutPut(input, output)
        }
        
        //音频采集
        fileprivate func initAudioInputOutput(){
            //音频输入
            guard let device = AVCaptureDevice.defaultDevice(withMediaType: AVMediaTypeAudio) else {return}
            guard let input = try? AVCaptureDeviceInput(device: device) else {return}
            //音频输出
            let output = AVCaptureAudioDataOutput()
            output.setSampleBufferDelegate(self, queue: DispatchQueue.global())
            //添加输入输出
            addInputOutPut(input, output)
        }
        
        //添加输入和输出
        private func addInputOutPut(_ input: AVCaptureInput, _ output: AVCaptureOutput) {
            //添加输入输出
            session.beginConfiguration()
            if session.canAddInput(input) {
                session.addInput(input)
            }
            if session.canAddOutput(output){
                session.addOutput(output)
            }
            session.commitConfiguration()
        }
        //创建预览层
        fileprivate func initPreViewLayer(){
            guard let preLayer = AVCaptureVideoPreviewLayer(session: session) else {return}
            self.previewLayer = preLayer
            preLayer.frame = view.bounds
            view.layer.insertSublayer(preLayer, at: 0)
        }
    }
    
    

    3.采集的代理方法
    //MARK: AVCapture delegate
    extension ViewController: AVCaptureVideoDataOutputSampleBufferDelegate, AVCaptureAudioDataOutputSampleBufferDelegate {
        func captureOutput(_ captureOutput: AVCaptureOutput!, didOutputSampleBuffer sampleBuffer: CMSampleBuffer!, from connection: AVCaptureConnection!) {
            if videoOutPut?.connection(withMediaType: AVMediaTypeVideo) == connection {
                print("采集到视频数据")
            }else{
                print("采集到音频数据")
            }
        }
    }
    
    

    4.开始采集、结束采集、切换摄像头方法调用
    extension ViewController{
    
        //开始采集
        @IBAction func startCapture(_ sender: Any) {
            print("startCapture")
            session.startRunning()
            movieOutPutFile()
        }
        
        //结束采集
        @IBAction func endCapture(_ sender: Any) {
            print("endCapture")
            self.fileOutPut?.stopRecording()
            session.stopRunning()
            previewLayer?.removeFromSuperlayer()
        }
        
        //切换镜头
        @IBAction func changeDirection(_ sender: Any) {
            print("changeDirection")
            guard let videoInput = videoInput else {
                return
            }
            let position: AVCaptureDevicePosition = videoInput.device.position == .front ? .back : .front
            guard let devices = AVCaptureDevice.devices() as? [AVCaptureDevice] else{return}
            guard let device = devices.filter({ $0.position == position }).first else {return}
            guard let newInput = try? AVCaptureDeviceInput(device: device) else {return}
            self.videoInput = newInput
            session.beginConfiguration()
            session.removeInput(videoInput)
            if session.canAddInput(newInput) {
                session.addInput(newInput)
            }
            session.commitConfiguration()
        }
        
        //写入文件
        fileprivate func movieOutPutFile() {
            let fileOutPut = AVCaptureMovieFileOutput()
            let connection = fileOutPut.connection(withMediaType: AVMediaTypeVideo)
            connection?.automaticallyAdjustsVideoMirroring = true
            print(session)
            session.beginConfiguration()
            session.removeOutput(self.fileOutPut)
            if session.canAddOutput(fileOutPut) {
                session.addOutput(fileOutPut)
            }
            session.commitConfiguration()
            self.fileOutPut = fileOutPut
            let path = NSSearchPathForDirectoriesInDomains(.documentDirectory, .userDomainMask, true).first! + "/glt.mp4"
            fileOutPut.startRecording(toOutputFileURL: URL(fileURLWithPath: path), recordingDelegate: self)
        }
        
    }
    

    5.写入文件代理
    //MARK: 写入文件代理
    extension ViewController: AVCaptureFileOutputRecordingDelegate {
    
        func capture(_ captureOutput: AVCaptureFileOutput!, didStartRecordingToOutputFileAt fileURL: URL!, fromConnections connections: [Any]!) {
            print("开始录制")
        }
        
        func capture(_ captureOutput: AVCaptureFileOutput!, didFinishRecordingToOutputFileAt outputFileURL: URL!, fromConnections connections: [Any]!, error: Error!) {
            print("结束录制")
        }
        
    }
    



    展开全文
  • swift获取plist文件

    2018-12-20 13:59:09
    VC里面获取文件路径搭建界面 import UIKit class ViewController: UIViewController ,UITableViewDelegate,UITableViewDataSource{ var tbv:UITableView? var nameArr:[String] = [] var dict:NSDictionary =...

    VC里面获取文件路径搭建界面

    import UIKit
    
    class ViewController: UIViewController ,UITableViewDelegate,UITableViewDataSource{
    
        var tbv:UITableView?
        var nameArr:[String] = []
        
        var dict:NSDictionary = [:]
        var data:NSMutableDictionary = [:]
        
        var marr:NSMutableArray = []
        
        
        override func viewDidLoad() {
            super.viewDidLoad()
            // Do any additional setup after loading the view, typically from a nib.
            
            // 生成文件的存储路径
            let plistPath = Bundle.main.path(forResource: "plist", ofType: "plist")
           // let plistPath = Bundle.main.path(forResource: "1", ofType: "plist")
            
            //读取属性列表文件,并转化为可变字典对象
            data = NSMutableDictionary(contentsOfFile: plistPath!)!
        
           // marr = NSMutableArray(contentsOfFile: plistPath!)!
           // print(marr)
            nameArr = data.allKeys as! [String]
            
            tbv = UITableView(frame: CGRect(x: 0, y: 0, width: UIScreen.main.bounds.width, height: UIScreen.main.bounds.height))
            view.addSubview(tbv!)
            
            tbv?.delegate = self
            tbv?.dataSource = self
            
            tbv?.register(UITableViewCell.self, forCellReuseIdentifier: "idCell")
            
        }
        
        func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
          //  return marr.count
            return nameArr.count
        }
        
        func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
            
            let cell:UITableViewCell = tableView.dequeueReusableCell(withIdentifier: "idCell")!
            cell.textLabel?.text = nameArr[indexPath.row];
    //        let dic:NSDictionary = marr[indexPath.row] as! NSDictionary
    //        let arr:NSArray = dic.allKeys as NSArray
    //        cell.textLabel?.text = arr[0] as? String;
            return cell
        }
        
        func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) {
            
            if nameArr[indexPath.row]=="国外"{
                dict = data["国外"] as! NSDictionary
                let vc:SecondVC = SecondVC()
                
                vc.dict = dict
                
                self.navigationController?.pushViewController(vc, animated: true)
                
            }else{
                
                dict = data["国内"] as! NSDictionary
                
                let vc:ThreeVC = ThreeVC()
                
                vc.dict = dict
                
                self.navigationController?.pushViewController(vc, animated: true)
            }
        }
    }
    

    跳第二个界面

    import UIKit
    
    class SecondVC: UIViewController,UITableViewDelegate,UITableViewDataSource {
    
        var dict:NSDictionary = [:]
        var tbv:UITableView?
        
        var nameArr:[String] = []
        
        
        override func viewDidLoad() {
            super.viewDidLoad()
    
            // Do any additional setup after loading the view.
            
            view.backgroundColor = UIColor.white
            
            nameArr = dict.allKeys as! [String];
            
            tbv = UITableView(frame: CGRect(x: 0, y: 0, width: UIScreen.main.bounds.width, height: UIScreen.main.bounds.height))
            view.addSubview(tbv!)
            
            tbv?.delegate = self
            tbv?.dataSource = self
            
            tbv?.register(UITableViewCell.self, forCellReuseIdentifier: "idCell")
            
        }
        
        func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
            return nameArr.count
        }
        
        func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
            
            let cell:UITableViewCell = tableView.dequeueReusableCell(withIdentifier: "idCell")!
            cell.textLabel?.text = nameArr[indexPath.row];
            return cell
        }
        
        func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) {
            
            if nameArr[indexPath.row]=="Britney Spears"{
                
                let arr:NSArray = dict["Britney Spears"] as! NSArray
                
                let vc:FourVC = FourVC()
                
                vc.dict = arr
                
                self.navigationController?.pushViewController(vc, animated: true)
                
            }else{
                let arr:NSArray = dict["Kelly Clarkson"] as! NSArray
                let vc:FourVC = FourVC()
                
                vc.dict = arr
                
                self.navigationController?.pushViewController(vc, animated: true)
            }
            
        }
    
    }
    

    再跳到播放界面记得导入框架AVFoundation

    import UIKit
    import AVFoundation
    
    class FourVC: UIViewController,UITableViewDelegate,UITableViewDataSource {
        
        var dict:NSArray = []
        var tbv:UITableView?
        var audioPlayer: AVAudioPlayer?
      //  var nameArr:[String] = []
        var select:Bool = true
        
        override func viewDidLoad() {
            super.viewDidLoad()
    
            // Do any additional setup after loading the view.
            
            // 设置音乐
            let path = Bundle.main.path(forResource: "试音碟-高山流水 (古筝)", ofType: "mp3")
            let pathURL=NSURL(fileURLWithPath: path!)
            do {
                audioPlayer = try AVAudioPlayer(contentsOf: pathURL as URL)
            } catch {
                audioPlayer = nil
            }
            
            audioPlayer?.prepareToPlay()
            
            view.backgroundColor = UIColor.white
            
            tbv = UITableView(frame: CGRect(x: 0, y: 0, width: UIScreen.main.bounds.width, height: UIScreen.main.bounds.height))
            view.addSubview(tbv!)
            
            tbv?.delegate = self
            tbv?.dataSource = self
            
            tbv?.register(UITableViewCell.self, forCellReuseIdentifier: "idCell")
        }
        
        func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
            return dict.count
        }
        
        func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
            
            let cell:UITableViewCell = tableView.dequeueReusableCell(withIdentifier: "idCell")!
            cell.textLabel?.text = (dict[indexPath.row] as! String);
            return cell
        }
        
        func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) {
            
            if select==true {
                audioPlayer?.play()
                select = false
            }else{
                audioPlayer?.pause()
                select = true
            }
            
           // let audioPlayer = MusicViewController()
          //  audioPlayer.playMusic(filePath)
          //  self.navigationController!.pushViewController(audioPlayer, animated: true)
        }
    }
    
    
    展开全文
  • IOS 我把音频变成NSData 了,如何在NSData变成音频?
  • 总体来说这个软件的实现难点更多的在UI界面…… 第一步里先将获取到的网络数据显示。 ...由这个网址获得 可以看到他必须要传的参数是appid,secret,还有topid,前两个进行注册并申请就可以获得,然后用CocoaPods在Xcode...

    总体来说这个软件的实现难点更多的在UI界面……

    第一步里先将获取到的网络数据显示。
    首先API的获取:https://www.showapi.com/api/lookPoint/213/4
    由这个网址获得
    可以看到他必须要传的参数是appid,secret,还有topid,前两个进行注册并申请就可以获得,然后用CocoaPods在Xcode中导入Alamofire还有swityJSON,import进文件后先创建一个简单的请求来获得他返回的数据,将数据复制粘贴进https://jsoneditoronline.org/里面看他数组的分布,当然也可以先用Postman来获得网址返回的数据,清楚数据分布之后将获取的数据详细至你所需要的值,例如获取歌手在[“showapi_res_body”][“pagebean”][“songlist”]下面的数组中。

    用swiftyJSON的功能将返回的数值提取成Xcode可以使用的形式,之后创建一个数组songlistArray来储存所获得的值,由于songlist下面还有很多数组,所以dic可以用他总的数组数量进行遍历,然后获取所有singername和songname的值。

    func downLoadData(){
            
            let paras = ["showapi_appid":appid,"showapi_sign":secret,"topid":"\(5)"]
            Alamofire.request("https://route.showapi.com/213-4",method: .post,parameters:paras).responseJSON { response in
                
                if let json = response.result.value {
                    let JSOnDictory = JSON(json)
                    let songlistArray = JSOnDictory["showapi_res_body"]["pagebean"]["songlist"].arrayValue
                    for dic in songlistArray{
                        let model = musicModel()
                        model.SingerName = dic["singername"].stringValue
                        model.SongName = dic["songname"].stringValue
                        self.models.add(model)
                    }
                    self.tableView.reloadData()
                }
            }
            
        }
    

    将TableView的行数与singername/songname相对应,就将每一个歌手和歌曲名字显示出来了。

     override func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
            // #warning Incomplete implementation, return the number of rows
            return self.models.count
        }
    
       
        override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
            
            let cell = tableView.dequeueReusableCell(withIdentifier: "List", for: indexPath) as! ListCell
            let model:musicModel = self.models[indexPath.row] as! musicModel
            cell.SingerName.text = model.SingerName
            cell.SongName.text = model.SongName
            
            
            return cell
        }
        
    

    其外的文件有一个ListCell文件来对应Lable去显示网络获取的数值,musicModel用于数据的存储

    展开全文
  • AVAsset:素材库里的素材; AVAssetTrack:素材的轨道; AVFoundation编辑API的核心就是compositions(合成); composition就是从一个或多个不同的资源中获取到的简单的track(轨道)的集合; AVMutableComposition:一个用来...
  • swift 之视频的剪辑

    2018-03-05 16:24:07
    参考:http://blog.csdn.net/u012297622/article/details/51784939 AVComposition 一个工程文件有很多轨道,如音频轨道1、音频轨道2、视频轨道1视频轨道2等,每个轨道里有许多素材,它可以进行压缩、旋转等操作,...
  • 最近做的一个项目,项目中有个录音功能,采用的录音方法是IOS下的AVAudioRecorder。录音效果不错,但是录制的原生.pcm文件太大,每分钟大约10M左右。 找了下相关的音频压缩方法,用speex的比较多。...
  • Swift\本地文件管理

    2019-01-08 15:58:02
    转载自:...进入正题,在Swift开发中,几乎是每一个App都需要在本地存储一些本地的持久化数据,毕竟不可能每次App使用都从网上现传数据回来使用吧,那样App的体验将会大打折扣。 ...
  • Swift实现iOS录音与播放音频功能   作用 AVPLayer:可以用来播放在线及本地音视频 AVAudioSession:音频会话,主要用来管理音频设置与硬件交互 使用时需要导入 #import &lt;AVFoundation/AVFoundation.h&...
  • //// ViewController.swift//网络歌曲播放//// Created by xx良on 14-8-16.// Copyright (c) 2014年xx良. All rights reserved.//这是我两天学习网络播放器项目的时候,总结和整理出来的代码,以后想要实现类似的...
  • ...本来说好是要在第三篇中讲AudioFileStream和AudioQueue,但写着写着发现光AudioFileStream就好多内容,最后还是决定分篇介绍,这篇先来说一下AudioFileStream,下一篇计划说一下和AudioFile
  • 虽然这个播放器也可以播放网络音频,但其实际上是将音频文件下载到本地后再播放的。 本文演示如何使用第三方的 StreamingKit 库,来实现网络流音频的播放。 ...(1)StreamingKit 是一个适用于 iOS
  • 这个 demo 是平时自己在工作之余学习 swift 写的,因为每天学习时间有限所以这个 demo 前后写了一个月左右,里面的语法和命名都不是很规范,也没有做大量的机型和版本测试,整体语法偏向于OC。在写的期间也查询了许多...
  • 一:iOS沙盒知识 出于安全考虑,iOS系统把每个应用以及数据都放到一个沙盒(sandbox)里面,应用只能访问自己沙盒目录里面的文件、网络资源等(也有例外,比如系统通讯录、照相机、照片等能在用户授权的情况下被第...
  • 1.swift~UI详解 2.md5 3.post和get请求
  • 本文主要分享下楼主在学习Swift编程过程中,对GitHub上的一个开源App Swift Music的研究心得。 项目地址:https://github.com/xujiyao123/SwiftMusic 一、项目简介 本项目主要实现了歌曲关键字查询歌曲,...
  • 最近在学Swift,也是刚刚开始。这里对自己最近所学做个简单的总结:视频和代码都在下面 http://pan.baidu.com/s/1sjHd5qX 1.String和NSString的不同 1 Swift的String类型是值类型。如果你创建了一个新的字符串...
1 2 3 4 5 ... 20
收藏数 452
精华内容 180
关键字:

data mp3转 swift