How do I achieve continuous rotation of an NSImage inside NSImageView?

前端 未结 2 790
暖寄归人
暖寄归人 2021-02-01 10:17

FUTURE VIEWERS:

I have managed to finish this rotation animation and code with description can be found on tho question. NSImage rotation in NSView is not working

<
2条回答
  •  星月不相逢
    2021-02-01 10:51

    Getting an object to rotate more than 180 degrees is actually a little bit tricky. The problem is that you specify a transformation matrix for the ending rotation, and the system decides to rotate in the other direction.

    What I've done is to create a CABasicAnimation of less than 180 degrees, set up to be additive , and with a repeat count. Each step in the animation animates the object more.

    The following code is taken from an iOS application, but the technique is identical in Mac OS.

      CABasicAnimation* rotate =  [CABasicAnimation animationWithKeyPath: @"transform.rotation.z"];
      rotate.removedOnCompletion = FALSE;
      rotate.fillMode = kCAFillModeForwards;
    
      //Do a series of 5 quarter turns for a total of a 1.25 turns
      //(2PI is a full turn, so pi/2 is a quarter turn)
      [rotate setToValue: [NSNumber numberWithFloat: -M_PI / 2]];
      rotate.repeatCount = 11;
    
      rotate.duration = duration/2;
      rotate.beginTime = start;
      rotate.cumulative = TRUE;
      rotate.timingFunction = [CAMediaTimingFunction functionWithName:kCAMediaTimingFunctionLinear];
    

    CAAnimation objects operate on layers, so for Mac OS, you'll need to set the "wants layer" property in interface builder, and then add the animation to your view's layer.

    To make your view rotate forever, you'd set repeat count to some very large number like 1e100.

    Once you've created your animation, you'd add it to your view's layer with code something like this:

    [myView.layer addAnimation: rotate forKey: @"rotateAnimation"];
    

    That's about all there is to it.

提交回复
热议问题