Swift - UITableView展开缩放动画

效果

源码

https://github.com/YouXianMing/Swift-Animations

//
//  HeaderViewTapAnimationController.swift
//  Swift-Animations
//
//  Created by YouXianMing on 16/8/9.
//  Copyright © 2016年 YouXianMing. All rights reserved.
//

import UIKit

class HeaderViewTapAnimationController: NormalTitleViewController, UITableViewDelegate, UITableViewDataSource {

    private var classes           : [ClassModel]!
    private var tableView         : UITableView!
    private var sectionFirstLoad  : Bool!
    private weak var tmpHeadView  : ClassHeaderView!

    override func setup() {

        super.setup()

        sectionFirstLoad = false

        // TableView.
        tableView                     = UITableView(frame: (contentView?.bounds)!)
        tableView.dataSource          = self
        tableView.delegate            = self
        tableView.rowHeight           = 60
        tableView.sectionHeaderHeight = 30
        tableView.separatorStyle      = .None
        contentView?.addSubview(tableView!)

        // Register.
        ClassHeaderView.registerToTableView(tableView)
        StudentInfoCell.registerToTableView(tableView)

        // Data source.
        let Aitna    = ClassModel(className: "Aitna")
        Aitna.expend = false
        Aitna.students?.append(StudentModel(name: "Y.X.M.",  age: 27))
        Aitna.students?.append(StudentModel(name: "Leif",    age: 12))
        Aitna.students?.append(StudentModel(name: "Lennon",  age: 23))
        Aitna.students?.append(StudentModel(name: "Jerome",  age: 19))
        Aitna.students?.append(StudentModel(name: "Isidore", age: 15))

        let Melete    = ClassModel(className: "Melete")
        Melete.expend = false
        Melete.students?.append(StudentModel(name: "Merle",  age: 17))
        Melete.students?.append(StudentModel(name: "Paddy",  age: 31))
        Melete.students?.append(StudentModel(name: "Perry",  age: 59))
        Melete.students?.append(StudentModel(name: "Philip", age: 23))

        let Aoede    = ClassModel(className: "Aoede")
        Aoede.expend = false
        Aoede.students?.append(StudentModel(name: "Verne",   age: 12))
        Aoede.students?.append(StudentModel(name: "Vincent", age: 89))
        Aoede.students?.append(StudentModel(name: "Walter",  age: 43))
        Aoede.students?.append(StudentModel(name: "Zachary", age: 21))

        let Dione    = ClassModel(className: "Dione")
        Dione.expend = false
        Dione.students?.append(StudentModel(name: "Timothy",  age: 72))
        Dione.students?.append(StudentModel(name: "Roderick", age: 34))
        Dione.students?.append(StudentModel(name: "Quentin",  age: 12))
        Dione.students?.append(StudentModel(name: "Paddy",    age: 75))

        let Adanos    = ClassModel(className: "Adanos")
        Adanos.expend = false
        Adanos.students?.append(StudentModel(name: "Mortimer", age: 43))
        Adanos.students?.append(StudentModel(name: "Michael",  age: 64))
        Adanos.students?.append(StudentModel(name: "Kevin",    age: 23))
        Adanos.students?.append(StudentModel(name: "Jeremy",   age: 21))

        classes = [ClassModel]()
        classes.append(Aitna)
        classes.append(Melete)
        classes.append(Aoede)
        classes.append(Dione)
        classes.append(Adanos)

        // Expend animations.
        GCDQueue.executeInMainQueue({ 

            self.sectionFirstLoad = true
            self.tableView.insertSections(NSIndexSet(indexesInRange: NSMakeRange(0, self.classes.count)), withRowAnimation: .Fade)

            GCDQueue.executeInMainQueue({

                self.tmpHeadView.buttonEvent()

                }, afterDelaySeconds: 0.4)
            }, afterDelaySeconds: 0.3)
    }

    // MARK: UITableView‘s delegate & dataSource.

    func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int {

        let classModel = classes[section]
        if classModel.expend == true {

            return (classModel.students?.count)!

        } else {

            return 0
        }
    }

    func numberOfSectionsInTableView(tableView: UITableView) -> Int {

        if sectionFirstLoad == false {

            return 0

        } else {

            return classes.count
        }
    }

    func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {

        let classModel       = classes[indexPath.section]
        let customCell       = tableView.dequeueReusableCellWithIdentifier("StudentInfoCell") as! CustomCell
        customCell.data      = classModel.students![indexPath.row]
        customCell.indexPath = indexPath
        customCell.loadContent()

        return customCell
    }

    func tableView(tableView: UITableView, didSelectRowAtIndexPath indexPath: NSIndexPath) {

        tableView.selectedEventWithIndexPath(indexPath)
    }

    func tableView(tableView: UITableView, viewForHeaderInSection section: Int) -> UIView? {

        let headerView       = tableView.dequeueReusableHeaderFooterViewWithIdentifier("ClassHeaderView") as! ClassHeaderView
        headerView.section   = section
        headerView.data      = classes[section]
        headerView.tableView = tableView
        headerView.loadContent()

        if tmpHeadView == nil && section == 0 {

            tmpHeadView = headerView
        }

        return headerView
    }
}
时间: 2024-10-24 07:38:04

Swift - UITableView展开缩放动画的相关文章

iOS项目开发实战——制作视图的缩放动画

视图的大小应该是随时可控的.今天我们就来实现对一个View的缩放动画.该动画的实现与位移动画,透明度动画稍有不同. 详细实现例如以下: import UIKit class ScaleViewController: UIViewController { @IBOutlet weak var greenSquare: UIView! override func viewDidLoad() { super.viewDidLoad() // Do any additional setup after

android动画的透明度渐变、旋转动画、缩放动画、评议动画

这是我在学习android的时候做的一个小小的东西可以实现图片的旋转.平移.缩放.透明度的渐变 首先我们要创建一个android的项目 在自己的drawable-mdpi中添加自己的图片 然后在res目录中,创建一个名称是anim(动画)的目录,并且在该目录中实现图片的操作 首先是anim_alpha.xml定义一个实现透明渐变的动画该动画实现的是完全不透明-->完全透明---->完全不透明 <pre name="code" class="html"

ArcGIS api for javascript——地图配置-定制缩放动画

描述 本例展示了当用户放大或缩小地图时如何定义地图的动画.zoomDuration和zoomRate是Dojo动画属性,他们确定了动画的duration和帧刷新的rate .这些属性单位是毫秒,zoomDuration默认值是250,zoomRate默认值是25. 在本例中,可以通过调整这些属性为数据和应用获得更好的样子.例如,如果地图需要很长的时间加载,可以增加zoomDuration以便用户在等待加载缩放地图时看到空的或扭曲的屏幕时间较短.反之,如果地图加载很快,可以降低zoomDurati

ArcGIS api for javascript——地图配置-定制缩放动画,定制缩放框

描述 本例展示了当用户放大或缩小地图时如何定义地图的动画.zoomDuration和zoomRate是Dojo动画属性,他们确定了动画的duration和帧刷新的rate .这些属性单位是毫秒,zoomDuration默认值是250,zoomRate默认值是25. 在本例中,可以通过调整这些属性为数据和应用获得更好的样子.例如,如果地图需要很长的时间加载,可以增加zoomDuration以便用户在等待加载缩放地图时看到空的或扭曲的屏幕时间较短.反之,如果地图加载很快,可以降低zoomDurati

UI基础--动画(缩放动画, 渐变动画, 左右振动, 移动动画, 组合动画)(封装好)

创建一个CAAnimation的类别 CAAnimation+HCAnimation .h #import <QuartzCore/QuartzCore.h> #import <UIKit/UIKit.h> typedef NS_ENUM(NSInteger, Axis) { AxisX = 0, ///< x轴 AxisY, ///< y轴 AxisZ ///< z轴 }; typedef NS_ENUM(NSInteger, ShakeDerection) {

android缩放动画的两种实现方法

在android开发.我们会常常使用到缩放动画,普通情况下缩放动画有两种实现方式.一种是直接通过java代码去实现,第二种是通过配置文件实现动画,以下是两种动画的基本是用法: Java代码实现: //创建缩放动画对象 Animation animation = new ScaleAnimation(0, 1.0f, 0f, 1.0f); animation.setDuration(1500);//动画时间 animation.setRepeatCount(3);//动画的反复次数 animati

CSS3背景闪烁和图片缩放动画效果

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <title>CSS3感应鼠标的背景闪烁和图片缩放动态效

UITableView添加波浪动画效果

- (void)reloadDataAnimateWithWave:(WaveAnimation)animation; { [self setContentOffset:self.contentOffset animated:NO]; [UIView animateWithDuration:.2 animations:^{ [self setHidden:YES]; [self reloadData]; } completion:^(BOOL finished) { //Do something

Android缩放动画

Android缩放动画 核心方法 public void startAnimation(Animation animation) 运行动画,參数能够是各种动画的对象,Animation的多态.也能够是组合动画,后面会有. 4个參数构造方法 /** * Constructor to use when building a ScaleAnimation from code * * @param fromX Horizontal scaling factor to apply at the start