仿网易云音乐播放音乐转盘

#import <UIKit/UIKit.h>

@interface GKWYMusicCoverView : UIView

@property (nonatomic, strong) UIImageView *imgView;

- (void)playedWithAnimated:(BOOL)animated;

- (void)pausedWithAnimated:(BOOL)animated;

@end

//
//  GKWYMusicCoverView.m
//  GKAudioPlayerDemo
//
//  Created by QuintGao on 2017/9/19.
//  Copyright © 2017年 高坤. All rights reserved.
//

#import "GKWYMusicCoverView.h"

#define SCREEN_WIDTH_A ([UIScreen mainScreen].bounds.size.width)
#define SCREEN_HEIGHT_A ([UIScreen mainScreen].bounds.size.height)

#define SCREEN_WIDTH  MAX(SCREEN_WIDTH_A, SCREEN_HEIGHT_A)
#define SCREEN_HEIGHT MIN(SCREEN_WIDTH_A, SCREEN_HEIGHT_A)

#define MAS_SHORTHAND

//define this constant if you want to enable auto-boxing for default syntax
#define MAS_SHORTHAND_GLOBALS

#import "Masonry.h"

@interface GKWYMusicCoverView()

@property (nonatomic, strong) UIView *sepLineView;

@property (nonatomic, strong) UIImageView *imageView;

@property (nonatomic, strong) UIView *coverView;

@property (nonatomic, strong) UIImageView *needleView;

@property (nonatomic, strong) CADisplayLink *displayLink;

/** 是否正在动画 */
@property (nonatomic, assign) BOOL isAnimation;

@end

@implementation GKWYMusicCoverView

- (instancetype)initWithFrame:(CGRect)frame {
    if (self = [super initWithFrame:frame]) {
        // 超出部分裁剪
        self.clipsToBounds = YES;
        
        [self addSubview:self.sepLineView];
        [self addSubview:self.imageView];
        [self addSubview:self.coverView];
        
        [self addSubview:self.needleView];
        
        [self.sepLineView mas_makeConstraints:^(MASConstraintMaker *make) {
            make.left.top.right.equalTo(self);
            make.height.mas_equalTo(0.5);
        }];
        
        [self.imageView mas_makeConstraints:^(MASConstraintMaker *make) {
            make.centerX.equalTo(self);
            make.centerY.equalTo(self).offset(-12);
            make.width.height.mas_equalTo(SCREEN_WIDTH - 100);
        }];
        
        [self.coverView mas_makeConstraints:^(MASConstraintMaker *make) {
            make.centerX.equalTo(self);
            make.centerY.equalTo(self).offset(-12);
            make.width.height.mas_equalTo(SCREEN_WIDTH - 200);
        }];
        
        self.coverView.layer.borderColor = [[UIColor whiteColor] colorWithAlphaComponent:0.2].CGColor;
        self.coverView.layer.borderWidth = 10;
        self.coverView.layer.cornerRadius = (SCREEN_WIDTH - 75) * 0.5;
        
        [self.imageView addSubview:self.imgView];
        
        CGFloat imgWH = SCREEN_WIDTH - 180 - 100;
        
        [self.imgView mas_makeConstraints:^(MASConstraintMaker *make) {
            make.center.equalTo(self.imageView);
            make.width.height.mas_equalTo(imgWH);
        }];
        
        self.imgView.layer.cornerRadius = imgWH * 0.5;
        self.imgView.layer.masksToBounds = YES;
    }
    return self;
}

- (void)layoutSubviews {
    [super layoutSubviews];
    
    self.needleView.center = CGPointMake(100, self.needleView.center.y);
    
    CGPoint p = self.needleView.frame.origin;
    p.y = -25;
    
    CGRect rect = self.needleView.frame;
    rect.origin = p;
    self.needleView.frame       = rect;

    [self pausedWithAnimated:NO];
}

// 播放音乐时,指针恢复,图片旋转
- (void)playedWithAnimated:(BOOL)animated {
    
    if (self.isAnimation) return;
    
    self.isAnimation = YES;
    
    [self setAnchorPoint:CGPointMake(25.0/97, 25.0/153) forView:self.needleView];
    
    if (animated) {
        [UIView animateWithDuration:0.5 animations:^{
            self.needleView.transform = CGAffineTransformIdentity;
        }];
    }else {
        self.needleView.transform = CGAffineTransformIdentity;
    }
    
//    self.displayLink = [CADisplayLink displayLinkWithTarget:self selector:@selector(animation)];
    
    // 加入到主循环中
//    [self.displayLink addToRunLoop:[NSRunLoop mainRunLoop] forMode:NSDefaultRunLoopMode];
    
    [NSTimer scheduledTimerWithTimeInterval:0.1f target:self selector:@selector(animation) userInfo:nil repeats:YES];
}

// 停止音乐时,指针旋转-30°,图片停止旋转
- (void)pausedWithAnimated:(BOOL)animated {
    
    if (!self.isAnimation) return;
    
    self.isAnimation = NO;
    
    [self setAnchorPoint:CGPointMake(25.0/97, 25.0/153) forView:self.needleView];
    
    if (animated) {
        [UIView animateWithDuration:0.5 animations:^{
            self.needleView.transform = CGAffineTransformMakeRotation(-M_PI_2 / 2);
        }];
    }else {
        self.needleView.transform = CGAffineTransformMakeRotation(-M_PI_4);
    }
    
    [self.displayLink invalidate];
}

// 图片旋转
- (void)animation {
    self.imageView.transform = CGAffineTransformRotate(self.imageView.transform, M_PI_4 / 100);
}

- (void)setAnchorPoint:(CGPoint)anchorPoint forView:(UIView *)view
{
    CGPoint oldOrigin = view.frame.origin;
    view.layer.anchorPoint = anchorPoint;
    CGPoint newOrigin = view.frame.origin;
    
    CGPoint transition;
    transition.x = newOrigin.x - oldOrigin.x;
    transition.y = newOrigin.y - oldOrigin.y;
    
    view.center = CGPointMake (view.center.x - transition.x, view.center.y - transition.y);
}

#pragma mark - 懒加载
- (UIView *)sepLineView {
    if (!_sepLineView) {
        _sepLineView = [UIView new];
        _sepLineView.backgroundColor = [[UIColor whiteColor] colorWithAlphaComponent:0.6];
    }
    return _sepLineView;
}

- (UIImageView *)imageView {
    if (!_imageView) {
        _imageView = [UIImageView new];
        _imageView.image = [UIImage imageNamed:@"cm2_play_disc-ip6"];
    }
    return _imageView;
}

- (UIView *)coverView {
    if (!_coverView) {
        _coverView = [UIView new];
        _coverView.backgroundColor = [UIColor clearColor];
    }
    return _coverView;
}

- (UIImageView *)needleView {
    if (!_needleView) {
        _needleView = [UIImageView new];
        _needleView.image = [UIImage imageNamed:@"cm2_play_needle_play"];
        [_needleView sizeToFit];
    }
    return _needleView;
}

- (UIImageView *)imgView {
    if (!_imgView) {
        _imgView = [UIImageView new];
    }
    return _imgView;
}

@end

//
//  ViewController.m
//  afafffff
//
//  Created by huangmindong on 2017/9/26.
//  Copyright © 2017年 huangmindong. All rights reserved.
//

#import "ViewController.h"
#import "GKWYMusicCoverView.h"
#define SCREEN_WIDTH_A ([UIScreen mainScreen].bounds.size.width)
#define SCREEN_HEIGHT_A ([UIScreen mainScreen].bounds.size.height)

#define SCREEN_WIDTH  MAX(SCREEN_WIDTH_A, SCREEN_HEIGHT_A)
#define SCREEN_HEIGHT MIN(SCREEN_WIDTH_A, SCREEN_HEIGHT_A)

@interface ViewController ()
@property (nonatomic, strong) GKWYMusicCoverView *coverImgView;
@end

@implementation ViewController

- (void)viewDidLoad {
    [super viewDidLoad];
    // Do any additional setup after loading the view, typically from a nib.
    
    
    [self.view addSubview:self.coverImgView];
    self.coverImgView.frame = CGRectMake(0, 0, 320, 568);
    
    [self.coverImgView addGestureRecognizer:[[UITapGestureRecognizer alloc] initWithTarget:self action:@selector(pausePlay)]];
    
    
    
    dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(1 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
//         [self.coverImgView pausedWithAnimated:YES];
        
        [self.coverImgView playedWithAnimated:YES];
    });
}

- (void)pausePlay
{
    static BOOL pause = NO;
    pause = !pause;
    if (pause) {
        [self.coverImgView pausedWithAnimated:YES];
    }else
    {
        [self.coverImgView playedWithAnimated:YES];
    }
}

- (void)didReceiveMemoryWarning {
    [super didReceiveMemoryWarning];
    // Dispose of any resources that can be recreated.
}

- (GKWYMusicCoverView *)coverImgView {
    if (!_coverImgView) {
        _coverImgView = [GKWYMusicCoverView new];
    }
    return _coverImgView;
}
@end
 



http://www.jianshu.com/p/41ac0c9d6b21

https://github.com/QuintGao/GKAudioPlayerDemo

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值