中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

ios響應鏈的工作原理是什么

發布時間:2023-05-11 17:48:10 來源:億速云 閱讀:168 作者:iii 欄目:開發技術

今天小編給大家分享一下ios響應鏈的工作原理是什么的相關知識點,內容詳細,邏輯清晰,相信大部分人都還太了解這方面的知識,所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來了解一下吧。

事件響應鏈的工作原理

iOS 中,事件響應鏈的工作原理可以簡單概括為:從最上層的 UIWindow 開始,依次向下傳遞事件,直到找到最適合處理事件的響應者對象為止。在這個過程中,每個響應者對象都有機會處理事件。

當用戶執行一個操作時,如觸摸屏幕或運動設備,系統會創建一個 UIEvent 對象,并將其發送到當前的第一響應者對象。如果第一響應者對象無法處理該事件,則系統會將該事件傳遞給響應者鏈中的下一個對象,直到找到能夠處理該事件的對象。如果最終沒有對象能夠處理該事件,則事件被系統丟棄。

以下是事件響應鏈的示意圖:

         UIWindow
             |
       UIViewController
             |
           UIView
             |
     subviews of UIView

在這個示意圖中,UIWindow 是響應者鏈的起點,它是所有視圖的根視圖。UIViewControllerUIView 都是響應者對象,它們都可以處理事件。UIViewController 可以接收和處理來自其根視圖的事件,而 UIView 可以接收和處理來自其自身的事件,以及來自其子視圖的事件。

響應者對象的特點

響應者對象是一種特殊類型的對象,它們實現了 UIResponder 類。響應者對象可以處理事件,可以成為第一響應者對象,并且可以將事件傳遞給下一個響應者對象。以下是 UIResponder 類中的一些常用方法:

  • canBecomeFirstResponder:返回一個布爾值,指示對象是否可以成為第一響應者對象。

  • becomeFirstResponder:將對象設置為第一響應者對象。

  • resignFirstResponder:放棄第一響應者對象的地位。

  • next:返回響應者鏈中的下一個響應者對象。

響應者對象還可以實現許多方法來處理事件,例如:

  • touchesBegan(_:with:):當用戶在視圖上開始觸摸時調用。

  • touchesMoved(_:with:):當用戶在視圖上移動觸摸時調用。

  • touchesEnded(_:with:):當用戶在視圖上結束觸摸時調用。

  • touchesCancelled(_:with:):當系統取消觸摸事件時調用。

自定義事件處理

Swift 中,可以通過重寫 UIResponder 子類的方法來自定義事件處理。以下是一個示例代碼,展示如何重寫 UIView 子類的 touchesBegan 方法來處理觸摸事件:

class CustomView: UIView {
    override func touchesBegan(_ touches: Set<UITouch>, with event: UIEvent?) {
        super.touchesBegan(touches, with: event)
        
        // 處理觸摸事件
        // ...
    }
}

在這個示例中,當用戶在 CustomView 上開始觸摸時,系統會調用 CustomViewtouchesBegan 方法。在此方法中,開發者可以編寫自己的觸摸事件處理代碼。

事件傳遞和事件響應

事件傳遞和事件響應是事件響應鏈的兩個重要環節。在事件傳遞階段,系統會將事件從上往下傳遞,直到找到最適合處理事件的對象。在事件響應階段,系統會將事件從下往上響應,直到事件被處理或者傳遞到響應者鏈的頂部。

在事件傳遞階段,UIViewUIViewController 都有一個 hitTest( *:with:) 方法,該方法返回一個 UIView 對象。當系統接收到事件時,它會調用 hitTest(* :with:) 方法來確定最適合處理該事件的視圖對象。hitTest( *:with:) 方法首先檢查自己是否能夠處理該事件,如果不能,它會將事件傳遞給其子視圖,并遞歸調用子視圖的 hitTest(* :with:) 方法,直到找到能夠處理該事件的視圖對象。

在事件響應階段,系統會將事件傳遞到第一響應者對象,并沿著響應者鏈向上傳遞,直到事件被處理或者傳遞到響應者鏈的頂部。在這個過程中,每個響應者對象都有機會處理事件。如果某個響應者對象能夠處理事件,則它將調用相應的方法來處理事件,例如 touchesBegan(_:with:) 方法。如果該對象不能處理事件,則它將調用 next 方法,將事件傳遞給響應者鏈中的下一個對象。

事件攔截

hitTest(_:with:) 方法中,我們可以檢查觸摸點是否在指定區域內,如果在,則返回當前視圖作為攔截目標,否則返回 nil,讓系統將事件傳遞給下一個響應者。示例代碼如下:

class CustomView: UIView {
    
    override func hitTest(_ point: CGPoint, with event: UIEvent?) -> UIView? {
        if self.bounds.contains(point) {
            // 觸摸點在視圖內,攔截事件
            return self
        } else {
            // 觸摸點不在視圖內,將事件傳遞給下一個響應者
            return super.hitTest(point, with: event)
        }
    }
    
    override func touchesBegan(_ touches: Set<UITouch>, with event: UIEvent?) {
        super.touchesBegan(touches, with: event)
        print("CustomView touchesBegan")
    }
 
}

在上述代碼中,我們重寫了 hitTest( *:with:) 方法,并在該方法中檢查觸摸點是否在視圖內。如果在,則返回當前視圖作為攔截目標,否則返回 nil,讓系統將事件傳遞給下一個響應者。在 touchesBegan(* :with:) 方法中,我們打印了一條日志,以便在觸摸事件發生時能夠看到該方法是否被調用。

事件傳遞到父視圖

要將事件傳遞到父視圖,可以調用 next?.touchesBegan(touches, with: event) 方法,讓父視圖處理觸摸事件。示例代碼如下:

class CustomView: UIView {
    override func touchesBegan(_ touches: Set<UITouch>, with event: UIEvent?) {
        super.touchesBegan(touches, with: event)
        
        // 處理觸摸事件
        // 如果無法處理該事件,傳遞給父視圖進行處理
        next?.touchesBegan(touches, with: event)
    }
}

class ParentView: UIView {
    override func touchesBegan(_ touches: Set<UITouch>, with event: UIEvent?) {
        super.touchesBegan(touches, with: event)
        
        // 處理觸摸事件
    }
}

在上面的示例中,CustomViewParentView 都是 UIView 的子類。當用戶在 CustomView 上觸摸時,CustomViewtouchesBegan 方法會被調用。在這個方法中,如果 CustomView 無法處理該事件,它會將該事件傳遞給其父視圖(ParentView)進行處理。

通過 next?.touchesBegan(touches, with: event) 方法將事件傳遞給父視圖,如果父視圖能夠處理該事件,它的 touchesBegan 方法將被調用。在這個方法中,可以處理觸摸事件。如果父視圖仍然無法處理該事件,該事件將被傳遞給更高級別的響應對象進行處理。

需要注意的是,當事件被傳遞到下一個響應對象時,會調用該對象的 touchesBegan 方法。因此,在這個方法中,可以對事件進行處理,也可以將其傳遞給更高級別的響應對象進行處理。

自定義事件響應鏈

iOS 中,每個視圖都是一個 UIResponder 對象。UIResponder 是一個抽象類,它定義了響應者對象可以處理的事件類型,包括觸摸事件、加速計事件、遠程控制事件等。每個 UIResponder 對象都有一個 next 響應者,即下一個響應者對象。當一個事件發生時,系統會將該事件從前往后依次傳遞給響應者鏈中的對象,直到某個對象處理了該事件為止。如果沒有任何對象處理該事件,則該事件將被丟棄。

我們可以通過自定義 UIResponder 子類來實現更靈活的事件處理邏輯。下面是一個簡單的自定義響應者鏈的示例代碼:

class CustomResponder: UIResponder {
    
    override func touchesBegan(_ touches: Set<UITouch>, with event: UIEvent?) {
        super.touchesBegan(touches, with: event)
        print("CustomResponder touchesBegan")
        next?.touchesBegan(touches, with: event)
    }
    
}

class ViewController: UIViewController {
    
    override func touchesBegan(_ touches: Set<UITouch>, with event: UIEvent?) {
        super.touchesBegan(touches, with: event)
        print("ViewController touchesBegan")
    }
    
}

在上面的代碼中,我們定義了一個名為 CustomResponder 的自定義響應者子類。在該類中,我們重寫了 touchesBegan(_:with:) 方法,并在該方法中打印了一條日志。在該方法中,我們還調用了 next?.touchesBegan(touches, with: event) 方法,將觸摸事件傳遞給下一個響應者對象。

在 ViewController 中,我們也重寫了 touchesBegan( *:with:) 方法,并在該方法中打印了一條日志。當觸摸事件發生時,首先會調用 CustomRespondertouchesBegan(* :with:) 方法,并打印出 "CustomResponder touchesBegan"。然后,由于我們調用了 next?.touchesBegan(touches, with: event) 方法,系統會將觸摸事件傳遞給 CustomResponder 的下一個響應者對象,即 ViewController。此時,系統會調用 ViewControllertouchesBegan(_:with:) 方法,并打印出 "ViewController touchesBegan"。

通過自定義響應者子類,我們可以更加靈活地處理事件,實現更復雜的事件處理邏輯。例如,我們可以在響應者鏈中添加多個響應者對象,根據事件類型、觸摸點位置等條件來決定哪個響應者對象處理該事件。

以上就是“ios響應鏈的工作原理是什么”這篇文章的所有內容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會為大家更新不同的知識,如果還想學習更多的知識,請關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

ios
AI

博兴县| 水富县| 黔东| 汉沽区| 昭通市| 磐石市| 永平县| 吕梁市| 聂拉木县| 阿拉善左旗| 德钦县| 临汾市| 宁都县| 工布江达县| 普洱| 托克逊县| 敦化市| 扶沟县| 蒙阴县| 苍山县| 峡江县| 厦门市| 元氏县| 日喀则市| 砚山县| 兴山县| 资溪县| 墨江| 武冈市| 忻州市| 阜康市| 肥城市| 和林格尔县| 灵武市| 克东县| 马龙县| 富裕县| 宁津县| 江北区| 吉木萨尔县| 龙门县|