您的位置:首页 > 产品设计 > UI/UE

iOS学习之——UIButton

2016-05-19 14:08 351 查看
UIButton详解:

//这里创建一个圆角矩形的按钮

UIButton *button1 = [UIButton buttonWithType:UIButtonTypeRoundedRect];

// 能够定义的button类型有以下6种,

// typedef enum {

// UIButtonTypeCustom = 0, 自定义风格

// UIButtonTypeRoundedRect, 圆角矩形

// UIButtonTypeDetailDisclosure, 蓝色小箭头按钮,主要做详细说明用

// UIButtonTypeInfoLight, 亮色感叹号

// UIButtonTypeInfoDark, 暗色感叹号

// UIButtonTypeContactAdd, 十字加号按钮

// } UIButtonType;

//给定button在view上的位置
button1.frame = CGRectMake(20, 20, 280, 20);
[button setFrame:CGRectMake(20,20,50,50)];
//button背景色
button1.backgroundColor = [UIColor clearColor];
[button setBackgroundColor:[UIColor blueColor]];

//设置button填充图片和背景图片
//[button1 setImage:[UIImage imageNamed:@"btng.png"] forState:UIControlStateNormal];
[button setBackgroundImage:[UIImageimageNamed:@"btng.png"]forState:UIControlStateNormal];

//设置button标题和标题颜色
[button1 setTitle:@"点击" forState:UIControlStateNormal];
[buttonsetTitleColor:[UIColorredColor]forState:UIControlStateNormal];


/* forState: 这个参数的作用是定义按钮的文字或图片在何种状态下才会显现*/

//以下是几种状态

// enum {

// UIControlStateNormal = 0, 常规状态显现

// UIControlStateHighlighted = 1 << 0, 高亮状态显现

// UIControlStateDisabled = 1 << 1, 禁用的状态才会显现

// UIControlStateSelected = 1 << 2, 选中状态

// UIControlStateApplication = 0x00FF0000, 当应用程序标志时

// UIControlStateReserved = 0xFF000000 为内部框架预留,可以不管他

// };

/*

* 默认情况下,当按钮高亮的情况下,图像的颜色会被画深一点,如果这下面的这个属性设置为no,

* 那么可以去掉这个功能

*/

button1.adjustsImageWhenHighlighted = NO;


/跟上面的情况一样,默认情况下,当按钮禁用的时候,图像会被画得深一点,设置NO可以取消设置/

button1.adjustsImageWhenDisabled = NO;


/* 下面的这个属性设置为yes的状态下,按钮按下会发光*/

button1.showsTouchWhenHighlighted = YES;


/* 给button添加事件,事件有很多种

按下按钮,并且手指离开屏幕的时候触发这个事件,跟web中的click事件一样。

触发了这个事件以后,执行butClick:这个方法,addTarget:self 的意思是说,这个方法在本类中

也可以传入其他类的指针*/

//添加事件
[button1 addTarget:self action:@selector(butClick:) forControlEvents:UIControlEventTouchUpInside];
//删除事件
[button1 removeTarget:nil action:nil forControlEvents:UIControlEventTouchUpInside];

//显示控件
[self.view addSubview:button1];


设置按钮内部图片间距和标题间距

UIEdgeInsets insets; // 设置按钮内部图片间距
insets.top = insets.bottom = insets.right = insets.left = 10;
bt.contentEdgeInsets = insets;
bt.titleEdgeInsets = insets; // 标题间距
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: