我是Android开发的新手,现在我的启动器活动只显示5秒,之后我想检查用户是否已登录或未执行操作并执行操作。
这是我的代码。
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
exactPreferences = getSharedPreferences("ExactPreference",MODE_PRIVATE);
setContentView(R.layout.activity_landing_page);
session = exactPreferences.getString(Model.getSingleton().SHARED_SESSION_ID,null);
Log.i("Session Id",session);
displayData(); // I want to perform this function after 5 seconds.
}
private void displayData() {
if(session.equals("")){
Intent loginIntent = new Intent(LandingPage.this,
LoginActivity.class);
startActivity(loginIntent);
Log.i("User Logged In", "False");
}
else
{
Intent objIntent = new Intent(LandingPage.this,
IndexPageActivity.class);
startActivity(objIntent);
Log.i("User Logged In", "True");
}
}
答案 0 :(得分:65)
您可以使用处理程序添加一些延迟。如下所示调用方法displayData()
,以便在5秒后执行。
new Handler().postDelayed(new Runnable() {
@Override
public void run() {
displayData();
}
}, 5000);
注意:请勿使用Thread.sleep(5000);
之类的线程,因为它会阻止您的用户界面并使其无法响应。
答案 1 :(得分:3)
使用CountDownTimer
// There's a TextView txtCount in Main Activity
final int secs = 5;
new CountDownTimer((secs +1) * 1000, 1000) // Wait 5 secs, tick every 1 sec
{
@Override
public final void onTick(final long millisUntilFinished)
{
txtCount.setText("" + (int) (millisUntilFinished * .001f));
}
@Override
public final void onFinish()
{
txtCount.setText("GO!");
finish();
// Time's up - Start the Login Activity
final Intent tnt =
new Intent(getApplicationContext(), LoginActivity.class);
startActivity(tnt);
}
}.start();
答案 2 :(得分:3)
将 millisDelayTime 变量指定为您希望导致延迟的毫秒数。 mActivity 是活动的对象,用于提供应用程序上下文。在您的情况下,应使用5000
初始化 millisDelayTimemActivity.runOnUiThread(new Runnable() {
@Override
public void run() {
final Handler handler = new Handler();
handler.postDelayed(new Runnable() {
@Override
public void run() {
//your code here
}
}, millisDelayTime);
}
});
答案 3 :(得分:2)
试试这个,代码创建一个滴答的CountDownTimer
timer = new CountDownTimer(5000, 5000)
{
public void onTick(long millisUntilFinished)
{
}
public void onFinish()
{
displayData();
}
};
timer.start();
答案 4 :(得分:1)
实现此目标的最佳方法是使用Handler:
int TIME = 5000; //5000 ms (5 Seconds)
new Handler().postDelayed(new Runnable() {
@Override
public void run() {
function(); //call function!
}
}, TIME);
答案 5 :(得分:1)
long delay = 1000;
long period = 50000;
Timer task = new Timer();
task.scheduleAtFixedRate(new TimerTask() {
@Override
public void run() {
getDriver(sessionManager.getKEY(), ride_id);
}
}, delay, period);
答案 6 :(得分:1)
由于不建议使用Handler,因此请使用以下代码:
new Handler(Looper.myLooper()).postDelayed(new Runnable() {
@Override
public void run() {
//do what you want
}
}, 5000);
答案 7 :(得分:0)
尽可能避免使用postDelayed。这是一个坏习惯,因为它可能会丢失对您要在屏幕上绘制的对象的引用,并导致NPE。请改用Handler。首先,创建一个全局变量Handler,在其中必须“处理”代码的逻辑。通过使用handleMessage函数来实现。
Handler handler = new Handler(){
@Override
public void handleMessage(Message msg) {
if(msg.what == 1){
// your code here
}
}
};
然后,无论您要执行它的什么地方,只需调用该函数即可:
// 1 is the ID of your process
handler.sendEmptyMessageDelayed(1, 5000);
请记住,在onDestroyView方法(在Fragment中)或onDestroy(在Activity中)中,您将必须调用
handler.removeMessages(1)
答案 8 :(得分:0)
以科特林的方式
Handler().postDelayed({
//do something
}, 5000)