CGTransform简单使用,包括平移,旋转,缩放

旋转:

-(void)Rotate:(UIButton *)rotate

{

//位移(不累加)

//self.headImageView.transform=CGAffineTransformMakeTranslation(50, 200);

//缩放

//self.headImageView.transform=CGAffineTransformMakeScale(1.2, 10);

//在原有的基础上位移(是累加的)

//self.headImageView.transform=CGAffineTransformTranslate(self.headImageView.transform, 50, 50);

//在原有的基础上进行缩放

//self.headImageView.transform=CGAffineTransformScale(self.headImageView.transform, 1.5, 1.6);

//在原有的基础上进行旋转

if (rotate.tag) {

//旋转角度为1/pi,逆时针

self.headImageView.transform=CGAffineTransformRotate(self.headImageView.transform, -M_1_PI);

}

else

{

//旋转的角度为pi/2,顺时针

self.headImageView.transform=CGAffineTransformRotate(self.headImageView.transform, M_PI_2);

}

}

缩放:

-(void)Zoom:(UIButton *)btn

{

//使用bounds,以中心点位原点进行缩放

CGRect bounds = self.headImageView.bounds;

if (btn.tag) {

bounds.size.height+=30;

bounds.size.width+=30;

}

else

{

bounds.size.height-=50;

bounds.size.width-=50;

}

//设置首尾动画

[UIView beginAnimations:nil context:nil];

self.headImageView.bounds=bounds;

[UIView setAnimationDuration:2.0];

[UIView commitAnimations];

}

平移:

//控制方向的多个按钮调用同一个方法

-(void)Click:(UIButton *)button

{

//练习使用frame属性

//CGRect frame=self.headImageView.frame;

/**注意,这里如果控制位置的两个属性frame和center同时使用的话,会出现很好玩的效果,注意分析*/

//练习使用center属性

CGPoint center=self.headImageView.center;

switch (button.tag) {

case ktopbtntag:

center.y-=30;

break;

case kdownbtntag:

center.y+=30;

break;

case kleftbtntag:

//发现一个bug,之前的问题是因为少写了break,造成了它们的顺序执行,sorry

//center.x=center.x-30;

center.x-=50;

break;

case krightbtntag:

center.x+=50;

break;

}

//  self.headImageView.frame=frame;

//首尾式设置动画效果

[UIView beginAnimations:nil context:nil];

self.headImageView.center=center;

//设置时间

[UIView setAnimationDuration:2.0];

[UIView commitAnimations];

NSLog(@"移动!");

}

你可能感兴趣的:(CGTransform简单使用,包括平移,旋转,缩放)