android(基於回調)的事件處理


    基於回調的事件模型:事件源與事件監聽是統一的,事件由事件源自己處理。
java

    基於回調的事件處理適合於應付那種事件處理邏輯比較固定的VIew。
android

    Android最早觸發控件上綁定的事件監聽器。
ide


    使用回調機制處理GUI組件上所發生的事件,須要自定義組件類繼承GUI組件類,並重寫該類的事件處理方法來實現。而且在XML文件中使用自定義組件類。
佈局


    Android爲全部GUI組件都提供了一些事件處理的回調方法,如View類:
ui

     1.boolean onKeyDown(int keyCode,keyEvent event):當用戶在該組件上按下某個按鍵時觸發該方法。            //鍵碼、事件   對於有鍵盤的適用xml

    2.boolean onKeyLongPress(int keyCode,keyEvent event):當用戶在該組件上長按某個按鍵時觸發該方法。
繼承

    3.boolean onKeyShortcut(int keyCode,KeyEvent event):當一個鍵盤快捷鍵事件發生時觸發該方法。
事件

    4.boolean onKeyUp(int keyCode,KeyEvent event):當用戶在該組件上鬆開某個按鍵時觸發該方法。
it

    5.boolean onTouchEvent(MotionEvent event):當用戶在該組件上觸發觸摸屏事件時觸發該方法。                //對於觸屏的適用
io

    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; // ③
	}
}
相關文章
相關標籤/搜索