我试图创建一个简单的Tap Counter应用程序,但是在移至onFinish()之前,最后却出现了明显的滞后,在停止计数器之前为用户提供了一些额外的点击。
这是MainActivity.java
package com.example.tapcounter;
import android.os.Bundle;
import android.os.CountDownTimer;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.TextView;
import android.app.Activity;
public class MainActivity extends Activity
{
TextView time;
TextView taps;
Button b;
int flag = 0;
int count = 0, finalTap = 0;
@Override
protected void onCreate(Bundle savedInstanceState)
{
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
time = (TextView) findViewById(R.id.textView1);
taps = (TextView) findViewById(R.id.textView2);
b = (Button) findViewById(R.id.button1);
b.setOnClickListener(new OnClickListener()
{
@Override
public void onClick(View arg0)
{
if(finalTap==0)
{
if(flag==0)
{
beginTimer();
flag=1;
}
updateCount();
}
}
});
}
private void beginTimer()
{
new CountDownTimer(10000, 1000)
{
public void onTick(long millisUntilFinished)
{
time.setText("Time: "+millisUntilFinished/1000);
}
public void onFinish()
{
time.setText("Timeout!!!");
finalTap++;
}
}.start();
}
private void updateCount()
{
taps.setText("Taps: " + Integer.toString(++count));
}
}
最佳答案
首先,您是如何运行应用程序的?我注意到,当我以Debug模式运行应用程序时,Debugger占用了我的移动设备50%的性能。因此,如果您仅运行您的应用,onFinish的运行速度会更快。
第二点是在onTick方法中手动检测超时,一段时间后使用布尔值阻止抽头
private boolean tapBlock = false;
private void beginTimer()
{
new CountDownTimer(10100, 1000)
{
public void onTick(long millisUntilFinished)
{
if (!tapBlock)
{
time.setText("Time: "+millisUntilFinished/1000);
if (millisUntilFinished<100)
{
tapBlock = true;
}
}
}
public void onFinish()
{
time.setText("Timeout!!!");
finalTap++;
tapBlock = false;
}
}.start();
}
这有点问题,但可能更快,您必须在更新方法中添加“ tapBlock”
关于android - Android:在CountDownTimer中的onFinish()之前延迟,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/25815230/