9--按钮的基本使用
基本按钮 UIView 属性
Frame // 比较常用,既能改变 button 的 X Y 值也能改变长度和宽度,以父控件为标准排序
bounds // 也可以表示 X Y 位置和尺寸 但是以自己控件左上角为原点,也就是 X Y 永远都为0
center 中心位置 以父控件为标准
tag // 整形属性标记
transform // 形变属性 实现缩放 旋转 平移功能.
1. 使用 Frame 实现图片的平移
功能: 点击方向按钮 实现图片的平移
#import "ViewController.h" @interface ViewController () - (IBAction)up; - (IBAction)down; - (IBAction)left; - (IBAction)right; - (IBAction)big; - (IBAction)small; @property (nonatomic, weak) IBOutlet UIButton *head; @end @implementation ViewController #pragma mark 向上 - (IBAction)up { CGRect tempFrame = self.head.frame; tempFrame.origin.y -=10; self.head.frame = tempFrame; } #pragma mark 向下 - (IBAction)down { CGRect tempFrame = self.head.frame; tempFrame.origin.y +=10; self.head.frame = tempFrame; } #pragma mark 向左 - (IBAction)left { CGRect tempFrame = self.head.frame; tempFrame.origin.x -=10; self.head.frame = tempFrame; } #pragma mark 向右 - (IBAction)right { CGRect tempFrame = self.head.frame; tempFrame.origin.x +=10; self.head.frame = tempFrame; } #pragma mark 放大 - (IBAction)big { //1. 取出原来的frame属性 CGRect tempFrame = self.head.frame; //2.临时改变 frame 的 height和 width 的属性值 tempFrame.size.height +=10; tempFrame.size.width +=10; //3. 将临时更改后的属性值赋值回去覆盖之前的值 self.head.frame = tempFrame; } #pragma mark 缩小 - (IBAction)small { CGRect tempFrame = self.head.frame; tempFrame.size.height -=10; tempFrame.size.width -=10; self.head.frame = tempFrame; } @end
上述代码每一个按钮都需要写一个新的方法显得代码比较累赘 所以可以使用一个方法 move 来实现四个方向的平移,使用tag标记
1 // 2 // ViewController.m 3 // 02-按钮的基本使用(第二种实现方法) 4 // 5 // Created by Stephen on 16/4/9. 6 // Copyright © 2016年 Stephen. All rights reserved. 7 // 8 9 #import "ViewController.h" 10 11 @interface ViewController () 12 //申明一个 move 方法 通过一个方法来实现四个按钮的功能 13 - (IBAction)move:(UIButton *)btn; 14 - (IBAction)zoon:(UIButton *)btn; 15 16 @property (nonatomic , weak ) IBOutlet UIButton *head; 17 18 @end 19 20 @implementation ViewController 21 22 #pragma mark 实现方向移动 23 - (IBAction)move:(UIButton *)btn 24 { 25 26 //1.取出原来的属性 27 CGRect tempFrame = self.head.frame; 28 29 //2.修改临时属性 30 31 CGFloat delta = 10; 32 switch (btn.tag) { 33 case 10: 34 tempFrame.origin.y -= delta; 35 break; 36 37 case 20: 38 tempFrame.origin.y += delta; 39 break; 40 41 case 30: 42 tempFrame.origin.x -= delta; 43 break; 44 45 case 40: 46 tempFrame.origin.x += delta; 47 break; 48 49 } 50 51 //3. 重新赋值 52 53 self.head.frame = tempFrame; 54 55 56 } 57 58 #pragma mark 实现大小缩放 59 - (IBAction)zoon:(UIButton *)btn 60 { 61 CGRect tempFrame = self.head.frame; 62 63 CGFloat delta = 10; 64 switch (btn.tag) { 65 case 50: 66 tempFrame.size.width += delta; 67 tempFrame.size.height += delta; 68 break; 69 70 case 60: 71 tempFrame.size.width -= delta; 72 tempFrame.size.height -= delta; 73 break; 74 } 75 76 77 self.head.frame = tempFrame; 78 } 79 80 81 @end
同样的使用另外的一个属性进行实现同样的功能: 使用 bounds 属性
// // ViewController.m // 03-按钮的基本使用(bounds 重建) // // Created by Stephen on 16/4/10. // Copyright © 2016年 Stephen. All rights reserved. // #import "ViewController.h" @interface ViewController () - (IBAction)move:(UIButton *)btn; - (IBAction)zoon:(UIButton *)btn; @property (nonatomic , weak) IBOutlet UIButton *head; @end @implementation ViewController - (IBAction)move:(UIButton *)btn { //1. 获取属性值 CGPoint tempCenter = self.head.center; //2. 更改临时属性值 switch (btn.tag) { case 10: tempCenter.y -= 10; break; case 20: tempCenter.y +=10; break; case 30: tempCenter.x -=10; break; case 40: tempCenter.x += 10; break; } //3. 重新覆盖值 self.head.center = tempCenter; } - (IBAction)zoon:(UIButton *)btn { CGRect tempBounds = self.head.bounds; switch (btn.tag) { case 50: tempBounds.size.height += 10; tempBounds.size.width +=10; break; case 60: tempBounds.size.height -= 10; tempBounds.size.width -=10; break; } self.head.bounds = tempBounds; } @end
总结:
1.IBAction:
1> 能保证方法可以连线
2> 相当于void
2.IBOutlet:
1> 能保证属性可以连线
3.常见错误
setValue:forUndefinedKey:]: this class is not key value coding
错误原因是:连线出问题了
4.Xcode5开始的一些建议
把用于连线的一些方法和属性声明在.m文件的类扩展中
5.frame\center\bounds
1> frame:能修改位置和尺寸
2> center:能修改位置
3> bounds:能修改尺寸(x\y一般都是0)
附上一个: 加入了动画效果的小功能
// // ViewController.m // 03-按钮的基本使用(bounds 重建) // // Created by Stephen on 16/4/10. // Copyright © 2016年 Stephen. All rights reserved. // #import "ViewController.h" @interface ViewController () - (IBAction)move:(UIButton *)btn; - (IBAction)zoon:(UIButton *)btn; @property (nonatomic , weak) IBOutlet UIButton *head; @end @implementation ViewController - (IBAction)move:(UIButton *)btn { //开始动画 [UIView beginAnimations:nil context:nil]; //设置动画时间 默认为1/4秒 [UIView setAnimationDuration:3.0]; //1. 获取属性值 CGPoint tempCenter = self.head.center; //2. 更改临时属性值 CGFloat delta = 50; switch (btn.tag) { case 10: tempCenter.y -= delta; break; case 20: tempCenter.y +=delta; break; case 30: tempCenter.x -=delta; break; case 40: tempCenter.x += delta; break; } //3. 重新覆盖值 self.head.center = tempCenter; //提醒系统结束动画 [UIView commitAnimations]; } - (IBAction)zoon:(UIButton *)btn { [UIView beginAnimations:nil context:nil]; [UIView setAnimationDuration:3.0]; CGRect tempBounds = self.head.bounds; CGFloat number = 30; switch (btn.tag) { case 50: tempBounds.size.height += number; tempBounds.size.width +=number; break; case 60: tempBounds.size.height -= number; tempBounds.size.width -=number; break; } self.head.bounds = tempBounds; [UIView commitAnimations]; } @end