UIImageView 平滑过渡图片切换

本文介绍了一个简单的iOS应用示例,使用Swift实现图片视图在触摸结束时进行淡入淡出切换的效果。通过CATransition设置动画类型及时长,并利用触摸事件来循环显示不同的UIImage对象。

eg:

#import "ViewController.h"


@interface ViewController ()

@property (nonatomic, strong) UIImageView *imageView;

@property (nonatomic, copy) NSArray *images;

@end


@implementation ViewController


- (void)viewDidLoad

{

    [super viewDidLoad];


    self.images = @[[UIImage imageNamed:@"1.png"],

                    [UIImage imageNamed:@"2.png"]

                    ];

    

    self.imageView = [[UIImageView alloc] initWithFrame:CGRectMake(100, 100, 100, 100)];

    [self.imageView setBackgroundColor:[UIColor redColor]];

    [self.view addSubview:self.imageView];

}


- (void)touchesEnded:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event

{

    //set up crossfade transition

    CATransition *transition = [CATransition animation];

    transition.type = kCATransitionFade;

    transition.duration = 2.0;

    [self.imageView.layer addAnimation:transition forKey:nil];

    

    //cycle to next image

    UIImage *currentImage = self.imageView.image;

    NSUInteger index = [self.images indexOfObject:currentImage];

    index = (index + 1) % [self.images count];

    self.imageView.image = self.images[index];

}


@end


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值