美文网首页
iOS 读取音乐/歌曲文件

iOS 读取音乐/歌曲文件

作者: Sparkle_S | 来源:发表于2017-03-13 19:30 被阅读0次

    参考文件:http://blog.csdn.net/ismilesky/article/details/50687505

    需求:获取本地歌曲文件
    分析:本地歌曲文件也就是通多系统自带的‘音乐’软件下载的,通过iTunes导入的,以及通过第三方音乐软件(比如:‘QQ音乐’,‘网易云音乐’等)下载的音乐。

    • "由于iPhone 自带的音乐软件Music的推出.从iPod取出来的音乐MPMediaItemPropertyAssetURL属性可能为空.
      这是因为iPhone自带软件Music对音乐版权的保护,对于所有进行过 DRMProtection(数字版权加密保护)的音乐都不能被第三方APP获取并播放.即使这些音乐已经下载到本地.但是还是可以播放本地未进行过数字版权加密的音乐.也就是您自己手动导入的音乐。"

      从上面这段话可以看出,我们是没办法读取通过iTunes下载的本地音乐的,而只能获取通过iTunes手动导入的音乐。
    • 由于沙盒保护机制,你无法访问其它App的沙盒路径。
      所以无法获取到第三方软件中的文件。再者,音乐软件之间基本上都属于竞争关系,显而~这个不用想了

    实现:这里是通过MediaPlayer.framework这个系统自带的框架来实现的。如果你有更好的实现方法,敬请留言哦~

    1. 需要在Info.plist文件中设置媒体库权限:Privacy - Media Library Usage Description——请允许访问
    2. 在需要实现该功能的相关类中导入
    #import <AVFoundation/AVFoundation.h>    //获取授权状态需要导入
    #import <MediaPlayer/MediaPlayer.h>        
    
    1. 根据授权状态进行不同的处理
        AVAuthorizationStatus status = [AVCaptureDevice authorizationStatusForMediaType:AVMediaTypeVideo];
        if (status != AVAuthorizationStatusAuthorized&&status != AVAuthorizationStatusNotDetermined) {
            NSLog(@"提示用户发开访问媒体库的权限");
        }else{
            [self getLocalMusicItem];
        }
    
    1. 主代码块
        MPMediaQuery *_musicQuery = [MPMediaQuery songsQuery];      //获取查询队列   注:这里获取的是以歌曲名称排序的查询队列
        
        //创建筛选条件
        _albumNamePredicate = [MPMediaPropertyPredicate predicateWithValue:[NSNumber numberWithInt:MPMediaTypeMusic] forProperty: MPMediaItemPropertyMediaType];
        [_musicQuery addFilterPredicate:_albumNamePredicate];
        //获取对应的集合  注:你可以注意一下items和collections和的区别,下面也会给出二者的区别
         _dataCollectionArr = _musicQuery.collections;      
        
        _dataArr = [NSMutableArray array];
        for (MPMediaItemCollection *songCollection in _dataCollectionArr) {
            MPMediaItem *songItem = songCollection.representativeItem;
            //NSString *songTitle = song.title;   等价于 NSString *songTitle = [song valueForProperty: MPMediaItemPropertyTitle];
            [_dataArr addObject:songItem];
        }
        [_tbView reloadData];
    
    1. 一些简单的调用:
    //获取歌曲名    等价于 NSString *songTitle = [song valueForProperty: MPMediaItemPropertyTitle];
    songItem.title;     
    //获取专辑名       
     songItem.albumTitle;  
    //获取歌手名      
    songItem.artist;      
    
     //获取当前条目对应数组    根据上文,则获取的是同一首歌对应的数组        
    MPMediaItemCollection *itemCollection = _dataCollectionArr[selIndex];
    NSArray *subArray = itemCollection.items;;      
    
     //查询        这里是通过查询实现获取当前条目对应数组,
     MPMediaItem *curSong = _dataArr[indexPath.row];
    NSString *propertyStr = MPMediaItemPropertyArtistPersistentID;
    NSString *keyIDStr = [curSong valueForProperty:propertyStr];
    _albumNamePredicate =  [MPMediaPropertyPredicate predicateWithValue:keyIDStr   forProperty: propertyStr];
    MPMediaQuery *query = [[MPMediaQuery alloc]init];
    [query addFilterPredicate:_albumNamePredicate];
    NSArray *itemsFromQuery = [query items];
    SubViewController *subVC = [[UIStoryboard storyboardWithName:@"Main" bundle:nil]instantiateViewControllerWithIdentifier:@"SubViewController"];
    subVC.dataArr = subArray;
    [self.navigationController pushViewController:subVC animated:YES];      
    
    1. items和collections和的区别:通过查阅官方文档可以看出。items只是当前条目,collections是集合的集合,通过collections可以获取到当前条目对应的集合。
    // Returns an array of MPMediaItems matching the query filter predicates.
    // If no items match this method returns an empty array, otherwise returns nil if an error prevents the items from being fetched.
    @property (nonatomic, readonly, nullable) NSArray<MPMediaItem *> *items      
    
     // Returns an array of MPMediaItemCollections matching the query filter predicates. The collections are grouped by the groupingType.
    @property (nonatomic, readonly, nullable) NSArray<MPMediaItemCollection *> *collections;
    
    1. 一个简单的Demo:AppleMusicDemo

    建议:砍掉如此这般的功能😆

    期待你的评论建议O(∩_∩)O~

    相关文章

      网友评论

          本文标题:iOS 读取音乐/歌曲文件

          本文链接:https://www.haomeiwen.com/subject/fldqnttx.html