UIView animation along a round path?

ε祈祈猫儿з 提交于 2019-12-29 04:59:11

问题


I need to make my little guy (in a UIIamgeView) jump forward and it has to look natural. I want to know is there a way to do it with CoreAnimation (beginAnimation/commitAnimation)?

I could do it by setting a point in between in the air but the movement looks not natural :P


回答1:


Reading Brad Larson's post, I ended up with a nice function to make my image follow a circle.

You need to import QuartzCore framework: #import

Here is the code:

// Set up path movement
CAKeyframeAnimation *pathAnimation = [CAKeyframeAnimation animationWithKeyPath:@"position"];
pathAnimation.calculationMode = kCAAnimationPaced;
pathAnimation.fillMode = kCAFillModeForwards;
pathAnimation.removedOnCompletion = NO;
pathAnimation.repeatCount = INFINITY;
//pathAnimation.rotationMode = @"auto";
pathAnimation.timingFunction = [CAMediaTimingFunction functionWithName:kCAMediaTimingFunctionLinear];
pathAnimation.duration = 5.0;

// Create a circle path
CGMutablePathRef curvedPath = CGPathCreateMutable();
CGRect circleContainer = CGRectMake(0, 0, 400, 400); // create a circle from this square, it could be the frame of an UIView
CGPathAddEllipseInRect(curvedPath, NULL, circleContainer);

pathAnimation.path = curvedPath;
CGPathRelease(curvedPath);

[self.imageView.layer addAnimation:pathAnimation forKey:@"myCircleAnimation"];



回答2:


Create a CAKeyframeAnimation and assign a CGPath to its path property.




回答3:


To follow up on Ole's answer, my answer to this question provides code to perform such a curved animation using a CAKeyframeAnimation.



来源:https://stackoverflow.com/questions/2555614/uiview-animation-along-a-round-path

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!