博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
iOS开发基础篇-transform属性
阅读量:5194 次
发布时间:2019-06-13

本文共 2085 字,大约阅读时间需要 6 分钟。

一、 transform 属性

  在OC中,通过 transform 属性可以修改对象的平移、缩放比例和旋转角度。

  1)创建“基于控件初始位置”的形变

   CGAffineTransformMakeRotation ——旋转

   CGAffineTransformMakeTranslation ——平移

   CGAffineTransformMakeScale ——缩放

  2)创建“基于 transform 参数”的形变

   CGAffineTransformTranslate 

   CGAffineTransformScale 

   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 }

 

参考博客:

示例代码链接:

转载于:https://www.cnblogs.com/wjq-Law/p/5100108.html

你可能感兴趣的文章
[Angular Router] Lazy loading Module with Auxiliary router
查看>>
[CSS] Draw Simple Icons with CSS
查看>>
[Recompose] Transform Props using Recompose --mapProps
查看>>
[Cycle.js] The Cycle.js principle: separating logic from effects
查看>>
[AngularJS] Accessible Button Events
查看>>
[CSS] Use Generated Content to Augment Information
查看>>
MySQL中group_concat函数,用符号连接查询分组里字段值
查看>>
图解HTTP简单笔记【上】
查看>>
Vmware 注册服务 开机自启
查看>>
JS跨域
查看>>
sqlserver数据库差异比较
查看>>
二维数组,多维数组
查看>>
How To Synchronize Core Data with a Web Service – Part 2
查看>>
ui自动化--鼠标操作ActionChains
查看>>
学习es6
查看>>
native2ascii -reverse -encoding UTF-8 validation_msg.properties > validation_msg_src.properties
查看>>
java-4
查看>>
Windows下比较小巧的c/c++ ide
查看>>
python中的模块
查看>>
node_oracle连接
查看>>