iOS 用Swipe手势和动画实现循环播放图片示例

 更新时间:2017年03月01日 10:18:55   作者:34码的小孩子  
本篇文章主要介绍了iOS 用Swipe手势和动画实现循环播放图片示例,非常具有实用价值,需要的朋友可以参考下。

主要想法

  • 添加3个ImageView展示图片,实现图片的无限循环。
  • 使用Swipe手势识别用户向右或向左滑动图片。
  • 使用CATransition给ImageView.layer添加动画,展示图片更换的效果。

实现

在storyboard添加三个UIImageView,用来展示图片。而数组imageArray则用来保存图片对象。

@interface ViewController ()

@property (strong, nonatomic) IBOutlet UIImageView *middleImage;
@property (strong, nonatomic) IBOutlet UIImageView *leftImage;
@property (strong, nonatomic) IBOutlet UIImageView *rightImage;
@property (strong, nonatomic) NSMutableArray *imageArray;

@end

在viewDidLoad方法中设置一些初始参数

- (void)viewDidLoad {
[super viewDidLoad];

[self initData];
[self initView];
[self circleSwipeToMiddleImage];
}

- (void)initData {
self.imageArray = [NSMutableArray new];
NSString *imageName;

for (int i = 0; i < 5; i++) {
  imageName = [NSString stringWithFormat:@"image%i", i];

  [self.imageArray addObject:[UIImage imageNamed:imageName]];
}
}

中间的UIImageView(middleImage)最开始展示的第一张图。

- (void)initView {
self.middleImage.image = self.imageArray[0];

//在imageView中添加外框,比较容易区分三张图片的位置
[self addBorder:self.middleImage];
[self addBorder:self.leftImage];
[self addBorder:self.rightImage];
}
- (void)addBorder:(UIImageView *)imageView {
imageView.layer.borderWidth = 1.0;
imageView.layer.borderColor = [UIColor lightGrayColor].CGColor;
}

接着在self.view上添加swipe手势,分别是向左和向右轻扫。swipe手势必须要指定direction轻扫方向,否则默认是向右轻扫。

#pragma mark - 图片循环播放

- (void)circleSwipeToMiddleImage {
UISwipeGestureRecognizer *gesture1 = [[UISwipeGestureRecognizer alloc] initWithTarget:self action:@selector(circleSwipeImageToRight)];
gesture1.direction = UISwipeGestureRecognizerDirectionRight;
self.view.userInteractionEnabled = YES;

UISwipeGestureRecognizer *gesture2 = [[UISwipeGestureRecognizer alloc] initWithTarget:self action:@selector(circleSwipeImageToLeft)];
gesture2.direction = UISwipeGestureRecognizerDirectionLeft;

[self.view addGestureRecognizer:gesture1];
[self.view addGestureRecognizer:gesture2];
}

然后实现轻扫响应方法。

向右轻扫,middleImage显示下一张图片,则图片的下标index是当前展示图片的下标 + 1。而为了实现无限循环并不超出数组的下标范围,则需要%图片数据的张数。

/**
 向右轻扫响应方法
 */
- (void)circleSwipeImageToRight {
UIImage *currentImage = self.middleImage.image;
NSInteger index = [self.imageArray indexOfObject:currentImage];
index = (index + 1) % self.imageArray.count;

 [self changeAnimation:index toRight:YES];
}

向左轻扫,middleImage显示上一张图片,则图片的下标index是当前展示图片的下标 - 1。而为了实现无限循环并不超出数组的下标范围,则需要加上图片的张数之后在%图片的张数。

/**
 向左轻扫响应方法
 */
- (void)circleSwipeImageToLeft {
UIImage *currentImage = self.middleImage.image;
NSInteger index = [self.imageArray indexOfObject:currentImage];
index = (index - 1 + self.imageArray.count) % self.imageArray.count;

[self changeAnimation:index toRight:NO];
}

最后是对middleImage.layer添加动画。

#pragma mark - 添加动画

/**
 为middleImage添加动画效果

 @param index  图片数组下标
 @param toRight 是否是向右滑动
 */
- (void)changeAnimation:(NSInteger)index toRight:(BOOL)toRight {
CATransition *transition = [CATransition animation];
transition.type = kCATransitionReveal; //设置动画过渡的方式

if (toRight) {
  //向右滑动,则图片是由左向右运动
  transition.subtype = kCATransitionFromLeft;
}
else {
  //向左滑动,则图片是由右向左运动
  transition.subtype = kCATransitionFromRight;
}

//将动画添加middleIamge.layer上
[self.middleImage.layer addAnimation:transition forKey:nil];

NSInteger count = self.imageArray.count;

if (index >= 0 && index < count) {
  //更改middleImage展示的图片
  self.middleImage.image = self.imageArray[index];
}
}

还有,图片可以选中了之后直接拉到项目的Assets.xcassets里面

最终效果如下:

其实在这个项目中,leftImage和rightImage都没有显示图片,可以去掉,为了展示有多张图片的效果,可以在middleImage后面添加一个加了边框的UIView。

而在这个项目中,有一个局限,就是transition.type 只能指定是kCATransitionReveal格式,其他的格式的过渡效果都比较差。可以使leftImage和rightImage展示图片,然后将位置调整一下,并且修改transition.type看一下效果。下面是更改为kCATransitionPush的效果。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • iOS开发使用GDataXML框架解析网络数据

    iOS开发使用GDataXML框架解析网络数据

    GDataXML是Google开发的一个XML解析库,轻便,特点使用非常简单,支持XPath。今天把前两天弄的IOS XML解析记录下来,也供大家参考。
    2016-02-02
  • iOS开发之图片模糊效果的五种实现代码

    iOS开发之图片模糊效果的五种实现代码

    本篇文章主要介绍了iOS开发之模糊效果的五种实现代码。本文针对这五种方式讲解一下具体的实现,有兴趣的同学可以一起来了解一下
    2017-04-04
  • yii框架分类树扩展示例

    yii框架分类树扩展示例

    这篇文章主要介绍了yii框架分类树扩展示例,提供两种方式的分类树格式,表格和下拉框形式的树形结构,需要的朋友可以参考下
    2014-04-04
  • ios之UIScrollerView滚动视图总结

    ios之UIScrollerView滚动视图总结

    本篇文章主要介绍了ios之UIScrollerView滚动视图总结,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-01-01
  • ios设计模式--委托模式

    ios设计模式--委托模式

    这篇文章主要介绍了ios设计模式中的委托模式,希望对大家学习ios框架有所帮助,下面让我们一起来了解一下吧
    2023-03-03
  • objective-c实现点到直线的距离及与垂足的交点

    objective-c实现点到直线的距离及与垂足的交点

    这篇文章主要给大家介绍了利用objective-c实现点到直线的距离及与垂足的交点的相关资料,文中给出了详细的实现思路和实现代码,对大家具有一定的参考价值,需要的朋友们下面来一起看看吧。
    2017-04-04
  • iOS利用NSMutableAttributedString实现富文本的方法小结

    iOS利用NSMutableAttributedString实现富文本的方法小结

    这篇文章主要给大家介绍了关于iOS利用NSMutableAttributedString如何实现富文本的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2018-05-05
  • iOS 通过collectionView实现照片删除功能

    iOS 通过collectionView实现照片删除功能

    这篇文章主要介绍了iOS 通过collectionView实现照片删除功能,代码简单易懂,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2017-11-11
  • IOS 添加自定义字体方法详解

    IOS 添加自定义字体方法详解

    这篇文章主要介绍了IOS 添加自定义字体方法详解的相关资料,需要的朋友可以参考下
    2016-09-09
  • 详解Swift 利用Opration和OprationQueue来下载网络图片

    详解Swift 利用Opration和OprationQueue来下载网络图片

    这篇文章主要介绍了详解Swift 利用Opration和OprationQueue来下载网络图片的相关资料,希望通过本文能帮助到大家,需要的朋友可以参考下
    2017-09-09

最新评论