您好,登錄后才能下訂單哦!
基于回調的事件模型:事件源與事件監聽是統一的,事件由事件源本身處理。
基于回調的事件處理適合于應付那種事件處理邏輯比較固定的VIew。
Android最先觸發控件上綁定的事件監聽器。
使用回調機制處理GUI組件上所發生的事件,需要自定義組件類繼承GUI組件類,并重寫該類的事件處理方法來實現。并且在XML文件中使用自定義組件類。
Android為所有GUI組件都提供了一些事件處理的回調方法,如View類:
1.boolean onKeyDown(int keyCode,keyEvent event):當用戶在該組件上按下某個按鍵時觸發該方法。 //鍵碼、事件 對于有鍵盤的適用
2.boolean onKeyLongPress(int keyCode,keyEvent event):當用戶在該組件上長按某個按鍵時觸發該方法。
3.boolean onKeyShortcut(int keyCode,KeyEvent event):當一個鍵盤快捷鍵事件發生時觸發該方法。
4.boolean onKeyUp(int keyCode,KeyEvent event):當用戶在該組件上松開某個按鍵時觸發該方法。
5.boolean onTouchEvent(MotionEvent event):當用戶在該組件上觸發觸摸屏事件時觸發該方法。 //對于觸屏的適用
6.boolean onTrackballEvent(MotionEvent event):當用戶在該組件上觸發軌跡球屏事件時觸發該方法。
當回調方法返回true時,表明該處理方法已經完全處理該事件,該事件不會傳播出去。
當回調方法返回false時,表明該處理方法并未完全處理該事件,該事件會傳播出去。
對于基于回調的事件傳播而言,某組件上所發生的事情不僅會激發該組件上的回調方法,也會觸發該組件所在Activity的回調方法——只要時間能傳播到該Activity。
示例:
activity_main
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical" > <com.example.huidiao.MyButton android:id="@+id/bn" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="按鈕上的觸屏" /> </LinearLayout>
MyButton.java
package com.example.huidiao; public class MyButton extends Button { // AttributeSet是接收xml中定義的屬性信息,這不一定是自定義布局,不是自定義布局也有該屬性,要不xml中定義的屬性信息就無法接收了。 public MyButton(Context context, AttributeSet set) { super(context, set); } // 重寫觸屏事件的回調方法 public boolean onTouchEvent(MotionEvent event) { // 事件 super.onTouchEvent(event); Log.v("按鈕上觸屏事件", "在按鈕上的觸屏,事件源自己處理"); return false; // ② } }
MainActivity.java
package com.example.huidiao; public class MainActivity extends Activity { protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); } // 重寫onTouchEvent方法,該方法可監聽它所包含的所有控件被觸屏事件 public boolean onTouchEvent(MotionEvent event) { // 事件 super.onTouchEvent(event); Log.v("觸屏事件傳遞到Activity", "在自定義按鈕上觸屏,事件在按鈕所在Activity處理"); return true; // ③ } }
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。