3

私は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();  
    }
4

3 に答える 3

4

問題は解決しました。実際、空の基本クラスの 1 つで「onAttachedToWindow」が発生しました。そのオーバーライドを削除した後に機能しました。元の投稿で述べたように、別の投稿でこのソリューションに出くわしました。ここにその投稿への参照があります。

ただし、私の場合、このコードはユーザー向けのアクティビティには含まれていませんでした。私のランディングページが継承していた空白の親アクティビティにありました。この投稿の後、誰かが数時間節約できることを願っています。

于 2013-10-25T11:14:53.563 に答える
0

遅延のみを使用する場合は、これを試してください。

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();
    }

}
于 2013-10-24T14:14:25.127 に答える