zoukankan      html  css  js  c++  java
  • UITableViewCell实现3D缩放动画

    gif效果图:

    代码部分:

    import UIKit
    
    class TableViewController: UITableViewController {
    
        override func viewDidLoad() {
            super.viewDidLoad()
            
            self.tableView.registerClass(UITableViewCell.classForCoder(), forCellReuseIdentifier: "Cell")
            self.tableView.rowHeight = 100
    
        }
    
        // MARK: - Table view data source
    
        override func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
            // #warning Incomplete implementation, return the number of rows
            return 20
        }
    
        
        override func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {
            let cell = tableView.dequeueReusableCellWithIdentifier("Cell", forIndexPath: indexPath)
    
            cell.textLabel?.text = "TestValue"
            
            // 设置随机颜色
            let red = CGFloat(CGFloat(random()) / CGFloat(RAND_MAX))
            let blue = CGFloat(CGFloat(random()) / CGFloat(RAND_MAX))
            let green = CGFloat(CGFloat(random()) / CGFloat(RAND_MAX))
            cell.backgroundColor = UIColor(red: red, green: green, blue: blue, alpha: 1.0)
    
            return cell
        }
        
        // 在Cell即将显示的时候执行动画
        override func tableView(tableView: UITableView, willDisplayCell cell: UITableViewCell, forRowAtIndexPath indexPath: NSIndexPath) {
            cell.layer.transform = CATransform3DMakeScale(0.1, 0.1, 1)
            UIView.animateWithDuration(0.5) {
                cell.layer.transform = CATransform3DMakeScale(1, 1, 1)
            }
        }
        
    //    放在这个显示完毕之后执行就看不到动画效果了(都显示完了, 还看个毛动画)
    //    override func tableView(tableView: UITableView, didEndDisplayingCell cell: UITableViewCell, forRowAtIndexPath indexPath: NSIndexPath) {
    //        cell.layer.transform = CATransform3DMakeScale(0.1, 0.1, 1)
    //        UIView.animateWithDuration(0.5) {
    //            cell.layer.transform = CATransform3DMakeScale(1, 1, 1)
    //        }
    //    }
    
    }
  • 相关阅读:
    4.运算符&if条件控制
    欢迎进入软件构建的世界
    Linux是什么
    计算机概论
    Java基础11集合(2)
    基础06-存储过程和函数,流程控制结构,变量
    基础05-常见约束,tcl事物控制语言,视图,标识列
    基础04-联合查询,dml语言,ddl语言
    基础03-子查询,分页查询
    基础00-随笔里的数据来源(库,表数据)
  • 原文地址:https://www.cnblogs.com/Rinpe/p/5221969.html
Copyright © 2011-2022 走看看