注册 登录  
 加关注
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

尐鬼じ☆ve伱

和你在一起的日子

 
 
 

日志

 
 

UIButton 按钮控件-IOS开发 (转)  

2012-06-20 16:08:54|  分类: ios 自定义控件 |  标签: |举报 |字号 订阅

  下载LOFTER 我的照片书  |

http://blog.csdn.net/iukey/article/details/7305790

UIButton是一个标准的UIControl控件,所以如果你对UIControl不甚了解还是先看一下我的另一篇博文:《UIControl IOS控件编程》

一、创建

两种方法:

1. 常规的 initWithFrame

  1. UIButton *btn1 = [[UIButton alloc]initWithFrame:CGRectMake(10108044)];  
对代码创建View(UIControl继承自UIView,所以也是view)不甚了解的请参看:《有关View的几个基础知识点》

2. UIButton 的一个类方法(也可以说是静态方法)buttonWithType

  1. UIButton *btn2 = [UIButton buttonWithType:UIButtonTypeRoundedRect];  

风格有如下

  1. typedef enum {  
  2.     UIButtonTypeCustom = 0,           // no button type   自定义,无风格  
  3.     UIButtonTypeRoundedRect,          // rounded rect, flat white button, like in address card 白色圆角矩形,类似偏好设置表格单元或者地址簿卡片  
  4.     UIButtonTypeDetailDisclosure,//蓝色的披露按钮,可放在任何文字旁  
  5.     UIButtonTypeInfoLight,//微件(widget)使用的小圆圈信息按钮,可以放在任何文字旁  
  6.     UIButtonTypeInfoDark,//白色背景下使用的深色圆圈信息按钮  
  7.     UIButtonTypeContactAdd,//蓝色加号(+)按钮,可以放在任何文字旁  
  8. } UIButtonType;  
二、设置属性

1.Frame属性

第2种方法创建按钮后你可以给按钮的frame属性赋值,用一个CGRect结构设置他的位置和大小

  1. CGRect btn2Frame = CGRectMake(10.010.060.044.0);  
  2.     btn2.frame =btn2Frame;  
2. title属性

对于任何特定状态下的按钮,都可以设定该按钮该状态下的按钮标题。用setTitle 方法 设置即可:

  1. [btn1 setTitle:@"BTN1" forState:UIControlStateNormal];  
你也可以为按钮的某一状态设置为图。用 setImage 即可:

  1. [btn2 setImage:[UIImage imageNamed:@"pic"] forState:UIControlStateNormal];  
此外,你还可以为每种按钮状态设置标题的颜色和阴影,以及按钮的背景。方法 setTitleColor 和 setTitleShadowColor 都需要一个UIColor对象做参数:

  1. [btn1 setTitleColor:[UIColor redColor] forState:UIControlStateNormal];//设置标题颜色  
  2.     [btn1 setTitleShadowColor:[UIColor grayColor] forState:UIControlStateNormal ];//阴影  
  3.     [btn1 setBackgroundImage:[UIImage imageNamed:@"PIC"] forState:UIControlStateHighlighted];//背景图像  
上面几个方法都提到 共同的参数 forState . 这个参数决定了标题、图像或其他属性将在何种状态下显现。你可以编程令按钮在那个状态变化

  1. enum {  
  2.     UIControlStateNormal       = 0,  //常态                       
  3.     UIControlStateHighlighted  = 1 << 0,                  // used when UIControl isHighlighted is set 高亮  
  4.     UIControlStateDisabled     = 1 << 1,  //禁用  
  5.     UIControlStateSelected     = 1 << 2,                  // flag usable by app (see below) 选中  
  6.     UIControlStateApplication  = 0x00FF0000,              // additional flags available for application use 当应用程序标志使用时  
  7.     UIControlStateReserved     = 0xFF000000               // flags reserved for internal framework use  为内部框架预留的  
  8. };  
  9. typedef NSUInteger UIControlState;  
你只要掌握前四种状态就好了。

当按钮高亮或者禁用,UIButton 类可以调整自己的外观,下面几个属性可以让你按照需要对按钮的外观进行微调:

adjustsImageWhenHighlighted

默认情况下,在按钮被禁用时,图像会被画的颜色深一些。要禁用此功能,请将这个属性设置为NO:

  1. btn1.adjustsImageWhenHighlighted = NO;  

adjustsImageWhenDisabled

默认情况下,按钮在被禁用时,图像会被画的颜色淡一些。要禁用此功能,请将这个属性设置为NO:

  1. btn1.adjustsImageWhenDisabled = NO;  

showsTouchWhenHighlighted

这个
属性设置为YES,可令按钮在按下时发光。这可以用于信息按钮或者有些重要的按钮:

  1. btn1.showsTouchWhenHighlighted = YES;  
三、显示控件

 显示控件一如继往的简单:

  1. [self.view addSubview:btn1];  
  2.     [self.view addSubview:btn2];  

四、重写绘制行为

你可以通过子类化按钮来定制属于你自己的按钮类。在子类化的时候你可以重载下面这些方法,这些方法返回CGRect结构,指明了按钮每一组成部分的边界。

注意:不要直接调用这些方法, 这些方法是你写给系统调用的。

  1. backgroundRectForBounds   //指定背景边界  
  1. contentRectForBounds // 指定内容边界  
  1. titleRectForContentRect    // 指定文字标题边界  
  1. imageRectForContentRect     //指定按钮图像边界  

例:

  1. - (CGRect)imageRectForContentRect:(CGRect)bounds{  
  2.      return CGRectMake(0.00.04444);  
  3.  }  

五、添加动作

按钮是用来干嘛的?用来激发某个动作或事件的。那我们我们要为他添加一个动作,与 UIControl 里讲的一样:

  1. -(void)btnPressed:(id)sender{  
  2.     UIButton* btn = (UIButton*)sender;  
  3.     //开始写你自己的动作  
  4. }  
  5.   
  6.   
  7.  [btn1 addTarget:self action:@selector(btnPressed:) forControlEvents:UIControlEventTouchUpInside];  


六、END

END?还未结束,不过UIButton结束了,留下一个未结束的话题: UIBarButtonItem .他和UIButton啥关系,后面会有文章来讲,目前你只要搞清楚UIButton就好了。

  评论这张
 
阅读(245)| 评论(0)
推荐 转载

历史上的今天

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2017