UIButton是我们经常用的一个控件,它是继承自UIControl的,下面就总结一下相关属性及用法:

1.UIButton的创建


a.不带样式的:

let btn: UIButton = UIButton()

b.带样式的

let btns:UIButton =UIButton(type: UIButtonType);

其中UIButtonType是一个枚举如下所示:

publicenum UIButtonType :Int {
    case Custom // no button type 自定义样式按钮
    @available(iOS 7.0,*)
    case System // standard system button	//系统的样式按钮
    case Detaildisclosure
    case InfoLight
    case InfoDark
   case ContactAdd//联系人按钮
    public staticvar RoundedRect: UIButtonType { get }// Deprecated,use UIButtonTypeSystem instead
}

用法如下:

let btn: UIButton = UIButton(type: .Custom)

2.UIButton设置字内容和颜色

btn.setTitle("按钮",forState: .normal)

btn.setTitleColor(UIColor.whiteColor(),forState: .normal)


3.UIButton设置背景颜色和背景图片

btn.backgroundColor =UIColor.blackColor()

btn.setBackgroundImage(UIImage(named:"1"),forState: .normal)


4.UIButton设置字体大小

btn.titleLabel?.font =UIFont.systemFontOfSize(20)


5.禁用UIButton

btn.enabled =false //禁止按钮,默认为true


6.设置圆角

btn.layer.cornerRadius = 8


7.设置背景图片为圆角(因为我们直接设置UIButton圆角时,图片不会变为圆角)

buttonImage.setimage(UIImage(named:"1"),forState: UIControlState.normal)

//设置背景图片为圆角

buttonImage.imageView?.layer.cornerRadius = 50


8.在UIButton上添加图片和文字,有时需要我们调整,此时需要:

方向为逆时针方向,上、左、下、右依次去设置的

btn.imageEdgeInsets =UIEdgeInsetsMake(top: CGFloat,left: CGFloat,bottom: CGFloat,right: CGFloat)

btn.titleEdgeInsets =UIEdgeInsetsMake(top: CGFloat,right: CGFloat)

例子如下:

        //创建一个图片一个文字的按钮
        let btn2: UIButton = UIButton(type: .Custom)
        btn2.frame = CGRectMake(50,100,120,35)
        btn2.setimage(UIImage(named: "1"),forState: .normal)
        btn2.backgroundColor = UIColor.blackColor()
        btn2.titleLabel?.font = UIFont.systemFontOfSize(20)
        btn2.imageView?.contentMode = UIViewContentMode.ScaleAspectFit
        btn2.setTitle("图片按钮",forState: .normal)
        //偏移量,分别为上下左右
        btn2.imageEdgeInsets = UIEdgeInsetsMake(0,-50,0)
        btn2.titleEdgeInsets = UIEdgeInsetsMake(0,-80,5)
        btn2.setTitleColor(UIColor.whiteColor(),forState: .normal)
        btn2.adjustsImageWhenHighlighted = false
        self.view.addSubview(btn2)
9 .添加按钮的点击事件

第一种是不带参数的,第二种是带参数的

btn.addTarget(self,action:"click",forControlEvents: .TouchUpInside)

btn.addTarget(self,action:"clicks:",forControlEvents: .TouchUpInside)

第一种:

func click(){}

第二种:

func clicks(sender:UIButton){}

写的代码如下:

func initButtonView() {
        //创建有状态的按钮
        let btn: UIButton = UIButton(type: .Custom)
        btn.frame = CGRectMake(50,20,30)
        btn.setTitle("点击按钮",forState: .Selected)
        btn.setTitle("未点击",forState: .normal)
        btn.backgroundColor = UIColor.blackColor()
        btn.addTarget(self,action: "clickBtn:",forControlEvents: .TouchUpInside)
        self.view .addSubview(btn)
        
        //创建无状态的按钮
        let btn1: UIButton = UIButton()
        btn1.frame = CGRectMake(50,60,30)
        btn1.setTitle("normal",forState: .normal)
        btn1.backgroundColor = UIColor.blueColor()
        self.view.addSubview(btn1)
        
        //创建一个图片一个文字的按钮
        let btn2: UIButton = UIButton(type: .Custom)
        btn2.frame = CGRectMake(50,forState: .normal)
        btn2.adjustsImageWhenHighlighted = false
        self.view.addSubview(btn2)
        
        //创建禁止按钮
        let btn3: UIButton = UIButton(type: .Custom)
        btn3.frame = CGRectMake(50,140,35)
        btn3.setTitle("点击按钮",forState: .Highlighted)
        btn3.setTitle("禁止按钮",forState: .normal)
        btn3.enabled = false    //禁止按钮,默认为true
        btn3.setTitleColor(UIColor.redColor(),forState: .disabled)
        btn3.backgroundColor = UIColor.purpleColor()
        self.view.addSubview(btn3)
        
        //创建圆角按钮
        let btn4: UIButton = UIButton(type: .Custom)
        btn4.frame = CGRectMake(50,180,35)
        btn4.backgroundColor = UIColor.blackColor()
        btn4.setTitle("圆角按钮 ",forState: .normal)
        btn4.setTitleColor(UIColor.whiteColor(),forState: .normal)
        btn4.layer.cornerRadius = 8
        self.view.addSubview(btn4)
        
        //部分圆角按钮,主要利用layer的mask属性,在tongguoCAShaperLayer和UIBezierPath来画
        let btn5: UIButton = UIButton(type: .Custom)
        btn5.frame = CGRectMake(50,220,35)
        btn5.backgroundColor = UIColor.blackColor()
        btn5.setTitle("部分圆角按钮",forState: .normal)
        btn5.setTitleColor(UIColor.whiteColor(),forState: .normal)
        let shape: CAShapeLayer = CAShapeLayer()
        let bepath: UIBezierPath = UIBezierPath(roundedRect: btn5.bounds,byRoundingCorners: [UIRectCorner.TopRight,UIRectCorner.TopLeft,UIRectCorner.BottomLeft],cornerRadii: CGSize(width: 8,height: 8))
        UIColor.blackColor().setstroke()
        shape.path = bepath.CGPath
        btn5.layer.mask = shape
        self.view.addSubview(btn5)
        
        //创建带边框的按钮
        let btn6: UIButton = UIButton(type: .Custom)
        btn6.frame = CGRectMake(50,260,35)
        btn6.setTitle("边框按钮",forState: .normal)
        btn6.setTitleColor(UIColor.blackColor(),forState: .normal)
        btn6.layer.borderColor = UIColor.blackColor().CGColor
        btn6.layer.borderWidth = 1
        btn6.layer.cornerRadius = 8
        self.view.addSubview(btn6)
        
        //显示提示信息的UILabel
        labelText = UILabel()
        labelText.frame = CGRectMake(50,300,44)
        labelText.textColor = UIColor.orangeColor()
        self.view.addSubview(labelText)
        
        let btns: UIButton = UIButton(type: .Custom)
        btns.frame = CGRectMake(<#T##x: CGFloat##CGFloat#>,<#T##y: CGFloat##CGFloat#>,<#T##width: CGFloat##CGFloat#>,<#T##height: CGFloat##CGFloat#>)
        btn.setTitle("按钮",forState: .normal)
        btn.setTitleColor(UIColor.whiteColor(),forState: .normal)
        btn.backgroundColor = UIColor.blackColor()
        btn.setBackgroundImage(UIImage(named: "1"),forState: .normal)
        btn.imageEdgeInsets = UIEdgeInsetsMake(<#T##top: CGFloat##CGFloat#>,<#T##left: CGFloat##CGFloat#>,<#T##bottom: CGFloat##CGFloat#>,<#T##right: CGFloat##CGFloat#>)
        btn.titleEdgeInsets = UIEdgeInsetsMake(<#T##top: CGFloat##CGFloat#>,<#T##right: CGFloat##CGFloat#>)
        
        btn.addTarget(self,action: "click",forControlEvents: .TouchUpInside)
    }
    
    func clickBtn(sender: UIButton){
        
        sender.selected = !sender.selected
        labelText.text = "点击了按钮"
    }

效果图如下:

swift中UIButton的简单使用的更多相关文章

  1. ios – 如何通过编程方式为UIButtons组设置单个背景图像

    解决方法要使用选择器数组以编程方式创建按钮,您可以使用以下代码片段://定义策略

  2. ios – UIButton背景图像以编程方式更改

    如何在点击事件中更改我的UIButton的背景图像?并使用上一张图片在几秒钟内刷新它?我的意思是在点击后更改它的背景图像并在点击后重置它.解决方法将您的clickEvent图像作为按钮的突出显示图像.

  3. ios – UIPopoverController出现在错误的位置

    所以我花了一些时间寻找答案,但到目前为止还没有找到任何答案.我正在尝试从UIInputAccessoryView上的按钮呈现弹出窗口.UIBarButtonItem我想显示popover来自定制视图,所以我可以使用图像.我创建这样的按钮:当需要显示popover时,我这样做:但我得到的是:弹出窗口看起来很好,但它应该出现在第一个按钮上时出现在第二个按钮上.然后我发现了这个问题:UIBarButto

  4. ios – 无法在UIButton上更改自定义UIFont大小

    我有一个按钮,我使用自定义UIFont来显示文本.字体正确加载并正确应用于按钮标题.我的问题是我似乎无法改变字体大小:无论我输入什么字体大小,我都会得到一些默认大小.另一方面,如果我做这样的事情:我得到大小32字体,但是,当然,我没有得到我的自定义字体.那么,如何设置自定义字体的大小?解决方法要获取必须传递fontWithName:size:的字体名称,请使用FontBook应用程序打开字体,然后查找PostScript名称属性.确保您已将其添加到Info.plist文件中.

  5. ios – 创建UIButton(UIButtonTypeCustom),顶部带有图像,底部带有AutoLayout标签

    我试图在它的底部显示带有文本的按钮.顶部的图像;图像&单击时必须突出显示文本.像这样:这是viewDidLoad中的代码:问题是文本根本不显示.请参阅下面的链接图像.如何使用UIEdgeInset为文本腾出空间?我也试过创建一个UIButton类,但效果大致相同.解决方法请使用以下代码设置插图,希望这可以帮助..

  6. ios – Touch拖动输入如何工作?

    任何人都可以给我一个关于触摸拖动输入以从一个按钮拖动到另一个触发两个按钮事件的示例.它是如何工作的?例如,我想从Do到Fa拖动Do,Re,Mi,Fa的事件被触发.这是我的代码:哦,我已经看到,当我按住Simulator时,会触发方法btnDragOut.当我从Simulator拖出按钮时,会触发此按钮的方法.现在我希望当我拖出一个按钮时触发方法btnDragOut.有谁知道吗?

  7. ios – 如何让UIButton成为一个圆圈?

    我一直试图让细胞中的UIButton成为一个完美的圆圈.不幸的是,圆形是基于背景图像而不是UIButton框架形成的.我创建圆圈的代码:输出如下:我该怎么做才能获得我想要的完美圆形按钮框架?解决方法尝试这样的事情如果需要创建一个视图圆,则必须将masksToBounds设置为true,不要设置clipsToBounds希望这会帮助你.

  8. ios – UIButton在我不希望它时是透明的

    我有一个按钮,我放在自定义UICollectionViewCell的顶角.出于某种原因,它显得半透明,以便当我不喜欢这种情况时,通过按钮显示单元格的边框.在我的CustomCollectionviewCell中:这导致以下结果:这些图像都不是半透明的.他们有扎实的背景,所以我很困惑为什么他们在应用程序中显示为半透明.我原本以为他们可能被放在了单元格的后面,所以我在setupCellLayout()

  9. ios – UIButton在uiscrollView中不起作用

    我有一个将UIView作为子视图的scrollView.这有UIView子视图UIButton.只有scrollView连接到插座,其余全部都是代码.按钮不响应触摸,触摸时不变蓝.我能做些什么才能让它发挥作用?这是代码:解决方法您必须设置视图的内容大小.它必须大于或等于scrollView的内容大小.因为您的视图的默认大小是320*480和320*568.因此,增加视野的高度–self.view.frame=CGRectMake;然后将其添加为scrollView的子视图.将帮助您解决问题.

  10. ios – UIControlEventTouchDragExit在距离UIButton 100像素时触发

    非常感激!

随机推荐

  1. Swift UITextField,UITextView,UISegmentedControl,UISwitch

    下面我们通过一个demo来简单的实现下这些控件的功能.首先,我们拖将这几个控件拖到storyboard,并关联上相应的属性和动作.如图:关联上属性和动作后,看看实现的代码:

  2. swift UISlider,UIStepper

    我们用两个label来显示slider和stepper的值.再用张图片来显示改变stepper值的效果.首先,这三个控件需要全局变量声明如下然后,我们对所有的控件做个简单的布局:最后,当slider的值改变时,我们用一个label来显示值的变化,同样,用另一个label来显示stepper值的变化,并改变图片的大小:实现效果如下:

  3. preferredFontForTextStyle字体设置之更改

    即:

  4. Swift没有异常处理,遇到功能性错误怎么办?

    本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容,请发送邮件至dio@foxmail.com举报,一经查实,本站将立刻删除。

  5. 字典实战和UIKit初探

    ios中数组和字典的应用Applicationschedule类别子项类别名称优先级数据包contactsentertainment接触UIKit学习用Swift调用CocoaTouchimportUIKitletcolors=[]varbackView=UIView(frame:CGRectMake(0.0,0.0,320.0,CGFloat(colors.count*50)))backView

  6. swift语言IOS8开发战记21 Core Data2

    上一话中我们简单地介绍了一些coredata的基本知识,这一话我们通过编程来实现coredata的使用。还记得我们在coredata中定义的那个Model么,上面这段代码会加载这个Model。定义完方法之后,我们对coredata的准备都已经完成了。最后强调一点,coredata并不是数据库,它只是一个框架,协助我们进行数据库操作,它并不关心我们把数据存到哪里。

  7. swift语言IOS8开发战记22 Core Data3

    上一话我们定义了与coredata有关的变量和方法,做足了准备工作,这一话我们来试试能不能成功。首先打开上一话中生成的Info类,在其中引用头文件的地方添加一个@objc,不然后面会报错,我也不知道为什么。

  8. swift实战小程序1天气预报

    在有一定swift基础的情况下,让我们来做一些小程序练练手,今天来试试做一个简单地天气预报。然后在btnpressed方法中依旧增加loadWeather方法.在loadWeather方法中加上信息的显示语句:运行一下看看效果,如图:虽然显示出来了,但是我们的text是可编辑状态的,在storyboard中勾选Editable,再次运行:大功告成,而且现在每次单击按钮,就会重新请求天气情况,大家也来试试吧。

  9. 【iOS学习01】swift ? and !  的学习

    如果不初始化就会报错。

  10. swift语言IOS8开发战记23 Core Data4

    接着我们需要把我们的Rest类变成一个被coredata管理的类,点开Rest类,作如下修改:关键字@NSManaged的作用是与实体中对应的属性通信,BinaryData对应的类型是NSData,CoreData没有布尔属性,只能用0和1来区分。进行如下操作,输入类名:建立好之后因为我们之前写的代码有些地方并不适用于coredata,所以编译器会报错,现在来一一解决。

返回
顶部