Animating a bezier curve point

后端 未结 1 1182
囚心锁ツ
囚心锁ツ 2021-01-03 16:03

I\'m trying to animate a bezier curve I made with Paintcode (great app, btw) and am drawing in a custom UIView in the \"drawRect\" method.

The drawing works fine but

相关标签:
1条回答
  • 2021-01-03 16:13

    Quick Edit Just seen your layer code. You are mixing up several different concepts. Like drawRect, CAShapeLayer, old animation code etc...

    By doing the method below you should be able to get this working.

    You can't do this :( you can't animate the contents of drawRect (i.e. you can't get it to draw multiple times over the course of the animation).

    You may be able to use a timer or something and create your own animation type code. (i.e. create a timer that fires 30 times a second and runs a function that calculates where you are in the animation and updates the values you want to change and calls [self setNeedsDisplay]; to trigger the draw rect method.

    Other than that there isn't much you can do.

    ANOTHER EDIT

    Just adding another option here. Doing this with a CAShapeLayer might be very poor performance. You might be best using a UIImageView with a series of UIImages.

    There are built in properties, animationImages, animationDuration, etc... on UIImageView.

    POSSIBLE SOLUTION

    The path property of CAShapeLayer is animatable and so you could possible use this.

    Something like...

    // set up properties for path
    @property (nonatomic, assign) CGPath startPath;
    @property (nonatomic, assign) CGPath endPath;
    @property (nonatomic, strong) CAShapeLayer *pathLayer;
    
    // create the startPath
    UIBezierPath *path = [UIBezierPath //create your path using the paint code code
    self.startPath = path.CGPath;
    
    // create the end path
    path = [UIBezierPath //create your path using the paint code code
    self.endPath = path.CGPath;
    
    // create the shapee layer
    self.pathLayer = [CAShapeLayer layer];
    self.pathLayer.path = self.startPath;
    //also set line width, colour, shadows, etc...
    
    [self.view.layer addSubLayer:self.pathLayer];
    

    Then you should be able to animate the path like this...

    - (void)animatePath
    {
        [UIView animateWithDuration:2.0
            animations^() {
                self.pathlayer.path = self.endPath;
        }];
    }
    

    There are lots of notes in the docs about CAShapeLayer and animating the path property.

    This should work though.

    Also, get rid of the old animation code. It has been gone since iOS4.3 you should be using the updated block animations.

    0 讨论(0)
提交回复
热议问题