Обрабатывать ToggleButton в onResume()
Я написал программу, в которой я использую Timer
и контролировать этот таймер с помощью Toggle
состояния.
Toggle's
состояние по умолчанию OFF
после внесения изменений в состояние переключения из OFF
в ON
Timer
начинается, и когда я снова перехожу на OFF
это останавливает Timer
согласно требованию
Но проблема начинается, когда мой Timer
является ON
и я переключаюсь на другую деятельность, а затем снова come back
в ToggleActivity
а затем сделать изменения в состоянии переключения из ON
в OFF
- это все еще работает Timer
...
Примечание: когда я использую finish()
или же back
нажмите, вместо Intent
вернуться к ToggleActivity
все работает нормально, но когда пользуюсь Intent
сталкиваются с такими проблемами..
ToggleActivity.java:
public class ToggleActivity extends Activity implements OnCheckedChangeListener {
ToggleButton toggleButton;
TextView text;
Timer timer;
TimerTask timerTask;
final Handler handler = new Handler();
Button btnSwitchActivity;
boolean toggleState;
SharedPreferences sharedPreferences;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_toggle);
toggleButton = (ToggleButton) findViewById(R.id.toggleButton);
text = (TextView) findViewById(R.id.textView1);
btnSwitchActivity = (Button) findViewById(R.id.btnSwitchActivity);
sharedPreferences = getApplicationContext().getSharedPreferences("toggleState",0);
btnSwitchActivity.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
// TODO Auto-generated method stub
Intent intentSwitchActivity = new Intent(ToggleActivity.this, SwitchActivity.class);
startActivity(intentSwitchActivity);
}
});
}
@Override
public void onCheckedChanged(CompoundButton arg0, boolean isChecked) {
if(isChecked)
{
SharedPreferences.Editor editor = sharedPreferences.edit();
editor.putBoolean("toggleState", true);
editor.commit();
text.setText("ON");
startTimer();
} else
{
SharedPreferences.Editor editor = sharedPreferences.edit();
editor.putBoolean("toggleState", false);
editor.commit();
text.setText("OFF");
if (timer != null) {
timer.cancel();
timer = null;
}
}
}
public void startTimer() {
timer = new Timer();
initializeTimerTask();
timer.schedule(timerTask, 1000, 5000);
}
public void stoptimertask(View v) {
if (timer != null) {
timer.cancel();
timer = null;
}
}
public void initializeTimerTask() {
timerTask = new TimerTask() {
public void run() {
handler.post(new Runnable() {
public void run() {
Calendar calendar = Calendar.getInstance();
SimpleDateFormat simpleDateFormat = new SimpleDateFormat("dd:MMMM:yyyy HH:mm:ss a");
final String strDate = simpleDateFormat.format(calendar.getTime());
int duration = Toast.LENGTH_SHORT;
Toast toast = Toast.makeText(getApplicationContext(), strDate, duration);
toast.show();
}
});
}
};
}
public void onResume() {
super.onResume();
toggleState = sharedPreferences.getBoolean("toggleState", false);
Log.v("toggleState", Boolean.toString(toggleState));
if (toggleState) {
toggleButton.setChecked(true);
text.setText("ON");
} else {
toggleButton.setChecked(false);
text.setText("OFF");
}
toggleButton.setChecked(toggleState);
toggleButton.setOnCheckedChangeListener(this);
}
@Override
protected void onPause() {
super.onPause();
toggleButton.setOnCheckedChangeListener(null);
}
}
SwitchActivity.java
public class SwitchActivity extends Activity {
Button btnToggleActivity;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_switch);
btnToggleActivity = (Button) findViewById(R.id.btnToggleActivity);
btnToggleActivity.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
// TODO Auto-generated method stub
Intent intent = new Intent(SwitchActivity.this, ToggleActivity.class);
startActivity(intent);
/**
* if i use finish instead of Intent to switch to ToggleActivity
* my Timer works fine
*/
// finish
}
});
}
}
activity_toggle.xml
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:gravity="center"
android:background="#ffffff"
android:paddingTop="@dimen/activity_vertical_margin"
android:orientation="vertical"
tools:context=".ToggleActivity" >
<ToggleButton
android:id="@+id/toggleButton"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:background="@drawable/toggle_selector"
android:checked="false"
android:text=""
android:textOff=""
android:textOn="" />
<TextView
android:id="@+id/textView1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="20dp"
android:layout_marginBottom="20dp"
android:text="@string/string_toggle_off"
android:textAppearance="?android:attr/textAppearanceMedium" />
<Button
android:id="@+id/btnSwitchActivity"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/string_btn_switch"/>
</LinearLayout>
activity_switch.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:gravity="center"
android:background="#ffffff"
android:orientation="vertical" >
<Button
android:id="@+id/btnToggleActivity"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/string_btn_goback"
/>
</LinearLayout>
5 ответов
"Но проблема начинается, когда мой таймер включен, и я переключаюсь на другую активность, а затем снова возвращаюсь к активности переключения"...
Вы не вернетесь. Как сказал @Fabin Paul, вы просто создаете новый экземпляр ToggleActivity
, Таким образом, в сценарии, когда вы запускаете приложение, затем перейдите к SwitchActivity
и обратно, нажав кнопку, задний стек выглядит следующим образом:
ToggleActivity(1) -> SwitchActivity -> ToggleActivity(2)
"... а затем сделать изменения в состоянии переключения с ВКЛ на ВЫКЛ - он все еще работает Таймер..."
Вы выключаете таймер второго экземпляра ToggleActivity. Тот, который работает, принадлежит первому экземпляру ToggleActivity.
"Когда я использую Finish() или жму назад, вместо" Намерения "вернуться в ToggleActivity все работает нормально..."
Да, это так, потому что вы не создаете второй экземпляр ToggleActivity
и ваша логика работает правильно.
Самый простой способ получить желаемое поведение - это добавить android:launchMode="singleInstance"
на тег манифеста ToggleActivity.
Я предполагаю, что проблема в том, что для каждого экземпляра действия создается экземпляр таймера. Поэтому, когда вы нажимаете "Стоп", останавливается только один экземпляр таймера, в то время как экземпляр таймера фоновой активности не останавливается.
Я обошёл проблему, сделав таймер статичным
static Timer timer;
и запуск только одного экземпляра таймера
public void startTimer() {
if (timer == null) {
timer = new Timer();
initializeTimerTask();
timer.schedule(timerTask, 1000, 5000);
}
}
Я надеюсь, что это помогает...
Когда ToggleActivity
переключается на onPause
состояние, это не отменяет работу Timer
, Вы должны отменить это вручную.
Вы можете добавить следующий фрагмент кода в свой onPause()
метод:
if (timerTask != null)
timerTask.cancel();
if (timer != null) {
timer.cancel();
timer = null;
}
Назначьте слушателя на кнопку переключения после проверки состояния.
Просто удалите:
toggleMap.setOnCheckedChangeListener(this);
линия в onCreate
и добавить ту же строку в onResume
после обновления статуса.
toggleMap.setOnCheckedChangeListener(this);
И в onPause()
:
toggleMap.setOnCheckedChangeListener(null);
как это:
@Override
protected void onResume() {
super.onResume();
tg1pref = preferences.getBoolean("tg1pref", false);
if (!tg1pref) {
if (timer != null) {
timer.cancel();
timer = null;
}
}
toggleMap.setChecked(tg1pref);
toggleMap.setOnCheckedChangeListener(this);
}
а также:
@Override
protected void onPause() {
super.onPause();
toggleMap.setOnCheckedChangeListener(null);
}
Вот ты звонишь setChecked(true)
средства onCheckedChangeListener
будет вызывать, а затем обновить предпочтение, вы должны удалить слушателя и установить слушателя на кнопку переключения, как это:
toggleMap.setOnCheckedChangeListener(null);
toggleMap.setChecked(isChecked);
toggleMap.setOnCheckedChangeListener(this);
РЕДАКТИРОВАТЬ
@Override
protected void onResume() {
super.onResume();
tg1pref = preferences.getBoolean("tg1pref", false);
toggleMap.setOnCheckedChangeListener(null);
toggleMap.setChecked(tg1pref);
toggleMap.setOnCheckedChangeListener(this);
if (!tg1pref) {
if (timer != null) {
timer.cancel();
timer = null;
}
}
}
а также
@Override
protected void onPause() {
toggleMap.setOnCheckedChangeListener(null);
super.onPause();
}