使用Facebook Pop为视图仿射变换设置动画

时间:2015-01-27 00:29:58

标签: ios swift facebook-pop

我有以下代码,会以弹簧方式从底部为UITableViewCell动画显示:

override func viewDidAppear(animated: Bool) {
    super.viewDidAppear(animated)
    self.tableView.reloadData()

    let cellsNum = self.tableView.visibleCells() as NSArray

    // Hide the tableView and move the cells to below the tableView
    self.tableView.alpha = 0.0
    for cell in cellsNum as [UITableViewCell] {
        cell.transform = CGAffineTransformMakeTranslation(0, self.tableView.bounds.size.height)
        println("\(NSStringFromCGAffineTransform(cell.transform))")
        //cell.layer.transform = CATransform3DRotate(CATransform3DIdentity, CGFloat(90.0) * CGFloat(M_PI) / CGFloat(180.0), 1.0, 0.0, 0.0)
    }

    // Show the tableView and animate the cells
    self.tableView.alpha = 1.0
    for cell in cellsNum as [UITableViewCell] {
        UIView.animateWithDuration(1.2, delay: 0.05 * Double(cellsNum.indexOfObject(cell)), usingSpringWithDamping: 0.77, initialSpringVelocity: 0, options: nil, animations: { () -> Void in
            cell.transform = CGAffineTransformMakeTranslation(0, 0)
            //cell.layer.transform = CATransform3DRotate(CATransform3DIdentity, 0, 1.0, 0.0, 0.0)
            }, completion: nil);
    }
}

我如何在Facebook Pop中执行此操作?我查看了源代码,但最接近的是kPopLayerTranslationXY但是下面的代码没有工作:

for cell in cellsNum as [UITableViewCell] {
        let trans = POPSpringAnimation(propertyNamed: kPOPLayerTranslationXY)
        trans.toValue = NSValue(CGPoint: CGPointMake(0, 0))
        trans.fromValue = NSValue(CGPoint: CGPointMake(0, self.tableView.bounds.size.height))
        trans.springBounciness = 10
        trans.springSpeed = 5
        cell.pop_addAnimation(trans, forKey: "Translation")
    }

可能定义自定义动画属性?

1 个答案:

答案 0 :(得分:1)

您正在设置图层属性的动画,因此您应该将动画添加到单元格的图层,而不是单元格。

cell.layer.pop_addAnimation(trans, forKey: "Translation")

另外,由于您只是动画y,您可以使用kPOPLayerTranslationY并将toValuefromValue设置为浮动。