From 377a55c69f596becc6fa25a679c3f43bd743a988 Mon Sep 17 00:00:00 2001 From: AdrianLxM Date: Fri, 20 Jan 2017 20:33:41 +0100 Subject: [PATCH] DanaR Stats react on touch elsewhere --- .../DanaR/History/DanaRStatsActivity.java | 33 +++++++++++++++---- 1 file changed, 26 insertions(+), 7 deletions(-) diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/DanaR/History/DanaRStatsActivity.java b/app/src/main/java/info/nightscout/androidaps/plugins/DanaR/History/DanaRStatsActivity.java index 5e6d2b2c3b..0b218cddaa 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/DanaR/History/DanaRStatsActivity.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/DanaR/History/DanaRStatsActivity.java @@ -7,6 +7,7 @@ import android.content.Intent; import android.content.ServiceConnection; import android.content.SharedPreferences; import android.graphics.Color; +import android.graphics.Rect; import android.os.Bundle; import android.os.Handler; import android.os.HandlerThread; @@ -15,6 +16,7 @@ import android.preference.PreferenceManager; import android.support.v7.widget.LinearLayoutManager; import android.text.TextUtils; import android.view.KeyEvent; +import android.view.MotionEvent; import android.view.View; import android.view.WindowManager; import android.view.inputmethod.EditorInfo; @@ -111,6 +113,21 @@ public class DanaRStatsActivity extends Activity { } } + @Override + public boolean dispatchTouchEvent(MotionEvent event) { + if (event.getAction() == MotionEvent.ACTION_DOWN) { + View myView = getCurrentFocus(); + if ( myView instanceof EditText) { + Rect rect = new Rect(); + myView.getGlobalVisibleRect(rect); + if (!rect.contains((int)event.getRawX(), (int)event.getRawY())) { + myView.clearFocus(); + } + } + } + return super.dispatchTouchEvent( event ); + } + ServiceConnection mConnection = new ServiceConnection() { public void onServiceDisconnected(ComponentName name) { @@ -293,14 +310,8 @@ public class DanaRStatsActivity extends Activity { @Override public boolean onEditorAction(TextView v, int actionId, KeyEvent event) { if(actionId== EditorInfo.IME_ACTION_DONE){ - SharedPreferences.Editor edit = preferences.edit(); - edit.putString("TBB",totalBaseBasal.getText().toString()); - edit.commit(); - TBB = preferences.getString("TBB", ""); - loadDataFromDB(RecordTypes.RECORD_TYPE_DAILY); - InputMethodManager imm = (InputMethodManager) getSystemService(INPUT_METHOD_SERVICE); - imm.hideSoftInputFromWindow(getCurrentFocus().getWindowToken(), 0); totalBaseBasal.clearFocus(); + return true; } return false; } @@ -311,6 +322,14 @@ public class DanaRStatsActivity extends Activity { public void onFocusChange(View v, boolean hasFocus) { if(hasFocus){ totalBaseBasal.getText().clear(); + } else { + SharedPreferences.Editor edit = preferences.edit(); + edit.putString("TBB",totalBaseBasal.getText().toString()); + edit.commit(); + TBB = preferences.getString("TBB", ""); + loadDataFromDB(RecordTypes.RECORD_TYPE_DAILY); + InputMethodManager imm = (InputMethodManager) getSystemService(INPUT_METHOD_SERVICE); + imm.hideSoftInputFromWindow(totalBaseBasal.getWindowToken(), 0); } } });