在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 參數」的形變能夠基於控件上一次的狀態進行疊加形變,如先旋轉再平移。
用代碼在 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 }