欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Android點(diǎn)擊EditText文本框之外任何地方隱藏鍵盤(pán)的解決辦法

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

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

通過(guò)給當(dāng)前界面布局文件的父layout設(shè)置點(diǎn)擊事件(相當(dāng)于給整個(gè)Activity設(shè)置點(diǎn)擊事件),在事件里進(jìn)行鍵盤(pá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)聽(tīng):

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

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

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

通過(guò)dispatchTouchEvent每次ACTION_DOWN事件中動(dòng)態(tài)判斷非EditText本身區(qū)域的點(diǎn)擊事件,然后在事件中進(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); 
  } 
  // 必不可少,否則所有的組件都不會(huì)有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) { 
      // 點(diǎn)擊的是輸入框區(qū)域,保留點(diǎn)擊EditText的事件 
      return false; 
    } else { 
      return true; 
    } 
  } 
  return false; 
} 

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

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

通過(guò)給當(dāng)前界面布局文件的父layout設(shè)置點(diǎn)擊事件(相當(dāng)于給整個(gè)Activity設(shè)置點(diǎn)擊事件),在事件里進(jìn)行鍵盤(pá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)聽(tīng):

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

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

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

通過(guò)dispatchTouchEvent每次ACTION_DOWN事件中動(dòng)態(tài)判斷非EditText本身區(qū)域的點(diǎn)擊事件,然后在事件中進(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); 
  } 
  // 必不可少,否則所有的組件都不會(huì)有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) { 
      // 點(diǎn)擊的是輸入框區(qū)域,保留點(diǎn)擊EditText的事件 
      return false; 
    } else { 
      return true; 
    } 
  } 
  return false; 
} 

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

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

相關(guān)文章

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

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

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

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

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

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

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