iOS 9應用開發教程之ios9中實現按鈕的響應

來源:互聯網
上載者:User

標籤:

iOS 9應用開發教程之ios9中實現按鈕的響應IOS9實現按鈕的響應

按鈕主要是實現使用者互動的,即實現響應。按鈕實現響應的方式可以根據添加按鈕的不同分為兩種:一種是編輯介面添加按鈕實現的響應;另一種是使用代碼添加按鈕實現的響應。

1.編輯介面添加按鈕實現的響應

使用編輯介面添加按鈕可以使用拖動的方式來實現按鈕的響應,它也是最簡單的一種實現響應的方式。

【樣本2-4】以下將實現輕拍按鈕,改變主視圖背景顏色的功能。具體的操作步驟如下:

(1)建立一個Single View Application模板類型的項目,命名為UIButton-response。

(2)開啟Main.storyboard檔案,將主視圖的尺寸設定為iPhone 4.7-inch。從視圖庫中拖動按鈕控制項到主視圖中,將Title設定為Tap me,Change View Color。

(3)使用設定編輯器的三個視圖方式的表徵圖,將Xcode的介面調整為2.5所示的效果。這一過程在前面的章節中講解過。

 

圖2.5  調整Xcode的介面

(4)按住Ctrl鍵拖動介面中的按鈕對象,這時會出現一個藍色的線條,將這個藍色的線條拖動到ViewController.swift檔案的空白處中,2.6所示。

 

圖2.6  按住Ctrl鍵拖動介面中的按鈕對象

(5)鬆開滑鼠後,會彈出聲明關聯插座變數一起進行的對話方塊(在前面章節中講解過),2.7所示。

 

圖2.7  彈出聲明關聯插座變數一起進行的對話方塊

(6)將Connection選項設定為Action,表示關聯的是一個動作;將Name設定為tapButton,表示關聯的動作名為tapButton,2.8所示。

 

圖2.8  填寫對話方塊

注意:這裡的Name可以是任意的。

(7)單擊Connect按鈕,會在ViewController.swift檔案中看到2.9所示的代碼。

 

圖2.9  動作

此時,當使用者輕拍按鈕後,一個叫tapButton()的方法就會被觸發。

注意:以上這一種方式是動作聲明和關聯一起進行的,還有一種先聲明動作後關聯的方式。聲明動作可以使用關鍵字IBAction。該關鍵字可以告訴故事面板的介面,此方法是一個操作,且可以被某個控制項觸發。聲明動作的文法形式如下:

 

  • @IBAction func 動作名(參數:參數類型){
  • }

 

2.10所示,就是在ViewController.swift檔案中編寫的動作的聲明代碼。

 

圖2.10  聲明的動作

注意:在聲明動作後,會在代碼的前面出現一個空心的小圓圈,它表示此動作還未進行關聯。

聲明好動作後,就可以進行關聯了,首先使用調整視窗中的工具,將Xcode的介面進行調整。將其調整為和圖2.5一樣的效果。

然後,按住Ctrl鍵拖動介面中的按鈕對象,這時會出現一個藍色的線條,將這個藍色的線條和檔案ViewController.swift中的動作進行關聯,2.11所示。

 

圖2.11  關聯動作

最後,鬆開滑鼠後,按鈕對象就與動作成功的關聯在一起了,此時動作前面的空心小圓圈就變為了實心的小圓圈,它表示此動作已被關聯,效果和圖2.9一樣。

(8)開啟ViewController.swift檔案,編寫代碼,此代碼將實現按鈕的響應。代碼如下:

 

  • import UIKit
  • class ViewController: UIViewController {
  •     var isYellow:Bool=false
  • @IBAction func tapButton(sender: AnyObject) {
  •     //判斷主視圖的背景是否為黃色
  •         if(isYellow){
  •             self.view.backgroundColor=UIColor.whiteColor()                                 //設定主視圖的背景顏色
  •             isYellow=false
  •         }else{
  •             self.view.backgroundColor=UIColor.yellowColor()
  •             isYellow=true
  •         }
  •     }
  • ……
  • }

 

此時運行程式,首先會看到2.12的效果。當輕拍Tap me,Change View Color按鈕後,主視圖的背景變為黃色,2.13所示。當再一次輕拍Tap me,Change View Color按鈕,主視圖的背景顏色將會變回原來的白色。

 

圖2.12  運行效果                              圖2.13  運行效果

2.使用代碼添加按鈕實現的響應

使用代碼添加的按鈕,實現響應需要使用到addTarget(_:action:forControlEvents:)方法,其文法形式如下:

 

  • func addTarget(_ target: AnyObject?,
  •           action action: Selector,
  • forControlEvents controlEvents: UIControlEvents)

 

其中,參數說明如下:

 

  •   target:表示目標對象。它是動作訊息的發送方。
  •   action:表示選取器,用來識別動作訊息。它不可以為空白。
  •   controlEvents:表示控制項事件。在iOS中有19種控制項事件,如表2-4所示。

 

表2-4  控制項事件

 

【樣本2-5】以下將實現輕拍按鈕,改變主視圖背景顏色的功能。代碼如下:

 

  • import UIKit
  • class ViewController: UIViewController {
  •     var isCyan:Bool=false
  •     override func viewDidLoad() {
  •         super.viewDidLoad()
  •         // Do any additional setup after loading the view, typically from a nib.
  •         //添加按鈕對象
  •         let button=UIButton(frame: CGRectMake(90, 545, 225, 30))
  •         button.setTitle("Tap me,Change View Color", forState: UIControlState.Normal)  //設定按鈕的標題
  •         button.setTitleColor (UIColor.blackColor(), forState: UIControlState.Normal)   //設定按鈕標題的顏色
  •         self.view.addSubview(button)
  •         //實現按鈕的響應
  •         button.addTarget(self, action: "tapbutton", forControlEvents: UIControlEvents.TouchUpInside)
  • }
  • func tapbutton(){
  • //判斷主視圖的背景顏色是否為青色
  •         if(isCyan){
  •             self.view.backgroundColor=UIColor.whiteColor()
  •             isCyan=false
  •         }else{
  •             self.view.backgroundColor=UIColor.cyanColor()
  •             isCyan=true
  •         }
  •     }
  • ……
  • }

 

此時運行程式,首先會看到2.14的效果。當輕拍Tap me,Change View Color按鈕後,主視圖的背景變為青色,2.15所示。當再一次輕拍Tap me,Change View Color按鈕,主視圖的背景顏色將會變回原來的白色。

 

圖2.14  運行效果                                 圖2.15  運行效果

本文選自:iOS 9應用開發基礎教程大學霸內部資料,轉載請註明出處,尊重技術尊重IT人!

iOS 9應用開發教程之ios9中實現按鈕的響應

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.