DanaR Stats react on touch elsewhere
This commit is contained in:
parent
33bb7d80a6
commit
377a55c69f
1 changed files with 26 additions and 7 deletions
|
@ -7,6 +7,7 @@ import android.content.Intent;
|
||||||
import android.content.ServiceConnection;
|
import android.content.ServiceConnection;
|
||||||
import android.content.SharedPreferences;
|
import android.content.SharedPreferences;
|
||||||
import android.graphics.Color;
|
import android.graphics.Color;
|
||||||
|
import android.graphics.Rect;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.os.Handler;
|
import android.os.Handler;
|
||||||
import android.os.HandlerThread;
|
import android.os.HandlerThread;
|
||||||
|
@ -15,6 +16,7 @@ import android.preference.PreferenceManager;
|
||||||
import android.support.v7.widget.LinearLayoutManager;
|
import android.support.v7.widget.LinearLayoutManager;
|
||||||
import android.text.TextUtils;
|
import android.text.TextUtils;
|
||||||
import android.view.KeyEvent;
|
import android.view.KeyEvent;
|
||||||
|
import android.view.MotionEvent;
|
||||||
import android.view.View;
|
import android.view.View;
|
||||||
import android.view.WindowManager;
|
import android.view.WindowManager;
|
||||||
import android.view.inputmethod.EditorInfo;
|
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() {
|
ServiceConnection mConnection = new ServiceConnection() {
|
||||||
|
|
||||||
public void onServiceDisconnected(ComponentName name) {
|
public void onServiceDisconnected(ComponentName name) {
|
||||||
|
@ -293,14 +310,8 @@ public class DanaRStatsActivity extends Activity {
|
||||||
@Override
|
@Override
|
||||||
public boolean onEditorAction(TextView v, int actionId, KeyEvent event) {
|
public boolean onEditorAction(TextView v, int actionId, KeyEvent event) {
|
||||||
if(actionId== EditorInfo.IME_ACTION_DONE){
|
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();
|
totalBaseBasal.clearFocus();
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -311,6 +322,14 @@ public class DanaRStatsActivity extends Activity {
|
||||||
public void onFocusChange(View v, boolean hasFocus) {
|
public void onFocusChange(View v, boolean hasFocus) {
|
||||||
if(hasFocus){
|
if(hasFocus){
|
||||||
totalBaseBasal.getText().clear();
|
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);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
Loading…
Reference in a new issue