我需要在一段时间后从当前活动开始活动。我编码如下。
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>
答案 0 :(得分:17)
您可以使用 Handler
类postDelayed()
方法执行此操作:
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();
}