2012-04-18 4 views
0

Я разрабатываю приложение, в котором я использовал заставку. Но после того, как всплеск исчезнет, ​​тогда
Следующий экран становится черным, прежде чем переключиться на мою основную деятельность, и я не хочу черный экран. Кто-нибудь может предложить мне, как это сделать? Вот мой код.Черный экран появляется после экрана всплеска в android

Launcher активность

public class MainActivity extends Activity{ 
public static final String TAG = "MainActivity"; 
protected void onCreate(Bundle savedInstanceState) { 
// TODO Auto-generated method stub 
super.onCreate(savedInstanceState); 
Intent in = new Intent(getApplicationContext(), SplashScreenActivity.class); 
synchronized (this) { 
try { 
wait(50); 
} catch (InterruptedException e) { 
String str = e.toString(); 
Log.d(TAG, str); 
}//catch 
}//synchronized block 
startActivity(in); 
}//onCreate 
}//class 

SplashScreenAcitvity

public class SplashScreenActivity extends Activity { 
private Thread splashThread; 
public static final String TAG = "SplashScreenActivity"; 
public void onCreate(Bundle savedInstanceState) { 
super.onCreate(savedInstanceState); 
setContentView(R.layout.splash); 
final SplashScreenActivity splashScreen = this; 

splashThread = new Thread(){ 
public void run(){ 
try { 
synchronized (this) { 
wait(3000); 
} 
} catch (Exception e) { 
String str = e.toString(); 
Log.d(TAG, str); 
} 
finish(); 
Intent in = new Intent(); 
in.setClass(splashScreen, ProjectActivity.class); 
startActivity(in); 
stop(); 
}//run 
}; 
splashThread.start(); 
}//onCreate 

}//class 

Проектная деятельность Это класс от того, где основная работа начнется.

public class ProjectActivity extends TabActivity { 
static int x=0; 
static int color; 
public void onCreate(Bundle savedInstanceState) { 
super.onCreate(savedInstanceState); 
requestWindowFeature(Window.FEATURE_NO_TITLE); 
setContentView(R.layout.tabxml); 

if(x==1) 
{ 
Dor.c=1; 
color = getIntent().getExtras().getInt("color"); 
//Intent in=new Intent(); 
//in.putExtra("color",color); 
} 
Resources res = getResources(); // Resource object to get Drawables 
TabHost tabHost = getTabHost(); // The activity TabHost 
TabHost.TabSpec spec; // Resusable TabSpec for each tab 
Intent intent; // Reusable Intent for each tab 
// Create an Intent to launch an Activity for the tab (to be reused) 
intent = new Intent().setClass(this, Dor.class); 
// Initialize a TabSpec for each tab and add it to the TabHost 
spec = tabHost.newTabSpec("dor").setIndicator("Dor", 
res.getDrawable(R.drawable.ic_tab_artists)) 
.setContent(intent); 
tabHost.addTab(spec); 

// Do the same for the other tabs 
intent = new Intent().setClass(this, Album.class); 
spec = tabHost.newTabSpec("albums").setIndicator("Albums", 
res.getDrawable(R.drawable.ic_tab_album) 
.setContent(intent); 
tabHost.addTab(spec); 
intent = new Intent().setClass(this, Forhandler.class); 
spec = tabHost.newTabSpec("forhandler").setIndicator("Forhandler", 
res.getDrawable(R.drawable.ic_tab_forhandler)) 
.setContent(intent); 
tabHost.addTab(spec); 
intent = new Intent().setClass(this, Diplomat.class); 
spec = tabHost.newTabSpec("diplomat").setIndicator("Diplomat", 
res.getDrawable(R.drawable.ic_tab_diplomat)) 
.setContent(intent); 
tabHost.addTab(spec); 
tabHost.setCurrentTab(0); 
} 
} 

Я пробовал с асинхронной задачей, но это не сработало. Вот мой модифицированный код:

ProjectStart

public class ProjectStart extends AsyncTask<Context, Void, Void>{ 
public static final String TAG = "ProjectStart"; 
/*public ProjectStart() { 
    super("ProjectStart"); 
    // TODO Auto-generated constructor stub 
}*/ 

Context ctx; 
public ProjectStart(Context context){ 
    this.ctx = context; 
}//constructor 

@Override 
protected Void doInBackground(Context... params) { 
    // TODO Auto-generated method stub 
    Intent in = new Intent(); 
    in.setClass(ctx, ProjectActivity.class); 
    Log.d(TAG, "doInBackground called"); 
    return null; 
}//doInBackground 

/*@Override 
protected void onHandleIntent(Intent intent) { 
    // TODO Auto-generated method stub 
    Intent in = new Intent(); 
    in.setClass(getApplicationContext(), ProjectActivity.class); 
    startActivity(in); 
    Log.d("Project Start", "onHandleIntentCalled"); 
}*/ 

} // класс

В SplashScreen.java я следующие модификации

splashThread = new Thread() { 
     public void run(){ 
      try {     
       synchronized (this) { 
        wait(3000); 
       }//synchronized 
      }//try 
      catch(InterruptedException e) {} 
      finally { 
       finish(); 
       new ProjectStart(sPlashScreen).execute(); 
       /*Intent in = new Intent(getApplicationContext(), ProjectStart.class); 
       startService(in);*/ 
       stop(); 
      }//finally 
      Log.d(TAG, "run method called"); 
     }//run 
    }; 

И вот трассировки стека:

04-19 11:29:02.181: E/AndroidRuntime(341): FATAL EXCEPTION: Thread-8 
04-19 11:29:02.181: E/AndroidRuntime(341): java.lang.ExceptionInInitializerError 
04-19 11:29:02.181: E/AndroidRuntime(341): at abc.com.camera.SplashScreen$1.run(SplashScreen.java:32) 
04-19 11:29:02.181: E/AndroidRuntime(341): Caused by: java.lang.RuntimeException: Can't create handler inside thread that has not called Looper.prepare() 
04-19 11:29:02.181: E/AndroidRuntime(341): at android.os.Handler.<init>(Handler.java:121) 
04-19 11:29:02.181: E/AndroidRuntime(341): at android.os.AsyncTask$InternalHandler.<init>(AsyncTask.java:421) 
04-19 11:29:02.181: E/AndroidRuntime(341): at android.os.AsyncTask$InternalHandler.<init>(AsyncTask.java:421) 
04-19 11:29:02.181: E/AndroidRuntime(341): at android.os.AsyncTask.<clinit>(AsyncTask.java:152) 
04-19 11:29:02.181: E/AndroidRuntime(341): ... 1 more 


    04-19 11:29:02.181: E/AndroidRuntime(341): Caused by: java.lang.RuntimeException: Can't create handler inside thread that has not called Looper.prepare() 

Я не понимаю, в чем проблема.

+0

Где ваш код? –

+0

привет, вы можете рассказать мне, что вы делаете в своем заставке и основной активности. –

+0

попытайтесь уменьшить как можно больше кода в onCreate() MainActivity. – Richa

ответ

1

Я думаю, что лучшее решение для вас asynctask

Приведен пример с сайта разработчика. В Asynctask есть четыре основных метода.

onPreExecute() 

doInBackground(Params...) 

onProgressUpdate(Progress...) 

onPostExecute(Result) 

И это другое Example.

+0

Извините, по ошибке я изменил ваше сообщение. Согласно предложению ypur, я попытался выполнить асинхронную задачу, но это не сработало. – Nitish

+0

Использование async-задачи У меня есть это исключение: E/AndroidRuntime (341): Caused by: java.lang.RuntimeException: не удается создать обработчик внутри потока, который не вызвал Looper.prepare() – Nitish

+0

@nitish: можете ли вы просто посмотрите на этот блог. http://androidpartaker.wordpress.com/2010/08/01/android-async-task/ – Bhavin

2

Но после всплеска исчезает, экран становится черным, перед включением к моей основной деятельности

кажется, что вы могли бы делать некоторые фоновый процесс на ПИ MainActivity, что нашли время, чтобы сделать Фоновый процесс. Если так что использование

  • AsyncTask
  • Услуги
  • IntentService

для фонового процесса. Если не показать основную активность, какой код у нее есть.

0

Добавить флаг вашего намерения деятельности .. setFlags (Intent.FLAG_ACTIVITY_NO_ANIMATION)

Смежные вопросы