Android - Ошибка - IllegalArgumentException: тип окна нельзя изменить после добавления окна
Я отлаживаю приложение для Android (которое, к сожалению, было написано кем-то другим). Приложение имеет всплеск активности, который длится в течение 1 секунды, а затем переходит к активности целевой страницы с помощью намерения. Приложение работало нормально, пока я не заметил, что targetSDKVersion не был установлен в файле манифеста. Я установил его на 18. И затем, когда я запускаю приложение в эмуляторе, приложение вылетает, и я вижу следующую ошибку в logcat:
10-24 06:14:26.840: E/AndroidRuntime(2457): FATAL EXCEPTION: main
10-24 06:14:26.840: E/AndroidRuntime(2457): java.lang.IllegalArgumentException: Window type can not be changed after the window is added.
10-24 06:14:26.840: E/AndroidRuntime(2457): at android.os.Parcel.readException(Parcel.java:1435)
10-24 06:14:26.840: E/AndroidRuntime(2457): at android.os.Parcel.readException(Parcel.java:1385)
10-24 06:14:26.840: E/AndroidRuntime(2457): at android.view.IWindowSession$Stub$Proxy.relayout(IWindowSession.java:835)
10-24 06:14:26.840: E/AndroidRuntime(2457): at android.view.ViewRootImpl.relayoutWindow(ViewRootImpl.java:5034)
10-24 06:14:26.840: E/AndroidRuntime(2457): at android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:1399)
10-24 06:14:26.840: E/AndroidRuntime(2457): at android.view.ViewRootImpl.doTraversal(ViewRootImpl.java:1004)
10-24 06:14:26.840: E/AndroidRuntime(2457): at android.view.ViewRootImpl$TraversalRunnable.run(ViewRootImpl.java:5481)
10-24 06:14:26.840: E/AndroidRuntime(2457): at android.view.Choreographer$CallbackRecord.run(Choreographer.java:749)
10-24 06:14:26.840: E/AndroidRuntime(2457): at android.view.Choreographer.doCallbacks(Choreographer.java:562)
10-24 06:14:26.840: E/AndroidRuntime(2457): at android.view.Choreographer.doFrame(Choreographer.java:532)
10-24 06:14:26.840: E/AndroidRuntime(2457): at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:735)
10-24 06:14:26.840: E/AndroidRuntime(2457): at android.os.Handler.handleCallback(Handler.java:730)
10-24 06:14:26.840: E/AndroidRuntime(2457): at android.os.Handler.dispatchMessage(Handler.java:92)
10-24 06:14:26.840: E/AndroidRuntime(2457): at android.os.Looper.loop(Looper.java:137)
10-24 06:14:26.840: E/AndroidRuntime(2457): at android.app.ActivityThread.main(ActivityThread.java:5103)
10-24 06:14:26.840: E/AndroidRuntime(2457): at java.lang.reflect.Method.invokeNative(Native Method)
10-24 06:14:26.840: E/AndroidRuntime(2457): at java.lang.reflect.Method.invoke(Method.java:525)
10-24 06:14:26.840: E/AndroidRuntime(2457): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:737)
10-24 06:14:26.840: E/AndroidRuntime(2457): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553)
10-24 06:14:26.840: E/AndroidRuntime(2457): at dalvik.system.NativeStart.main(Native Method)
Приложение аварийно завершает работу сразу после отображения заставки и до загрузки активности целевой страницы. Следующие блоки показывают соответствующие блоки кода из всплеска активности.
Всплеск Активность
private Thread mSplashThread;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.splash);
final SplashScreenActivity sPlashScreen = this;
mSplashThread = new Thread(){
@Override
public void run(){
try {
synchronized(this){
// Wait given period of time or exit on touch
wait(1000);
}
}
catch(InterruptedException ex){
}
finish();
// Run next activity
Intent intent = new Intent();
intent.setClass(sPlashScreen, LandingPageActivity.class);
startActivity(intent);
}
};
mSplashThread.start();
}
@Override
public boolean onTouchEvent(MotionEvent evt)
{
if(evt.getAction() == MotionEvent.ACTION_DOWN)
{
try{
synchronized(mSplashThread){
mSplashThread.notifyAll();
}
}
catch (IllegalArgumentException e){
Log.v("This is it", e.getCause().getMessage());
}
}
return true;
}
Теперь во всех моих исследованиях по устранению этой проблемы я нашел предложения проверить следующий фрагмент кода, но в моем приложении ничего подобного нет:
@Override
public void onAttachedToWindow()
{
this.getWindow().setType(WindowManager.LayoutParams.TYPE_KEYGUARD);
super.onAttachedToWindow();
}
3 ответа
Проблема решена. Действительно, onAttachedToWindow возник в одном из пустых базовых классов. Это сработало после удаления этого переопределения. Как я упоминал в своем первоначальном посте, я столкнулся с этим решением в другом посте. Вот ссылка на этот пост.
В моем случае, однако, этот код не был связан ни с какими действиями, связанными с пользователем. Это было в пустом родительском действии, которое наследовала моя целевая страница. Надеюсь, кто-то спасет через несколько часов после этого поста.
У меня есть решение для вас. Это не очень полезно, но может решить вашу проблему. Вам следует изменить версию minsdk на 8.
<uses-sdk android:minSdkVersion="8" />
Давай попробуй и скажи мне результат;)
Если вы используете только задержку, попробуйте это;
public class MainActivity extends Activity implements OnClickListener{
private Thread mSplashThread;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.splash);
View root = getWindow().getDecorView().findViewById(android.R.id.content);
root.setOnClickListener(this);
final SplashScreenActivity sPlashScreen = this;
mSplashThread = new Thread(){
@Override
public void run(){
try {
Thread.currentThread().sleep(2000);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
finish();
// Run next activity
Intent intent = new Intent();
intent.setClass(sPlashScreen, LandingPageActivity.class);
startActivity(intent);
}
};
}
@Override
public void onClick(View v) {
mSplashThread.start();
}
}