精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

Swift之貪婪的UIButton

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

一、內容概要

QQ截圖20150730101519.png

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

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

二、UIButton基礎

2.1 創建

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 = "確定" 

此方式會在點擊時標題自動變為setTitleColor方法Normal狀態下的文字.

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作為參數,創建接口如下:

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

image_2.png

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

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

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

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

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

iOS系統會根據設備的分辨率自動加載1倍圖、2倍圖、3倍圖,而方法resizableImageWithCapInsets中的上下左右是以像素為單位,這就要求在使用時,根據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性能與可變區域大小的關系

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

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

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

Tips

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

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提供了可視化界面來設置圖片的可變區,操作方便,使用簡單。點擊右下方的Show Slicing

image_4.png

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

QQ截圖20150730101922.png

三個按鈕的作用

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

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

QQ截圖20150730102019.png

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

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

  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 倒計時按鈕(閃爍問題也輕松解決)

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

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

在測試時會發現,當定時器每隔一秒更改標題時,會有閃爍現象,將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("重新發送"
  7. self.view.addSubview(countButton) 

四、貪婪按鈕

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

QQ截圖20150730102312.png

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

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

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

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

2009-08-20 13:48:37

C#正則表達式

2012-06-05 09:12:27

Windows Pho

2014-06-05 14:12:05

SwiftUI學習iOS

2015-04-17 16:30:46

swiftOC

2022-03-04 09:02:01

StoryBoard工具git

2014-09-26 09:49:48

SwiftObjective-C

2013-07-24 19:27:45

iOS開發學習自定義帶下劃線文本UI

2018-04-02 10:54:56

2011-08-17 16:29:12

iPhone開發UIButton

2015-04-17 16:07:11

swiftOC

2015-01-21 16:25:29

Swift指針

2016-06-07 14:42:18

Swift設計

2015-07-08 16:43:02

Configurati

2015-07-21 11:52:34

Swift分享按鈕源碼

2015-07-01 13:50:29

Swift開源思考

2015-03-16 10:33:14

Swift指針

2015-11-23 10:07:19

Swift模式匹配

2025-02-17 08:50:00

OpenAI馬斯克人工智能

2009-08-13 15:02:52

C#正則表達式引擎貪婪

2019-10-29 15:09:52

Python貪心算法代碼
點贊
收藏

51CTO技術棧公眾號

亚洲免费观看| 日本一区影院| 亚洲欧美日韩国产综合在线| 91精品中国老女人| 激情综合网五月婷婷| 日韩aaa久久蜜桃av| 欧美中文字幕亚洲一区二区va在线| 一区二区精品免费视频| 亚洲精品久久久久avwww潮水| 性欧美videos另类喷潮| 北条麻妃在线一区二区| 精品人妻一区二区三区日产| av成人在线观看| 艳妇臀荡乳欲伦亚洲一区| 欧美日韩在线精品| 亚洲国产精品一| 麻豆国产91在线播放| 91精品国产91久久久久久吃药| 日本污视频网站| 久久男人av| 91精品国产麻豆国产自产在线| 人妻有码中文字幕| 羞羞视频在线免费国产| 中文乱码免费一区二区| 精品一区在线播放| 99在线小视频| 天堂av在线一区| 国产+人+亚洲| 亚洲色婷婷一区二区三区| 精品72久久久久中文字幕| 欧美va亚洲va香蕉在线| 伊人色在线观看| 午夜av成人| 欧美日韩亚洲一区二区| 蜜臀av色欲a片无码精品一区| 97在线观看免费观看高清| 91免费国产视频网站| 91亚洲精品丁香在线观看| 中文字幕第2页| 久久精品一区二区国产| 68精品国产免费久久久久久婷婷| 欧美日韩免费一区二区| 国产精品99在线观看| 亚洲男人天堂古典| 欧美一级视频在线| 成人国产综合| 欧美写真视频网站| 国产熟人av一二三区| 成人免费网站视频| 色婷婷av一区二区| 免费午夜视频在线观看| 中文字幕一区久| 欧美日韩中文字幕日韩欧美| 乱人伦xxxx国语对白| 狂野欧美性猛交xxxxx视频| 最新热久久免费视频| 中文视频一区视频二区视频三区| av中文在线| 国产精品天天看| 亚洲精品中字| 免费黄色网址在线观看| 1000部国产精品成人观看| 亚洲一区二区三区加勒比| 日本中文在线观看| 亚洲色大成网站www久久九九| 国产一区一区三区| 少妇一级黄色片| 久久亚州av| 精品视频在线播放免| 亚洲精品中文字幕在线播放| 丝袜av一区| 亚洲欧洲日本专区| 手机看片日韩av| 欧美韩日一区| 欧美美女操人视频| 中文字幕一区二区三区手机版 | 亚洲福利影院| 日韩欧美精品免费在线| www.色偷偷.com| 国产亚洲观看| 亚洲电影免费观看高清完整版在线| 毛茸茸free性熟hd| 国产亚洲一区| 不卡中文字幕av| 日韩精品一区三区| 视频一区二区不卡| 91视频88av| 欧美视频xxx| 久久久精品蜜桃| www亚洲国产| www.综合| 欧美人xxxx| 日韩综合第一页| 精品日韩一区| 欧美风情在线观看| 国产免费一区二区三区四区五区 | 亚洲黄色小说在线观看| 欧美人妖视频| 俺去啦;欧美日韩| 国产精品1234区| 久久精品国产久精国产爱| 国产激情一区二区三区在线观看 | 无码一区二区三区在线观看| 久久www免费人成看片高清| 不卡一区二区三区视频| 国产区视频在线| 亚洲综合丝袜美腿| 在线免费视频a| 91精品国产乱码久久久竹菊| 一本久久综合亚洲鲁鲁| 日本在线观看视频网站| 久久国产婷婷国产香蕉| 久草精品电影| 婷婷在线播放| 欧美三级三级三级爽爽爽| 日本黄色录像片| 亚洲天堂免费| 国产精品高清在线| 亚洲 欧美 激情 另类| 自拍偷拍亚洲欧美日韩| 亚洲色图38p| 免费看久久久| 欧美精品videosex性欧美| 亚洲无码久久久久久久| 2021久久国产精品不只是精品| 天天想你在线观看完整版电影免费| 欧美香蕉视频| 亚洲精品动漫100p| 国产无码精品久久久| 韩国一区二区三区| 一区二区三区的久久的视频| 欧美理论影院| 亚洲欧美日韩久久久久久| 国产精品美女毛片真酒店| 国产精品影视天天线| 在线观看日韩片| 成人看片在线观看| 亚洲欧美色图片| 亚洲不卡视频在线观看| 99久久99久久精品国产片果冻 | 国产精品久久久视频| 国产精品久久久免费| 国产厕所精品在线观看| 日本片在线观看| 日韩三级免费观看| 丝袜 亚洲 另类 欧美 重口| 老司机免费视频一区二区三区| 日韩欧美视频一区二区三区四区| 另类激情视频| 亚洲乱码国产乱码精品精天堂| 日韩精品一区二区在线播放| 色乱码一区二区三区在线| 欧美精品乱码| 国产日产欧美a一级在线| 在线视频三区| 91麻豆精品国产91久久久资源速度| 日本 欧美 国产| 国产一区二区免费在线| 五月天在线免费视频| 国产一区二区三区视频在线| 欧美成在线视频| 亚洲国产精品欧美久久| 婷婷亚洲久悠悠色悠在线播放 | 狠狠一区二区三区| 69av在线视频| 番号在线播放| 91精品午夜视频| 久久精品国产亚洲av高清色欲| a美女胸又www黄视频久久| 99爱视频在线| 欧美中文字幕一区二区| 亚洲一区国产精品| 牛牛在线精品视频| 亚洲九九九在线观看| 最近中文字幕在线免费观看| 亚洲色图19p| 亚州av综合色区无码一区| 久久尤物视频| 国产又粗又爽又黄的视频| 超碰在线成人| 国产精品jvid在线观看蜜臀| 国产一二三区在线观看| 亚洲精品一区二区精华| 成人免费视频国产免费| 亚洲欧美日韩综合aⅴ视频| 国产污在线观看| 青草av.久久免费一区| 老司机午夜网站| 亚洲人成网站77777在线观看| 国产精品视频一区二区三区四 | 亚洲国产综合在线| 能免费看av的网站| 韩国精品久久久| 欧美日韩黄色一级片| 色婷婷亚洲mv天堂mv在影片| 成人综合色站| av成人免费| 91精品国产精品| 麻豆传媒在线完整视频| 亚洲国产古装精品网站| 在线视频欧美亚洲| 五月婷婷色综合| 亚洲精品久久久久久国| 2014亚洲片线观看视频免费| 在线观看视频你懂得| 日产欧产美韩系列久久99| 国产免费黄色一级片| 99久久九九| 欧美一区二区三区在线播放| 麻豆精品国产| 国产欧美在线视频| 都市激情亚洲综合| 高清欧美性猛交xxxx黑人猛交| 欧美jizz18性欧美| 亚洲人成在线电影| 亚洲国产精品久久人人爱潘金莲| 欧美视频在线观看一区| 中文字幕超碰在线| 亚洲电影一级黄| 男女做暖暖视频| 中文字幕av资源一区| 久久精品女同亚洲女同13| 国产一区二区三区免费| 免费看污污网站| 亚洲资源av| 成人一区二区免费视频| 中文字幕av亚洲精品一部二部| 亚洲精品欧洲精品| 红桃成人av在线播放| 麻豆视频成人| 麻豆国产欧美一区二区三区r| 91精品国产91久久久久青草| 国产成人精品一区二区三区在线| 日韩av免费一区| 深夜在线视频| 午夜欧美大片免费观看| 超级碰碰不卡在线视频| 欧美激情亚洲视频| 污污的视频在线观看| 色综合久久88色综合天天看泰| 在线观看av免费| 久热精品视频在线观看一区| 久操免费在线| 成人97在线观看视频| 国产激情在线| 欧美成人在线免费| 91蜜桃在线视频| 欧美激情a∨在线视频播放| 国产白丝在线观看| 午夜精品久久久久久久久久久久| 19禁羞羞电影院在线观看| 高清一区二区三区日本久| 欧美私密网站| 欧美洲成人男女午夜视频| 厕沟全景美女厕沟精品| 日韩美女视频免费在线观看| 日韩一区二区三区在线免费观看 | 中文字幕你懂的| 欧美人妖巨大在线| 国产夫妻在线观看| 亚洲成人中文字幕| 视频国产在线观看| 亚洲色图35p| 欧美性videos| 欧美日产国产成人免费图片| 91桃色在线| 国产成+人+综合+亚洲欧洲 | 激情视频一区二区| 九一亚洲精品| 亚洲图片都市激情| 国产精品v日韩精品v欧美精品网站 | 欧美最顶级的aⅴ艳星| 小明成人免费视频一区| 国产在线观看91精品一区| 色悠久久久久综合先锋影音下载| 国产欧美精品一区二区三区| 国产欧美日韩免费观看| 综合久久国产| 夜夜嗨一区二区| 青青青在线视频免费观看| 国产高清一区日本| 97人妻精品一区二区三区免| 国产精品二三区| 日本学生初尝黑人巨免费视频| 色综合天天性综合| 国产美女免费视频| 亚洲欧美激情精品一区二区| 精品麻豆一区二区三区| 91国产精品视频在线| 欧美成人三级| 国产综合动作在线观看| 欧美岛国激情| 国产综合av在线| 精品中文av资源站在线观看| 人妻在线日韩免费视频| 日韩毛片在线免费观看| 成年人午夜视频| 56国语精品自产拍在线观看| 手机看片国产1024| 久久九九免费视频| 自拍偷拍欧美视频| 成人91视频| 91日韩欧美| 50路60路老熟妇啪啪| 国产大陆a不卡| 日本高清黄色片| 欧美日韩美女在线| www.综合色| 日韩在线国产精品| 桃色一区二区| 黑人另类av| 欧美1区2区| 色婷婷一区二区三区av免费看| 91在线观看污| 亚洲黄色一区二区| 日韩一区二区三区精品视频| 成a人v在线播放| 秋霞午夜一区二区| 久久久久97| 国产二区视频在线| 国产福利精品导航| 情侣偷拍对白清晰饥渴难耐| 色久优优欧美色久优优| 污视频在线免费观看| 欧美福利视频在线| 伊人久久大香伊蕉在人线观看热v 伊人久久大香线蕉综合影院首页 伊人久久大香 | 中文字幕另类日韩欧美亚洲嫩草| 91国在线观看| 你懂的在线观看视频网站| 8x拔播拔播x8国产精品| 粉嫩av一区二区| www精品久久| 成人免费黄色大片| 久久久久免费看| 日韩视频不卡中文| 成人av免费| 91最新在线免费观看| 久久久久免费av| 性欧美在线视频| 亚洲图片激情小说| 国产精品美女一区| 久久久国产成人精品| 激情不卡一区二区三区视频在线| 伊人久久99| 久久99久久精品欧美| 九九这里只有精品视频| 7777精品伊人久久久大香线蕉超级流畅 | 国产精品视频首页| 天天综合五月天| 国产一区二区看久久| 在线播放精品一区二区三区| 国产美女av在线| 亚洲综合在线做性| 国产精品mv在线观看| 日本精品一二三| 无吗不卡中文字幕| 欧美少妇另类| 国产精品第10页| 国产电影一区二区在线观看| 精品亚洲视频在线| 一二三区精品福利视频| 天天干,天天操,天天射| 欧美一级淫片丝袜脚交| 精品黄色一级片| 免费黄频在线观看| 亚洲成人动漫精品| 九色在线观看视频| 国产主播喷水一区二区| 在线精品视频在线观看高清| youjizz.com日本| 欧美色欧美亚洲高清在线视频| 国产网站在线播放| 92看片淫黄大片看国产片| 伊人久久成人| 精品成人无码一区二区三区| 欧美精品日韩一区| 黄色小说在线播放| 欧美精品亚洲精品| 国内精品视频一区二区三区八戒 | 青青青手机在线视频观看| 国产精品久久久久久搜索| 影音先锋日韩精品| 日本少妇毛茸茸| 精品视频1区2区3区| 男女免费观看在线爽爽爽视频| 欧美午夜精品久久久久久蜜| 国产一区二区三区免费看| 800av免费在线观看| 日韩网站在线观看| 久久99国产精品久久99大师| 一级在线免费视频| 亚洲一区免费视频| 素人av在线| 久久久久久久有限公司| 国内精品自线一区二区三区视频| 国产成人综合欧美精品久久| 久久综合国产精品台湾中文娱乐网| 欧美三级午夜理伦三级在线观看 | 久久精品中文字幕一区| 亚洲欧美tv|