【IOS动画】UIView放大缩小背景淡入淡出动画效果

UIView+CGAffineTransform.h:

#import <UIKit/UIKit.h>

#define animateWithDuration_times 0.2
#define animateWithDuration_sade_times 0.1
@interface UIView (CGAffineTransform)
//放大
-(void)show:(void(^)(void))finishBlock;
//缩小
-(void)hidden:(void(^)(void))finishBlock;

//淡入
-(void)sadeIn:(void(^)(void))finishBlock;
//淡出
-(void)sadeOut:(void(^)(void))finishBlock;
@end


UIView+CGAffineTransform.m:

#import "UIView+CGAffineTransform.h"

#import "UIView+CGAffineTransform.h"

@implementation UIView (CGAffineTransform)
-(void)show:(void(^)(void))finishBlock{
    //缩小创建好的视图
    CGAffineTransform newTransform = CGAffineTransformScale(self.transform, 0.1, 0.1);
    [self setTransform:newTransform];
    
    //第一次显示的时候放大它
    [UIView animateWithDuration:animateWithDuration_times animations:^{
        CGAffineTransform newTransform = CGAffineTransformConcat(self.transform,  CGAffineTransformInvert(self.transform));
        [self setTransform:newTransform];
        self.alpha = 1.0;
    } completion:^(BOOL finished) {
        if(finishBlock != nil){
            finishBlock();
        }
    }];
}
-(void)hidden:(void(^)(void))finishBlock{
    [UIView animateWithDuration:animateWithDuration_times animations:^{
        CGAffineTransform newTransform =  CGAffineTransformScale(self.transform, 0.0, 0.0);
        [self setTransform:newTransform];
    } completion:^(BOOL finished) {
        if(finishBlock != nil){
            finishBlock();
        }
    }];
    
}

//淡入
-(void)sadeIn:(void(^)(void))finishBlock{
    self.alpha = 0.0;
    [UIView animateWithDuration:animateWithDuration_sade_times animations:^{
        self.alpha = 1.0;
    } completion:^(BOOL finished) {
        if(finishBlock != nil){
            finishBlock();
        }
    }];
}
//淡出
-(void)sadeOut:(void(^)(void))finishBlock;{
    [UIView animateWithDuration:animateWithDuration_sade_times animations:^{
        self.alpha = 0.0;
    } completion:^(BOOL finished) {
        if(finishBlock != nil){
            finishBlock();
        }
    }];
}
@end

调用方式:
[_background sadeIn:^{
        [_background addSubview:_webContainer];
        [_webContainer show:^{
            [self loadUrl:_url webview:alertWebView];
        }];
    }];
        






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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值