亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 系統 > iOS > 正文

實例解析iOS中音樂播放器應用開發的基本要點

2020-07-26 03:30:23
字體:
來源:轉載
供稿:網友

一、調整項目的結構,導入必要的素材
  調整后的項目結構如下:

20161491512776.png (259×444)

二、新建兩個控制器
(1)新建一個控制器,用于展示音樂文件列表界面,其繼承自UITableViewController

20161491546838.png (511×136)

(2)新建一個控制器,用于展示播放界面,其繼承自UIViewController

20161491603783.png (507×135)

(3)在storyboard中,把之前的控制器刪除,換上一個導航控制器,設置tableViewController與之前新建的控制器類進行關聯

20161491621225.png (683×341)

三、音樂文件列表控制器中基本界面的搭建
(1)新建一個音樂文件的模型
根據plist文件建立模型:

20161491645285.png (654×211)
音樂模型的代碼如下:
YYMusicModel.h文件

復制代碼 代碼如下:

//
//  YYMusicModel.h
//  20-音頻處理(音樂播放器1)
//
//  Created by apple on 14-8-13.
//  Copyright (c) 2014年 yangyong. All rights reserved.
//

#import <Foundation/Foundation.h>

@interface YYMusicModel : NSObject
/**
 *  歌曲名字
 */
@property (copy, nonatomic) NSString *name;
/**
 *  歌曲大圖
 */
@property (copy, nonatomic) NSString *icon;
/**
 *  歌曲的文件名
 */
@property (copy, nonatomic) NSString *filename;
/**
 *  歌詞的文件名
 */
@property (copy, nonatomic) NSString *lrcname;
/**
 *  歌手
 */
@property (copy, nonatomic) NSString *singer;
/**
 *  歌手圖標
 */
@property (copy, nonatomic) NSString *singerIcon;
@end


(2)使用字典轉模型的第三方框架

20161491705409.png (208×143)

部分相關代碼如下:

20161491725512.png (567×355)

此時的界面顯示效果為:

20161491742778.png (316×494)

(3)添加一個UIimageView的分類,調整歌手的頭像(正方形――>圓形)
  分類的實現代碼如下:
  UIImage+YY.h文件

復制代碼 代碼如下:

#import <UIKit/UIKit.h>
 
@interface UIImage (YY)
+ (instancetype)circleImageWithName:(NSString *)name borderWidth:(CGFloat)borderWidth borderColor:(UIColor *)borderColor;
@end

  UIImage+YY.m文件
復制代碼 代碼如下:

#import "UIImage+YY.h"
#import <objc/message.h>

@implementation UIImage (YY)
+ (instancetype)circleImageWithName:(NSString *)name borderWidth:(CGFloat)borderWidth borderColor:(UIColor *)borderColor
{
    // 1.加載原圖
    UIImage *oldImage = [UIImage imageNamed:name];
   
    // 2.開啟上下文
    CGFloat imageW = oldImage.size.width + 2 * borderWidth;
    CGFloat imageH = oldImage.size.height + 2 * borderWidth;
    CGSize imageSize = CGSizeMake(imageW, imageH);
    UIGraphicsBeginImageContextWithOptions(imageSize, NO, 0.0);
   
    // 3.取得當前的上下文
    CGContextRef ctx = UIGraphicsGetCurrentContext();
   
    // 4.畫邊框(大圓)
    [borderColor set];
    CGFloat bigRadius = imageW * 0.5; // 大圓半徑
    CGFloat centerX = bigRadius; // 圓心
    CGFloat centerY = bigRadius;
    CGContextAddArc(ctx, centerX, centerY, bigRadius, 0, M_PI * 2, 0);
    CGContextFillPath(ctx); // 畫圓
   
    // 5.小圓
    CGFloat smallRadius = bigRadius - borderWidth;
    CGContextAddArc(ctx, centerX, centerY, smallRadius, 0, M_PI * 2, 0);
    // 裁剪(后面畫的東西才會受裁剪的影響)
    CGContextClip(ctx);
   
    // 6.畫圖
    [oldImage drawInRect:CGRectMake(borderWidth, borderWidth, oldImage.size.width, oldImage.size.height)];
   
    // 7.取圖
    UIImage *newImage = UIGraphicsGetImageFromCurrentImageContext();
   
    // 8.結束上下文
    UIGraphicsEndImageContext();
   
    return newImage;
}
@end


分類的使用:

20161491759734.png (814×366)

實現的效果:

20161491818008.png (315×492)

(4)推薦使用一個第三方框架,用來處理顏色

20161491840633.png (193×146)

涉及的代碼:

20161491858112.png (761×141)

四、實現代碼
  YYMusicsViewController.m文件

復制代碼 代碼如下:

//
//  YYMusicsViewController.m
//  20-音頻處理(音樂播放器1)
//
//  Created by apple on 14-8-13.
//  Copyright (c) 2014年 yangyong. All rights reserved.
//

#import "YYMusicsViewController.h"
#import "YYMusicModel.h"
#import "MJExtension.h"
#import "UIImage+YY.h"
#import "Colours.h"

@interface YYMusicsViewController ()
@property(nonatomic,strong)NSArray *musics;
@end


復制代碼 代碼如下:

@implementation YYMusicsViewController
#pragma mark-懶加載
-(NSArray *)musics
{
    if (_musics==nil) {
        _musics=[YYMusicModel objectArrayWithFilename:@"Musics.plist"];
    }
    return _musics;
}


- (void)viewDidLoad
{
    [super viewDidLoad];
   
}

#pragma mark - Table view data source
/**
 *一共多少組
 */
-(NSInteger)numberOfSectionsInTableView:(UITableView *)tableView
{
    return 1;
}
/**
 *每組多少行
 */
-(NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section
{
    return self.musics.count;
}
/**
 *每組每行的cell
 */
-(UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
{
    static NSString *ID=@"ID";
    UITableViewCell *cell=[tableView dequeueReusableCellWithIdentifier:ID];
    if (cell==nil) {
        cell=[[UITableViewCell alloc]initWithStyle:UITableViewCellStyleSubtitle reuseIdentifier:ID];
    }
    //取出數據模型
    YYMusicModel *model=self.musics[indexPath.row];
    cell.textLabel.text=model.name;
    cell.detailTextLabel.text=model.singer;
    cell.imageView.image=[UIImage circleImageWithName:model.singerIcon borderWidth:1 borderColor:[UIColor skyBlueColor]];
    return cell;
}
/**
 *  設置每個cell的高度
 */
-(CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath
{
    return 70;
}

/**
 *  cell的點擊事件
 */
-(void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath
{
    //取消選中被點擊的這行
    [tableView deselectRowAtIndexPath:indexPath animated:YES];
   
}
@end


五、改進
  對tableViewcell的代碼進行封裝:
實現:新建一個YYmusicCell類,繼承自UITableViewCell。
封裝代碼如下:
YYMusicCell.h文件
復制代碼 代碼如下:

//
//  YYMusicCell.h
//  20-音頻處理(音樂播放器1)
//
//  Created by apple on 14-8-13.
//  Copyright (c) 2014年 yangyong. All rights reserved.
//

#import <UIKit/UIKit.h>
@class YYMusicModel;
@interface YYMusicCell : UITableViewCell
+(instancetype)cellWithTableView:(UITableView *)tableView;
@property(nonatomic,strong)YYMusicModel *music;
@end


YYMusicCell.m文件
復制代碼 代碼如下:

//
//  YYMusicCell.m
//  20-音頻處理(音樂播放器1)
//
//  Created by apple on 14-8-13.
//  Copyright (c) 2014年 yangyong. All rights reserved.
//

#import "YYMusicCell.h"
#import "YYMusicModel.h"
#import "Colours.h"
#import "UIImage+YY.h"

@implementation YYMusicCell
//返回一個cell
+(instancetype)cellWithTableView:(UITableView *)tableView
{
    static NSString *ID=@"ID";
    YYMusicCell *cell=[tableView dequeueReusableCellWithIdentifier:ID];
    if (cell==nil) {
        cell=[[YYMusicCell alloc]initWithStyle:UITableViewCellStyleSubtitle reuseIdentifier:ID];
    }
    return cell;
}

-(void)setMusic:(YYMusicModel *)music
{
    _music=music;
    self.textLabel.text=music.name;
    self.detailTextLabel.text=music.singer;
    self.imageView.image=[UIImage circleImageWithName:music.singerIcon borderWidth:1 borderColor:[UIColor skyBlueColor]];
}
@end


YYMusicsViewController.m文件
復制代碼 代碼如下:

//
//  YYMusicsViewController.m
//  20-音頻處理(音樂播放器1)
//
//  Created by apple on 14-8-13.
//  Copyright (c) 2014年 yangyong. All rights reserved.
//

#import "YYMusicsViewController.h"
#import "YYMusicModel.h"
#import "MJExtension.h"
#import "YYMusicCell.h"

@interface YYMusicsViewController ()
@property(nonatomic,strong)NSArray *musics;
@end


復制代碼 代碼如下:

@implementation YYMusicsViewController
#pragma mark-懶加載
-(NSArray *)musics
{
    if (_musics==nil) {
        _musics=[YYMusicModel objectArrayWithFilename:@"Musics.plist"];
    }
    return _musics;
}

- (void)viewDidLoad
{
    [super viewDidLoad];
}

#pragma mark - Table view data source
/**
 *一共多少組
 */
-(NSInteger)numberOfSectionsInTableView:(UITableView *)tableView
{
    return 1;
}
/**
 *每組多少行
 */
-(NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section
{
    return self.musics.count;
}
/**
 *每組每行的cell
 */
-(UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
{
    YYMusicCell *cell=[YYMusicCell cellWithTableView:tableView];
    cell.music=self.musics[indexPath.row];
    return cell;
}
/**
 *  設置每個cell的高度
 */
-(CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath
{
    return 70;
}

/**
 *  cell的點擊事件
 */
-(void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath
{
    //取消選中被點擊的這行
    [tableView deselectRowAtIndexPath:indexPath animated:YES];
   
}
@end


實現效果:

20161491930658.png (318×500)

六、補充說明

需要注意的細節處理

(1)UIImageView的分類,方形圖片剪為圓形

(2)顏色的處理,文章中推薦的顏色處理框架提供了大量的顏色。

(3)取消選中被點擊的這行cell.

復制代碼 代碼如下:

    [tableView deselectRowAtIndexPath:indexPath animated:YES];

(4)tableViewCell的封裝

七、跳轉
1.跳轉到音樂播放界面的方法選擇
 ?。?)使用模態跳轉(又分為手動的和自動的)
 ?。?)使用xib并設置跳轉
2.兩種方法的分析
  可以使用模態的方法,添加一個控制器,讓這個控制器和音樂播放控制器類進行關聯,脫線,設置標識符且在cell的點擊事件中執行segue即可。
  步驟說明:
 ?。?)在storyboard中新拖入一個控制器,然后設置和playing控制器類相關聯。

20161491951708.png (1089×158)

(2)設置手動跳轉

20161492016251.png (505×407)

(3)設置segue的標識符

20161492039138.png (256×139)

(3)跳轉代碼處理

20161492055780.png (724×218)

不推薦使用模態的原因如下:
    當選中一首音樂跳轉到播放界面進行播放后,如果要跳回到音樂列表界面,那么最常見的做法是在音樂播放控制器上添加一個按鈕。
    當點擊的時候,銷毀這個控制器(dismissed)。但是,控制器銷毀了那么正在播放的音樂也就隨之不在了。
    且由于播放界面控制器的布局是固定的,因此這里選擇的方法是使用xib進行創建。
3.選擇的方法
  新建一個xib,對應于音樂播放控制器。
  xib的結構如下圖所示:

20161492112778.png (734×609)

細節:控制器只需要創建一次,因此建議使用懶加載,當然也可是把播放器設置為單例

復制代碼 代碼如下:

//
//  YYMusicsViewController.m
//

#import "YYMusicsViewController.h"
#import "YYMusicModel.h"
#import "MJExtension.h"
#import "YYMusicCell.h"
#import "YYPlayingViewController.h"

@interface YYMusicsViewController ()
@property(nonatomic,strong)NSArray *musics;
@property(nonatomic,strong)YYPlayingViewController *playingViewController;
@end


復制代碼 代碼如下:

@implementation YYMusicsViewController
#pragma mark-懶加載
-(NSArray *)musics
{
    if (_musics==nil) {
        _musics=[YYMusicModel objectArrayWithFilename:@"Musics.plist"];
    }
    return _musics;
}
-(YYPlayingViewController *)playingViewController
{
    if (_playingViewController==nil) {
        _playingViewController=[[YYPlayingViewController alloc]init];
    }
    return _playingViewController;
}

4.xib的內部細節:
(1)已經實現了約束,用于適配ios6和ios7。
(2)設置音樂名稱和歌手的View設置為半透明的,設置方法如下:

20161492131283.png (249×140)

設置為30%

20161492146732.png (213×361)

注意:不要再storyboard中控件的屬性面板上設置透明度(這樣的話,這個控件中的子控件也是同樣的透明度)。
    不推薦的做法:

20161492200046.png (251×148)

(3)按鈕點擊發光

20161492222793.png (241×103)

(4)設置view隱藏能夠節省一些性能。(參考代碼)
(5)在切換控制器的過程中,設置窗口不能點擊(這樣做是為了防止用戶多次連續的點擊歌曲名會出現的問題)。
 
5.補充:
  項目代碼中拖入了UIView的分類,以方便計算frame
 
6.涉及到的代碼
在播放控制器的.h文件中提供一個公共對象方法接口
YYPlayingViewController.h文件

復制代碼 代碼如下:

//  YYPlayingViewController.h

#import <UIKit/UIKit.h>

@interface YYPlayingViewController : UIViewController
//顯示控制器
-(void)show;
@end


YYPlayingViewController.m文件
復制代碼 代碼如下:

//
//  YYPlayingViewController.m
//

#import "YYPlayingViewController.h"

@interface YYPlayingViewController ()
- (IBAction)exit;

@end


復制代碼 代碼如下:

@implementation YYPlayingViewController
#pragma mark-公共方法
-(void)show
{
    //1.禁用整個app的點擊事件
    UIWindow *window=[UIApplication sharedApplication].keyWindow;
    window.userInteractionEnabled=NO;
   
    //2.添加播放界面
    //設置View的大小為覆蓋整個窗口
    self.view.frame=window.bounds;
    //設置view顯示
    self.view.hidden=NO;
    //把View添加到窗口上
    [window addSubview:self.view];
   
    //3.使用動畫讓View顯示
    self.view.y=self.view.height;
    [UIView animateWithDuration:0.25 animations:^{
        self.view.y=0;
    } completion:^(BOOL finished) {
        window.userInteractionEnabled=YES;
    }];
}
#pragma mark-內部的按鈕監聽方法
//返回按鈕
- (IBAction)exit {
    //1.禁用整個app的點擊事件
    UIWindow *window=[UIApplication sharedApplication].keyWindow;
    window.userInteractionEnabled=NO;
   
    //2.動畫隱藏View
    [UIView animateWithDuration:0.25 animations:^{
        self.view.y=window.height;
    } completion:^(BOOL finished) {
        window.userInteractionEnabled=YES;
        //設置view隱藏能夠節省一些性能
        self.view.hidden=YES;
    }];
}
@end

cell的點擊事件中的處理代碼:
復制代碼 代碼如下:

/**
 *  cell的點擊事件
 */
-(void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath
{
    //取消選中被點擊的這行
    [tableView deselectRowAtIndexPath:indexPath animated:YES];
   
    //調用公共方法
    [self.playingViewController show];
   
//    //執行segue跳轉
//    [self performSegueWithIdentifier:@"music2playing" sender:nil];
}

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
91精品在线一区| 日韩中文在线观看| 中文字幕国产精品| 欧美性猛交xxxx富婆弯腰| 91在线观看免费网站| 97精品一区二区视频在线观看| 中文字幕欧美在线| 国产专区欧美专区| 91精品国产乱码久久久久久蜜臀| 在线亚洲欧美视频| 亚洲级视频在线观看免费1级| 国产精品99久久99久久久二8| 日韩av在线免费看| 日韩av手机在线| 久久免费视频网站| 欧美超级乱淫片喷水| 精品国产一区二区三区在线观看| 超碰日本道色综合久久综合| 久久综合88中文色鬼| 国产男人精品视频| 久久久久久久久久久亚洲| 欧美成人在线免费视频| 国产精品一二区| 亚洲自拍高清视频网站| 福利二区91精品bt7086| 欧美高清在线观看| 亚洲乱亚洲乱妇无码| 欧美极品少妇xxxxⅹ裸体艺术| 日韩av在线免播放器| 欧洲亚洲免费视频| 欧美精品福利视频| 麻豆国产精品va在线观看不卡| 欧美在线视频免费播放| 久久久国产精品一区| 人人做人人澡人人爽欧美| 亚洲另类xxxx| 国产精品久久久久77777| 亚洲专区中文字幕| 亚洲一区二区久久久| 亚洲国产精品999| 国产精品视频一区国模私拍| 国产日产欧美a一级在线| 国产一区二区日韩精品欧美精品| 国产精品久久久久久久久久久新郎| 欧美猛交ⅹxxx乱大交视频| 97久久精品人人澡人人爽缅北| 在线成人免费网站| 国产一区二区三区久久精品| 92国产精品久久久久首页| 色爱av美腿丝袜综合粉嫩av| 亚洲毛片在线观看.| 中日韩午夜理伦电影免费| 欧美肥老太性生活视频| 欧美国产日韩一区| 91精品91久久久久久| 国产97在线|亚洲| 日本亚洲欧美成人| 国产精品91在线| 在线亚洲国产精品网| 九九精品视频在线| 亚洲香蕉av在线一区二区三区| 国产精品入口免费视| 欧美午夜精品在线| 高清欧美一区二区三区| 伦伦影院午夜日韩欧美限制| 粗暴蹂躏中文一区二区三区| xvideos国产精品| 亚洲视频777| 操日韩av在线电影| 欧美一级淫片aaaaaaa视频| 久久久精品美女| 欧美精品少妇videofree| 国产精品小说在线| 日韩精品在线观看视频| 久久影院免费观看| www.亚洲男人天堂| 97精品久久久中文字幕免费| 九九视频直播综合网| 欧美一级大片在线观看| 欧美最顶级丰满的aⅴ艳星| 国产+成+人+亚洲欧洲| 国产成人精品一区二区三区| 国产精品专区h在线观看| 91av在线视频观看| 69久久夜色精品国产69乱青草| 欧美日韩中文字幕综合视频| 欧美激情极品视频| 精品亚洲一区二区三区在线播放| 欧美日韩国产色视频| 国产精品久久久久久久久久新婚| 精品日本高清在线播放| 亚洲精品国产精品国自产观看浪潮| 91久久精品国产91久久性色| 久久福利视频网| 亚洲成av人片在线观看香蕉| 一区二区三区国产在线观看| 午夜精品美女自拍福到在线| 欧美激情视频在线观看| 日韩在线播放av| 欧美国产中文字幕| 欧美性猛xxx| 亚洲情综合五月天| 国产精品免费看久久久香蕉| 国产91精品高潮白浆喷水| 欧美日韩精品中文字幕| 亚洲wwwav| 亚洲丁香久久久| 精品性高朝久久久久久久| 国产日韩欧美自拍| 日韩有码在线视频| 亚洲精品视频网上网址在线观看| 国产美女高潮久久白浆| 午夜精品久久久久久久久久久久久| 国产亚洲精品久久久久久| 日韩欧美成人免费视频| 国产精品久久中文| 欧美精品制服第一页| 青草青草久热精品视频在线网站| 亚洲经典中文字幕| 亚洲男人天堂2024| 欧美精品九九久久| 狠狠综合久久av一区二区小说| 亚洲欧美精品在线| 日韩欧美在线免费观看| 国产美女直播视频一区| 国产精品视频自在线| 亚洲精品720p| 欧美成人免费va影院高清| 国产精品专区第二| 欧美在线精品免播放器视频| 456亚洲影院| 国产suv精品一区二区| 国产精品久久久久久中文字| 日韩有码在线视频| 91精品久久久久久久久久入口| 久久色精品视频| 国产婷婷色综合av蜜臀av| 26uuu久久噜噜噜噜| 欧美综合第一页| 欧洲美女7788成人免费视频| 国产一区二区三区在线播放免费观看| 国产999精品视频| 国产va免费精品高清在线观看| 在线播放国产一区二区三区| 国产一区二区三区视频免费| 久久精品一偷一偷国产| 黑人巨大精品欧美一区二区三区| 日韩av免费一区| 久久久精品一区二区三区| 久久久久久久爱| 国产激情综合五月久久| 久久久久久18| 国内揄拍国内精品少妇国语| 日韩视频第一页| 国产欧美日韩亚洲精品| 日韩欧美在线视频日韩欧美在线视频| 欧美激情综合色综合啪啪五月| 亚洲第一免费网站| 欧美日韩亚洲成人| 日韩高清有码在线| 日韩欧美成人免费视频| 亚洲va久久久噜噜噜久久天堂| 欧美专区在线视频| 国内精品国产三级国产在线专|