cover_image

一行代码让你的TableView动起来-iOS动画

Cocoa开发者社区
2017年09月08日 02:58

前言

图片


UITableView 是iOS日常开发中经常使用到的控件。tableView的普通展示效果比较生硬,为了提升APP的活力,提升体验,我们可以对根据tableView的特点,操作Cell实现一些动画效果。


我写了一个简单的动画集 TableViewAnimationKit,只需要一行代码就可以让tableView实现动画


目前有大概10个动画,后续会优化增加。


源码放到Github上: TableViewAnimationKit 欢迎大家star、下载,交流沟通。



正文

图片


效果展示



图片

图片

图片


使用方法


TableViewAnimationKit调用各个动画的方法都为类方法,只需一行代码就可以调用。


eg:


[TableViewAnimationKit shakeAnimationWithTableView:tableView];


TableViewAnimationKit提供的动画类方法


+ (void)moveAnimationWithTableView:(UITableView *)tableView;

+ (void)alphaAnimationWithTableView:(UITableView *)tableView;

+ (void)fallAnimationWithTableView:(UITableView *)tableView;

+ (void)shakeAnimationWithTableView:(UITableView *)tableView;

+ (void)overTurnAnimationWithTableView:(UITableView *)tableView;

+ (void)toTopAnimationWithTableView:(UITableView *)tableView;

+ (void)springListAnimationWithTableView:(UITableView *)tableView;

+ (void)shrinkToTopAnimationWithTableView:(UITableView *)tableView;

+ (void)layDonwAnimationWithTableView:(UITableView *)tableView;

+ (void)roteAnimationWithTableView:(UITableView *)tableView;


源码讲解


先举其中一个动画效果为例子:


图片


动画效果为Cell左右各自插入。


实现代码很简单如下:


+ (void)shakeAnimationWithTableView:(UITableView *)tableView {

    

    NSArray *cells = tableView.visibleCells;

    for (int i = 0; i < cells.count; i++) {

        UITableViewCell *cell = [cells objectAtIndex:i];

        if (i%2 == 0) {

            cell.transform = CGAffineTransformMakeTranslation(-XS_SCREEN_WIDTH,0);

        }else {

            cell.transform = CGAffineTransformMakeTranslation(XS_SCREEN_WIDTH,0);

        }

        [UIView animateWithDuration:0.4 delay:i*0.03 usingSpringWithDamping:0.75 initialSpringVelocity:1/0.75 options:0 animations:^{

            cell.transform = CGAffineTransformIdentity;

        } completion:^(BOOL finished) {

            

        }];

    }

}


主要思路为:


获得tableview的visibleCells数组,进行遍历,对每个执行动画,不同cell的执行时间、方向有所差异,一起构成整个动画。


其他一些动画效果


图片

图片

图片

图片

图片


后语

图片



源码放到Github上: TableViewAnimationKit有需要的同学可以下载、star,目前只算Demo级别,后面会继续优化、增加动画。如有什么想法,欢迎进行技术交流。


作者:alanwangmodify

链接:http://www.jianshu.com/p/2dc3c9e0ca3e

來源:简书

著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。


CC严选

iOS 通用链接(UniversalLinks)+ 分享功能的一些看法

【iOS】Airbnb 开源动画库 Lottie 介绍以及详细示例

从916CVP沙龙这一课开始 选择成为更优秀的自己!

只有程序员才能懂的幽默,太生动形象了

基于开源项目搭建属于自己的技术堆栈

买买买 iPhone 8购机指南

CC严选


图片

继续滑动看下一个
Cocoa开发者社区
向上滑动看下一个