亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

 更新時間:2017年01月23日 15:54:46   作者:qq_34378183  
這篇文章主要介紹了Android點擊EditText文本框之外任何地方隱藏鍵盤的解決辦法,非常不錯,具有參考借鑒價值,需要的朋友可以參考下

1,實現(xiàn)方法一:

通過給當(dāng)前界面布局文件的父layout設(shè)置點擊事件(相當(dāng)于給整個Activity設(shè)置點擊事件),在事件里進(jìn)行鍵盤隱藏

<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事件的監(jiān)聽:

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; 
  } 
}

這樣就可以完美的解決了輸入框外的隱藏效果,對于布局不是特別復(fù)雜或是其它觸摸事件少的情況下可以使用。

2,實現(xiàn)思路二:

通過dispatchTouchEvent每次ACTION_DOWN事件中動態(tài)判斷非EditText本身區(qū)域的點擊事件,然后在事件中進(jìn)行屏蔽。

@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 }; 
    //獲取輸入框當(dāng)前的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) { 
      // 點擊的是輸入框區(qū)域,保留點擊EditText的事件 
      return false; 
    } else { 
      return true; 
    } 
  } 
  return false; 
} 

這種方法實現(xiàn)起來比較麻煩,解決思路與iOS中的事件分發(fā)機制是類似,對于處理隱藏事件比較清晰,通過層層事件分發(fā),然后判斷是否在需要屏蔽的區(qū)域。

1,實現(xiàn)方法一:

通過給當(dāng)前界面布局文件的父layout設(shè)置點擊事件(相當(dāng)于給整個Activity設(shè)置點擊事件),在事件里進(jìn)行鍵盤隱藏

<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事件的監(jiān)聽:

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; 
  } 
}

這樣就可以完美的解決了輸入框外的隱藏效果,對于布局不是特別復(fù)雜或是其它觸摸事件少的情況下可以使用。

2,實現(xiàn)思路二:

通過dispatchTouchEvent每次ACTION_DOWN事件中動態(tài)判斷非EditText本身區(qū)域的點擊事件,然后在事件中進(jìn)行屏蔽。

@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 }; 
    //獲取輸入框當(dāng)前的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) { 
      // 點擊的是輸入框區(qū)域,保留點擊EditText的事件 
      return false; 
    } else { 
      return true; 
    } 
  } 
  return false; 
} 

這種方法實現(xiàn)起來比較麻煩,解決思路與iOS中的事件分發(fā)機制是類似,對于處理隱藏事件比較清晰,通過層層事件分發(fā),然后判斷是否在需要屏蔽的區(qū)域。

以上所述是小編給大家介紹的Android點擊EditText文本框之外任何地方隱藏鍵盤的解決辦法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關(guān)文章

  • Android App開發(fā)中自定義View和ViewGroup的實例教程

    Android App開發(fā)中自定義View和ViewGroup的實例教程

    這篇文章主要介紹了Android App開發(fā)中自定義View和ViewGroup的實例教程,分別介紹了進(jìn)度條和圖片上傳并排列的例子,效果很好很強大,需要的朋友可以參考下
    2016-05-05
  • android中實現(xiàn)在ImageView上隨意畫線涂鴉的方法

    android中實現(xiàn)在ImageView上隨意畫線涂鴉的方法

    今天小編就為大家分享一篇android中實現(xiàn)在ImageView上隨意畫線涂鴉的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-10-10
  • Android applicationId和包名的區(qū)別總結(jié)

    Android applicationId和包名的區(qū)別總結(jié)

    這篇文章主要給大家介紹了關(guān)于Android applicationId和包名的區(qū)別,文中通過示例代碼介紹的非常詳細(xì),對各位Android開發(fā)者們具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-06-06
  • 最新評論