【发布时间】:2012-10-14 10:00:19
【问题描述】:
您好,我有一张图片,我想上下移动(上移 10 像素和下移 10 像素),以便我的图片看起来像是在悬停。我怎么能用简单的动画做到这一点非常感谢!!!
【问题讨论】:
标签: ios animation uiimageview core-animation ios6
您好,我有一张图片,我想上下移动(上移 10 像素和下移 10 像素),以便我的图片看起来像是在悬停。我怎么能用简单的动画做到这一点非常感谢!!!
【问题讨论】:
标签: ios animation uiimageview core-animation ios6
您可以使用 Core Animation 为视图层的位置设置动画。如果您将动画配置为additive,您就不必费心计算新的绝对位置,只需计算变化(相对位置)。
CABasicAnimation *hover = [CABasicAnimation animationWithKeyPath:@"position"];
hover.additive = YES; // fromValue and toValue will be relative instead of absolute values
hover.fromValue = [NSValue valueWithCGPoint:CGPointZero];
hover.toValue = [NSValue valueWithCGPoint:CGPointMake(0.0, -10.0)]; // y increases downwards on iOS
hover.autoreverses = YES; // Animate back to normal afterwards
hover.duration = 0.2; // The duration for one part of the animation (0.2 up and 0.2 down)
hover.repeatCount = INFINITY; // The number of times the animation should repeat
[myView.layer addAnimation:hover forKey:@"myHoverAnimation"];
由于这是使用 Core Animation,您需要将 QuartzCore.framework 和 #import <QuartzCore/QuartzCore.h> 添加到您的代码中。
【讨论】:
对于 Swift 3、Swift 4 和 Swift 5:
let hover = CABasicAnimation(keyPath: "position")
hover.isAdditive = true
hover.fromValue = NSValue(cgPoint: CGPoint.zero)
hover.toValue = NSValue(cgPoint: CGPoint(x: 0.0, y: 100.0))
hover.autoreverses = true
hover.duration = 2
hover.repeatCount = Float.infinity
myView.layer.add(hover, forKey: "myHoverAnimation")
【讨论】:
试试这个:
CGRect frm_up = imageView.frame;
frm_up.origin.y -= 10;
[UIView animateWithDuration:0.5
delay:0.0
options:UIViewAnimationOptionAutoreverse | UIViewAnimationOptionRepeats
animations:^{
imageView.frame = frm_up;
}
completion:NULL
];
【讨论】:
options 参数)。我确定你错过了什么。
对于这样的任务,最好将图像放置在UIView 的子层中,然后为该子层帧设置动画。本教程可以给你一些想法:http://www.raywenderlich.com/2502/introduction-to-calayers-tutorial
【讨论】: