Вы, вероятно, уже нашли ответ на эту проблему, но я искал, как решить эту проблему, и до сих пор не могу найти именно то, что искал, поэтому я решил опубликовать его здесь.
Я сделал следующее (это очень обобщенно, цель - дать вам представление о том, как действовать, копирование и вставка всего кода не сработает O: D):
Сначала создайте EditText и любые другие представления, которые вы хотите использовать в своей программе, в одном представлении. В моем случае я использовал LinearLayout, чтобы обернуть все.
<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>
Затем в вашем коде вы должны установить Touch Listener для вашего основного LinearLayout.
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;
}
});
Я надеюсь, что это поможет некоторым людям. Или, по крайней мере, помогает им начать решать свою проблему.