0

iOSで回転ノブボタンを作成しています。グラフィックデザイナーからpngレイヤーが提供されたので、画像コンテキストを使用してレイヤーをブレンドできるようにしています。

回転すると、一部のレイヤーのみが回転します。私の目標は、これらのローテーションをアニメートすることです。

現在、使用しています

- (BOOL)beginTrackingWithTouch:(UITouch *)touch withEvent:(UIEvent *)event
- (BOOL)continueTrackingWithTouch:(UITouch *)touch withEvent:(UIEvent *)event
- (BOOL)endTrackingWithTouch:(UITouch *)touch withEvent:(UIEvent *)event

これらの方法では、画像の必要な回転を計算して描画します。

これは正常に機能します。私が持っているハードルは

- (BOOL)endTrackingWithTouch:(UITouch *)touch withEvent:(UIEvent *)event

「スナップ」アニメーションを実行したい。これどうやってするの?この場合、ブレンディングのためにアフィン変換をどのように使用できるかわかりません。次の方法は、イメージを作成する方法です。

- (UIImage *)knobImageWithRadians:(float)radians
{
UIImage *i05 = [UIImage imageNamed:@"05 - Metal Over Empty Space - ROTATE ME.png"];
UIImage *i04 = [UIImage imageNamed:@"04 - Inner Knob.png"];
UIImage *i03 = [UIImage imageNamed:@"03 - Over Knob Metal - (OVERLAY BLEND)  - ROTATE ME.png"];
UIImage *i02 = [UIImage imageNamed:@"02 - Numbers and Dashes - ROTATE ME.png"];
UIImage *i01 = [UIImage imageNamed:@"01 - Reflective Overlay - (COLOR DODGE BLEND).png"];

CGSize size = i11.size;     

UIGraphicsBeginImageContext(size);
CGContextRef bitmap = UIGraphicsGetCurrentContext();
CGContextTranslateCTM(bitmap, size.width/2, size.height/2);


[i04 drawInRect:CGRectMake(-i04.size.width/2, -i04.size.height/2, i04.size.width, i04.size.height) blendMode:kCGBlendModeNormal alpha:1.0];

CGContextRotateCTM(bitmap, radians);
[i03 drawInRect:CGRectMake(-i03.size.width/2, -i03.size.height/2, i03.size.width, i03.size.height) blendMode:kCGBlendModeOverlay alpha:1.0];

[i02 drawInRect:CGRectMake(-i02.size.width/2, -i02.size.height/2, i02.size.width, i02.size.height) blendMode:kCGBlendModeNormal alpha:1.0];
CGContextRotateCTM(bitmap, -radians);

[i01 drawInRect:CGRectMake(-i01.size.width/2, -i01.size.height/2, i01.size.width, i01.size.height) blendMode:kCGBlendModeColorDodge alpha:1.0];

UIImage* blendedImage = UIGraphicsGetImageFromCurrentImageContext();

UIGraphicsEndImageContext();

return blendedImage;
}

アップデート:

今のところ、アニメーションなしで直接スナップさせています。

4

1 に答える 1

2

定期的に新しい角度で画像を再描画して、これを自分でアニメーション化する必要があります。または、合成ではなくソースのみを使用するビジュアルを考え出すことで、各画像を別々のレイヤーに配置できます。

于 2012-07-14T20:37:28.007 に答える