如何在一段时间后开始活动?

时间:2012-11-05 11:17:25

标签: android timer

我需要在一段时间后从当前活动开始活动。我编码如下。

public class FirstActivity extends Activity {

@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_first);


    new Timer().schedule(new TimerTask(){
        public void run() { 
            startActivity(new Intent(FirstActivity.this, SecondActivity.class));
        }
    }, 2000); 
}

但是它没有用......它一直在崩溃..我的方法是否正确?我的清单文件如下

`

<uses-sdk
    android:minSdkVersion="8"
    android:targetSdkVersion="15" />

<application
    android:icon="@drawable/ic_launcher"
    android:label="@string/app_name"
    android:theme="@style/AppTheme" >
    <activity
        android:name=".FirstActivity"
        android:label="@string/title_activity_first" >
        <intent-filter>
            <action android:name="android.intent.action.MAIN" />

            <category android:name="android.intent.category.LAUNCHER" />
        </intent-filter>
    </activity>
    <activity
        android:name=".SecondActivity"
        android:label="@string/title_activity_second" >
        <meta-data
            android:name="android.support.PARENT_ACTIVITY"
            android:value="com.example.first.FirstActivity" />
    </activity>
</application>

9 个答案:

答案 0 :(得分:17)

您可以使用 HandlerpostDelayed()方法执行此操作:

Handler mHandler = new Handler();
mHandler.postDelayed(new Runnable() {

    @Override
    public void run() {
        //start your activity here  
    }

}, 1000L);

其中1000L是Runnable类中代码之后的时间(以毫秒为单位) 将被召唤。

尝试使用此功能。

答案 1 :(得分:9)

使用runOnUiThread从Timer启动活动:

new Timer().schedule(new TimerTask(){
        public void run() { 
         FirstActivity.this.runOnUiThread(new Runnable() {
            public void run() {
            startActivity(new Intent(FirstActivity.this, SecondActivity.class));
          }
        });
       }
    }, 2000);

答案 2 :(得分:1)

试一试。我在我的应用程序中将它用于启动画面并且工作得很好。此外,正如@Venture在评论中指出的那样,请确保将活动添加到您的清单文件中。

new Handler().postDelayed(new Runnable() {
    @Override
    public void run() {
        Intent startActivity = new Intent(FirstActivity.this, SecondActivity.class);
        startActivity(startActivity);
        finish();
    }
}, 2000);

答案 3 :(得分:1)

我在网上发现了这个。 您可以创建一个界面,并在匿名方法

中在您的类中实现它
public static void delay(int timeMillisecond , final DelayCallBack delayCallBack){
    Handler handler = new Handler();
    handler.postDelayed(new Runnable() {
        @Override
        public void run() {
            delayCallBack.postDelay();
        }
    } , timeMillisecond );
}

public interface DelayCallBack{
    void postDelay();
}

Util,那就是我的静态方法

Util.delay( delay , new Util.DelayCallBack() {
    @Override
    public void postDelay() {
        startActivity( new Intent( [currentContext] , [nextActivity] );
    }
});

答案 4 :(得分:0)

我不知道您的代码有什么问题,但这应该有效:

private Handler mHandler = new Handler();
mHandler.postDelayed(mStartActivityTask, 2000);
private Runnable mStartActivityTask= new Runnable() {
    public void run() {
       // Start the Activity
    }
};

答案 5 :(得分:0)

你可以试试这个:

Thread toRun = new Thread()

        {
               public void run()
               {
                   try {                      
                    sleep(500);

                     Intent intent = new Intent (FirstActivity.this, SecondActivity.class);
                     startActivity(intent);

                } catch (InterruptedException e) {
                    // TODO Auto-generated catch block
                    e.printStackTrace();
                }
               }
        };
        toRun.start();

答案 6 :(得分:0)

感谢所有......它现在正在工作..问题在于第二个活动不在于计时器。当我注释掉“getActionBar()。setDisplayHomeAsUpEnabled(true);”在第二项活动中,这些线路开始运作。这些行在编译时不会给出任何错误,但是在运行时它将是一个问题。谢谢。

答案 7 :(得分:0)

@Override
protected void onStart() {
    super.onStart();

    try {
    Runnable myRunnable = new Runnable(){

        public void run(){

        try{
           sleep(SPLASH_TIME_OUT);
            finish();

        }catch (Exception e){
            System.exit(1);
        }
            Intent i = new Intent(SplashScreen.this, MainActivity.class);
            startActivity(i);
        }
    };

    Thread thread = new Thread(myRunnable);
    thread.start();




    }catch (Exception e){
        System.exit(1);
    }

}

答案 8 :(得分:0)

Better to use CountDownTimer. Inside Finish() method launch your activity.Check below:-

 private void Start_Timer(String duration) {
        Log.d(TAG,"duration value"+Long.parseLong(duration));
        new CountDownTimer(Long.parseLong(duration), 10000){
            public void onTick(long millisUntilFinished){
                Log.d(TAG,"counting");
            }
            public  void onFinish(){
                Log.d(TAG,"inside finish");
                Intent intent =new Intent(getApplicationContext(),Result_Summary.class);
                startActivity(intent);
            }
        }.start();
    }