Android onResume()中的句柄切换按钮
我已经编写了一个程序,其中我使用Android onResume()中的句柄切换按钮,android,android-activity,android-lifecycle,back-stack,android-togglebutton,Android,Android Activity,Android Lifecycle,Back Stack,Android Togglebutton,我已经编写了一个程序,其中我使用定时器并使用切换状态控制定时器 切换的默认状态为关闭,一旦我将切换状态从关闭更改为打开计时器启动,当我再次更改为关闭时,它会根据需要停止计时器 但当我的定时器打开时,问题就开始了,我切换到其他活动,然后再次返回到切换活动,然后切换状态从打开到关闭-它仍然运行定时器 注意:当我使用finish()或back时,按下以代替Intent返回toggleavity时,一切正常,但当我使用Intent时,面对这样的问题 ToggleActivity.java: public
定时器
并使用切换
状态控制定时器
切换的默认状态为关闭
,一旦我将切换状态从关闭
更改为打开
计时器
启动,当我再次更改为关闭
时,它会根据需要停止计时器
但当我的定时器
打开时,问题就开始了,我切换到其他活动,然后再次返回到切换活动
,然后切换状态从打开
到关闭
-它仍然运行定时器
注意:当我使用finish()
或back
时,按下以代替Intent
返回toggleavity
时,一切正常,但当我使用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
}
});
}
}
活动\u 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>
<?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>
activity\u switch.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>
<?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>
这里您正在调用setChecked(true)
意味着一旦checkedChangeListener
将调用,然后更新首选项,您必须删除侦听器并将侦听器设置为切换按钮,如下所示:
toggleMap.setOnCheckedChangeListener(null);
toggleMap.setChecked(isChecked);
toggleMap.setOnCheckedChangeListener(this);
@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 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;
}
}
}
及
检查状态后,将侦听器分配给切换按钮
只需删除:
toggleMap.setOnCheckedChangeListener(this);
更新状态后,onCreate
中的行,并在onResume
中添加相同的行
toggleMap.setOnCheckedChangeListener(this);
在onPause()
中:
像这样:
toggleMap.setOnCheckedChangeListener(null);
toggleMap.setChecked(isChecked);
toggleMap.setOnCheckedChangeListener(this);
@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);
}
以及:
当ToggleActivity
切换到onPause
状态时,它不会取消正在运行的计时器。你需要手动取消它
您可以在onPause()
方法中添加以下代码段:
if (timerTask != null)
timerTask.cancel();
if (timer != null) {
timer.cancel();
timer = null;
}
我猜问题是因为每个活动实例都创建了一个计时器实例。因此,当您按下stop键时,只有一个计时器实例停止,而后台活动的计时器实例未停止
我把计时器设为静态,从而避开了这个问题
static Timer timer;
并且只启动计时器的一个实例
public void startTimer() {
if (timer == null) {
timer = new Timer();
initializeTimerTask();
timer.schedule(timerTask, 1000, 5000);
}
}
我希望这会有帮助…“但当我的计时器打开,我切换到其他活动,然后再次返回切换活动时,问题就开始了”
你不回来了。正如@Fabin Paul提到的,您只需创建一个新的ToggleActivity
实例。因此,在场景中,当您启动应用程序,然后移动到SwitchActivity
,然后单击按钮返回,结果如下所示:
切换活动(1)->切换活动->切换活动(2)
“…然后在切换状态中从ON切换到OFF-它仍然运行计时器…”
关闭第二个TogleActivity实例的计时器。正在运行的属于第一个TogleActivity的实例
“当我使用finish();或back press时,为了避免返回到ToggleActivity,一切正常…”
是的,确实如此,因为您没有创建ToggleActivity
的第二个实例,并且您的逻辑工作正常
获取所需行为的最简单方法是添加到清单的ToggleActivity标记中 请检查我发布的代码,仍然得到相同的问题全部不起作用,甚至没有保存切换状态在onPause()方法中删除onCheckedChangeLister。bro我没有使用onPause()我尝试了你的方法,甚至没有保存切换状态我编辑了我的答案检查了一次,不幸的是,我删除了列表器设置功能之间的一行。我很困惑。你能告诉我必须在哪里输入onResume()以及为什么要在onPause()中输入吗?是否已解决?请先告诉我,然后我将解释该方案。确定我会尝试一下他们。。。有一段时间,它显示了确切的状态,但在同一个问题之后,请告诉我们,setText
的行为是否正确(如您所期望的时间),还是像时间一样行为不当?@NeilTownsend检查我更新的代码和屏幕。您不想使用finish的原因是什么?如果没有充分的理由不这样做,那么这似乎是正确的方法。但我不想取消计时器,但你说,它一直在运行,这是你的问题?然后做一件事,在stoptimertask(View v)函数中添加上述代码。然后再试一次。`if(toggleState){toggleButton.setChecked(true);text.setText(“ON”);}else{text.setText(“OFF”);toggleButton.setChecked(false);}``文本可见性不是问题,问题在于何时关闭它运行时间这是核心问题。我只想补充一点,另一种解决方案是使用finish,正如您在更新的问题中所指出的那样。@Onik inclusible:)您是高手。。感谢每一个帮助我的人