Você provavelmente já encontrou a resposta para este problema, mas estou procurando uma maneira de resolver isso e ainda não consigo encontrar exatamente o que estava procurando, então resolvi postar aqui.
O que fiz foi o seguinte (isso é muito generalizado, o objetivo é dar uma ideia de como proceder, copiar e colar todo o código não vai funcionar O: D):
Primeiro, tenha o EditText e quaisquer outras visualizações que você deseja em seu programa envolvidas por uma única visualização. No meu caso, usei um LinearLayout para embrulhar tudo.
<LinearLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/mainLinearLayout">
<EditText
android:id="@+id/editText"/>
<ImageView
android:id="@+id/imageView"/>
<TextView
android:id="@+id/textView"/>
</LinearLayout>
Então, em seu código, você deve definir um Touch Listener para seu LinearLayout principal.
final EditText searchEditText = (EditText) findViewById(R.id.editText);
mainLinearLayout.setOnTouchListener(new View.OnTouchListener() {
@Override
public boolean onTouch(View v, MotionEvent event) {
// TODO Auto-generated method stub
if(searchEditText.isFocused()){
if(event.getY() >= 72){
//Will only enter this if the EditText already has focus
//And if a touch event happens outside of the EditText
//Which in my case is at the top of my layout
//and 72 pixels long
searchEditText.clearFocus();
InputMethodManager imm = (InputMethodManager) v.getContext().getSystemService(Context.INPUT_METHOD_SERVICE);
imm.hideSoftInputFromWindow(v.getWindowToken(), 0);
}
}
Toast.makeText(getBaseContext(), "Clicked", Toast.LENGTH_SHORT).show();
return false;
}
});
Espero que isso ajude algumas pessoas. Ou pelo menos os ajuda a começar a resolver seus problemas.