iOS開發基礎篇-transform屬性

1、 transform 屬性

  在OC中,經過 transform 屬性能夠修改對象的平移、縮放比例和旋轉角度。html

  1)建立「基於控件初始位置」的形變ide

   CGAffineTransformMakeRotation ——旋轉spa

   CGAffineTransformMakeTranslation ——平移code

   CGAffineTransformMakeScale ——縮放orm

  2)建立「基於 transform 參數」的形變htm

   CGAffineTransformTranslate 對象

   CGAffineTransformScale blog

   CGAffineTransformRotate 事件

補充:在OC中,全部跟角度相關的數值,都爲弧度制 180度 = M_PI , 45度 = M_PI_4 。開發

  正數表示順時針旋轉,負數表示逆時針旋轉。

  「基於 transform 參數」的形變能夠基於控件上一次的狀態進行疊加形變,如先旋轉再平移。 

 

2、示例

  用代碼在 viewDidLoad 中添加控制旋轉的按鈕:

 1     //向左旋轉按鈕
 2     UIButton *leftrotatebtn = [UIButton buttonWithType:UIButtonTypeCustom];
 3     leftrotatebtn.frame = CGRectMake(125, 450, 80, 40);
 4     [leftrotatebtn setTitle:@"向左旋轉" forState:UIControlStateNormal];
 5     [leftrotatebtn setTitleColor:[UIColor blueColor] forState:UIControlStateNormal];
 6     [leftrotatebtn setTag:1];
 7     [self.view addSubview:leftrotatebtn];
 8     //添加按鈕的單擊事件
 9     [leftrotatebtn addTarget:self action:@selector(rotate:) forControlEvents:UIControlEventTouchUpInside];
10     
11     //向右旋轉按鈕
12     UIButton *rightrotatebtn = [UIButton buttonWithType:UIButtonTypeCustom];
13     rightrotatebtn.frame = CGRectMake(125, 500, 80, 40);
14     [rightrotatebtn setTitle:@"向右旋轉" forState:UIControlStateNormal];
15     [rightrotatebtn setTitleColor:[UIColor blueColor] forState:UIControlStateNormal];
16     [rightrotatebtn setTag:0];
17     [self.view addSubview:rightrotatebtn];
18     //添加按鈕的單擊事件
19     [rightrotatebtn addTarget:self action:@selector(rotate:) forControlEvents:UIControlEventTouchUpInside];

   viewDidLoad 是視圖加載完成後調用的方法,一般在此方法中執行視圖控制器的初始化工做。

  添加旋轉按鈕響應事件:

 1 - (void)rotate:(id)sender{
 2     UIButton *button = (UIButton *)sender;
 3     if (button.tag) {
 4         //self.headImageView.transform = CGAffineTransformMakeRotation(-M_PI_4);
 5         //逆時針旋轉
 6         self.headImageView.transform = CGAffineTransformRotate(self.headImageView.transform, -M_1_PI);
 7     } else {
 8         //順時針旋轉
 9         self.headImageView.transform = CGAffineTransformRotate(self.headImageView.transform, M_PI_4);
10     }
11 }

 

參考博客:iOS開發UI篇—transframe屬性(形變)

示例代碼連接:http://pan.baidu.com/s/1skkbcw1

相關文章
相關標籤/搜索