自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

Swift之貪婪的UIButton

移動開發(fā)
按鈕是所有UI體系中非常重要的組件,在iOS中按鈕UIButton的使用也非常靈活,本文將從幾點詳細介紹UIButton的使用。

一、內(nèi)容概要

QQ截圖20150730101519.png

按鈕是所有UI體系中非常重要的組件,在iOS中按鈕UIButton的使用也非常靈活,本文將從以下幾點介紹UIButton的使用(基于Swift2.0):

  1. UIButton基礎
  2. UIButton圖片使用
  3. 圓角按鈕
  4. 復選框按鈕
  5. 倒計時按鈕(閃爍問題也輕松解決)
  6. 貪婪按鈕(父控件事件也歸我,擴大事件響應區(qū)域)

二、UIButton基礎

2.1 創(chuàng)建

UIButton提供了一個簡單的構造方法

 

  1. convenience init(type buttonType: UIButtonType) 

此方法中需要我們傳入一個UIButtonType枚舉類型,使用代碼如下:

  1. func createButton() { 
  2.     let button = UIButton(type: UIButtonType.System) 
  3.     button.frame = CGRectMake(505010050
  4.     button.setTitle("確定", forState: UIControlState.Normal) 
  5.     button.addTarget(self, action: "buttonPressed:", forControlEvents: UIControlEvents.TouchUpInside) 
  6.     self.view.addSubview(button) 
  7. func buttonPressed(button: UIButton) { 

Tips:

1.設置按鈕標題時,一定要通過

  1. func setTitleColor(color: UIColor?, forState state: UIControlState) 

不可通過

  1. button.titleLabel?.text = "確定" 

此方式會在點擊時標題自動變?yōu)閟etTitleColor方法Normal狀態(tài)下的文字.

2.2圖片使用

UIButton提供了以下兩個接口使用圖片:

  1. func setImage(image: UIImage?, forState state: UIControlState) 
  2. func setBackgroundImage(image: UIImage?, forState state: UIControlState) 

(1)其中接口setImage用來設置按鈕的圖片,默認情況下,它會與按鈕文字水平線性排列

(2)接口setBackgroundImage用來設置按鈕的背景圖片,setImage及按鈕文字都會顯示在背景圖片之上

這里著重討論一下setBackgroundImage接口,很多時候,按鈕看起來是這樣的:

QQ截圖20150730101627.png

這些按鈕,背景相同,只是尺寸不一樣,下面來談一下,如何復用這一類圖片資源.

2.2.1代碼方式

2.2.1.1 原理說明

在UIImage接口中,有以下方法

  1. func resizableImageWithCapInsets(_ capInsets: UIEdgeInsets) -> UIImage 

使用此方法時,需要傳遞UIEdgeInsets作為參數(shù),創(chuàng)建接口如下:

  1. func UIEdgeInsetsMake(_ top: CGFloat, _ left: CGFloat, _ bottom: CGFloat, _ right: CGFloat) -> UIEdgeInsets 
這個方法提供了上下左右的參數(shù)來創(chuàng)建可變區(qū)域,如下圖(Tips:下圖標明的可變區(qū)域與視圖內(nèi)邊距是不同的概念)

image_2.png

圖中,藍色標識為可變區(qū)域, 綠色標識為不變區(qū)域。UIEdgeInsets結構體的屬性top與bottom為一對,用來指定縱向可變區(qū)域(黑色虛線矩形),left與right為一對,用來指定橫向可變區(qū)域(白色虛線矩形)。當UIButton/UIImageView的size大于UIImage的size時,會調(diào)整圖片中可變區(qū)域大小以鋪滿整個控件,具體調(diào)整規(guī)則如下:

(1)控件寬度大于圖片寬度,拉伸白色虛線矩形

(2)控件高度大于圖片高度,拉伸黑色虛線矩形

(3)控制寬度小于圖片寬度時,橫向整體縮小(可變區(qū)與不變區(qū)比例不變)

(4)控制高度小于圖片高度時,縱向整體縮小(可變區(qū)與不變區(qū)比例不變)

iOS系統(tǒng)會根據(jù)設備的分辨率自動加載1倍圖、2倍圖、3倍圖,而方法resizableImageWithCapInsets中的上下左右是以像素為單位,這就要求在使用時,根據(jù)x倍圖,來設置對應的邊距,例如:

  1. let image = UIImage(named: "image_name"
  2. //1倍圖時上下左右邊距都是25 
  3. let padding = 25 * (image?.scale)! 
  4. let edge = UIEdgeInsetsMake(padding, padding, padding, padding) 
  5. let resizeImage = image?.resizableImageWithCapInsets(edge) 
  6. button.setBackgroundImage(resizeImage!, forState: UIControlState.Normal) 

#p#

2.2.1.2性能與可變區(qū)域大小的關系

(1)性能***:可變區(qū)為1像素寬或者高時,繪圖時通過拉伸1像素方式

(2)性能較好:可變區(qū)為整張圖片,方法resizableImageWithCapInsets參數(shù)為UIEdgeInsetsZero,繪制時通過平鋪整張圖片方式

(3)性能較差:可變區(qū)寬或者高大于1像素時,繪圖時通過平鋪方式,此種方式性能較差,但是在實際開發(fā)中此種方式也是用的最多的一種。

Tips

在一些應用中,應用程序有一些非純色背景,這個背景會在多個界面使用,由于設備分辨率、界面控件的尺寸差別,會要求制作多個尺寸的圖,導致ipa包變大、內(nèi)存使用增加。這里結合上面(2)設置可變區(qū)為整張圖片,可以解決此問題,原理請看無縫貼圖

QQ截圖20150730101812.png

示例代碼如下:

 
  1. let image = UIImage(named: "tile"
  2. let resizeImage = image?.resizableImageWithCapInsets(UIEdgeInsetsZero) 
  3. self.bkImageView.image = resizeImage 
  4. 2.2.2 Asset Catalogs方式(推薦) 

Xcode提供了Asset Catalogs的方式來管理圖片資源,Asset Catalogs提供了可視化界面來設置圖片的可變區(qū),操作方便,使用簡單。點擊右下方的Show Slicing

image_4.png

進入編輯模式后,圖片的中間會有一個Start Slicing按鈕,點擊后,會讓我們選擇拉伸方式,如下圖:

QQ截圖20150730101922.png

三個按鈕的作用

1
2
3
按鈕1只做水平拉伸
按鈕2水平垂直都拉伸
按鈕3只做垂直拉伸

水平及垂直的拉伸處理相同,這里以水平為例,選擇水平拉伸按鈕1后,會提供三條操作線用來指定可變區(qū)及刪除區(qū)

QQ截圖20150730102019.png

可變區(qū):操作線1與操作線2指定的區(qū)域,在拉伸時,會根據(jù)最終尺寸改變此區(qū)域的大小

刪除區(qū):操作線2與操作線3指定的區(qū)域(白色半透明層),可以簡單的理解為,此區(qū)域在拉伸時會被直接刪除。使用方法跟普通圖片一樣,代碼如下:

  1. let image = UIImage(named: "image_asset_name"
  2. button.setBackgroundImage(image, forState: UIControlState.Normal) 

QQ截圖20150730102059.png

#p#

三、UIButton其它用法

3.1 圓角按鈕

有些時候,我們需要一個圓形按鈕,例如頭像:

QQ截圖20150730102144.png

  1. let image = UIImage(named: "user_avatar"
  2. self.button.setImage(image, forState: UIControlState.Normal) 
  3. self.button.imageView?.layer.cornerRadius = self.button.frame.width / 2 

3.2 復選框按鈕

UIKit中沒有復選框組件怎么辦?

QQ截圖20150730102155.png

  1. func checkBoxButton() { 
  2.     let frame = CGRectMake(6879300128
  3.     let button = UIButton(type: UIButtonType.Custom) 
  4.     button.setTitleColor(UIColor.whiteColor(), forState: UIControlState.Normal) 
  5.     button.frame = frame 
  6.     button.titleLabel?.font = UIFont.systemFontOfSize(30
  7.     button.contentHorizontalAlignment = UIControlContentHorizontalAlignment.Left 
  8.     button.setTitle("復選框按鈕", forState: UIControlState.Normal) 
  9.     //上面是樣式的設定,下面才是跟復選框有關 
  10.     button.addTarget(self, action: "buttonPressed:", forControlEvents: UIControlEvents.TouchUpInside) 
  11.     button.setImage(UIImage(named: "check"), forState: UIControlState.Normal) 
  12.     button.setImage(UIImage(named: "uncheck"), forState: UIControlState.Selected) 
  13.     self.view.addSubview(button) 
  14. func buttonPressed(button: UIButton) { 
  15.     button.selected = !button.selected 

3.3 倒計時按鈕(閃爍問題也輕松解決)

很多應用中發(fā)短信倒計時功能,一般都會將NSTimer與UIButton結合來實現(xiàn)此功能,如果UIButton是這么初使化的:

1
let button = UIButton(type: UIButtonType.System)

在測試時會發(fā)現(xiàn),當定時器每隔一秒更改標題時,會有閃爍現(xiàn)象,將UIButtonType.System更改為UIButtonType.Custom即可

這里提供封裝好的倒計時按鈕大家可以直接下載使用:http://00red.com/download/Swift之貪婪的UIButton/ILCountDownButton.swift

使用示例如下:

 
  1. let frame = CGRectMake(505010040
  2. let countButton = ILCountDownButton(count: 5
  3. countButton.frame = frame 
  4. countButton.setBackgroundImageForCount(UIImage(named: "bk_count")!) 
  5. countButton.setBackgroundImageForRestart(UIImage(named: "bk_restart")!) 
  6. countButton.setTitleForRestart("重新發(fā)送"
  7. self.view.addSubview(countButton) 

四、貪婪按鈕

UIButton的frame會直接影響到setImage及setBackgroundImage的顯示效果,有的時候我們只需要擴大UIButton的點擊區(qū)域,而不想直接修改UIButton的frame而影響顯示。這時可以通過以下方法來處理

QQ截圖20150730102312.png

將UIButton的父視圖(superView)的點擊事件占有,所有的觸控操作全部轉(zhuǎn)嫁到UIButton控件上。iOS在處理事件分發(fā)時,分為兩個步驟:***步,查找哪一個UI組件響應此事件,第二步,事件處理,響應者鏈。要實現(xiàn)事件的轉(zhuǎn)嫁,在***步中來處理即可,代碼如下:

 
  1. class ILGreedButton: UIButton { 
  2.     override func hitTest(point: CGPoint, withEvent event: UIEvent?) -> UIView? { 
  3.         return self 
  4.     } 

在使用ILGreedButton時,就會出現(xiàn)點擊父視圖,UIButton響應事件的效果

責任編輯:倪明 來源: 一葉博客
相關推薦

2009-08-20 13:48:37

C#正則表達式

2012-06-05 09:12:27

Windows Pho

2015-04-17 16:30:46

swiftOC

2014-06-05 14:12:05

SwiftUI學習iOS

2022-03-04 09:02:01

StoryBoard工具git

2013-07-24 19:27:45

iOS開發(fā)學習自定義帶下劃線文本UI

2014-09-26 09:49:48

SwiftObjective-C

2011-08-17 16:29:12

iPhone開發(fā)UIButton

2018-04-02 10:54:56

2015-04-17 16:07:11

swiftOC

2016-06-07 14:42:18

Swift設計

2015-01-21 16:25:29

Swift指針

2015-07-01 13:50:29

Swift開源思考

2015-07-08 16:43:02

Configurati

2015-11-23 10:07:19

Swift模式匹配

2015-07-21 11:52:34

Swift分享按鈕源碼

2015-03-16 10:33:14

Swift指針

2025-02-17 08:50:00

OpenAI馬斯克人工智能

2009-08-13 15:02:52

C#正則表達式引擎貪婪

2019-10-29 15:09:52

Python貪心算法代碼
點贊
收藏

51CTO技術棧公眾號