1. 程式人生 > >Android點選EditText文字框之外任何地方隱藏鍵盤的解決辦法

Android點選EditText文字框之外任何地方隱藏鍵盤的解決辦法

1,實現方法一:通過給當前介面佈局檔案的父layout設定點選事件(相當於給整個Activity設定點選事件),在事件裡進行鍵盤隱藏

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/traceroute_rootview"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:background="@color/white"
    android:clickable="true"
    android:gravity="center_horizontal"
    android:orientation="vertical" >

</LinearLayout>
加上id和clickable=true

然後在onCreate裡,新增onClick事件的監聽:

findViewById(R.id.traceroute_rootview).setOnClickListener(this);
在onClick中:
	@Override
	public void onClick(View v) {
		switch (v.getId()) {
		case R.id.traceroute_rootview:
			 InputMethodManager imm = (InputMethodManager)
			 getSystemService(Context.INPUT_METHOD_SERVICE);
			 imm.hideSoftInputFromWindow(v.getWindowToken(), 0);
			break;
		}

	}

這樣就可以完美的解決了輸入框外的隱藏效果,對於佈局不是特別複雜或是其它觸控事件少的情況下可以使用。

2,實現思路二:通過dispatchTouchEvent每次ACTION_DOWN事件中動態判斷非EditText本身區域的點選事件,然後在事件中進行遮蔽。

	@Override
	public boolean dispatchTouchEvent(MotionEvent ev) {
		if (ev.getAction() == MotionEvent.ACTION_DOWN) {
			View v = getCurrentFocus();
			if (isShouldHideInput(v, ev)) {

				InputMethodManager imm = (InputMethodManager) getSystemService(Context.INPUT_METHOD_SERVICE);
				if (imm != null) {
					imm.hideSoftInputFromWindow(v.getWindowToken(), 0);
				}
			}
			return super.dispatchTouchEvent(ev);
		}
		// 必不可少,否則所有的元件都不會有TouchEvent了
		if (getWindow().superDispatchTouchEvent(ev)) {
			return true;
		}
		return onTouchEvent(ev);
	}

isShoudHideInput(View v,MotionEvent e)方法:
	public  boolean isShouldHideInput(View v, MotionEvent event) {
		if (v != null && (v instanceof EditText)) {
			int[] leftTop = { 0, 0 };
			//獲取輸入框當前的location位置
			v.getLocationInWindow(leftTop);
			int left = leftTop[0];
			int top = leftTop[1];
			int bottom = top + v.getHeight();
			int right = left + v.getWidth();
			if (event.getX() > left && event.getX() < right
					&& event.getY() > top && event.getY() < bottom) {
				// 點選的是輸入框區域,保留點選EditText的事件
				return false;
			} else {
				return true;
			}
		}
		return false;
	}
這種方法實現起來比較麻煩,解決思路與iOS中的事件分發機制是類似,對於處理隱藏事件比較清晰,通過層層事件分發,然後判斷是否在需要遮蔽的區域。