2015-07-03 51 views
0

我的應用程序工作得很好。我更新了Android Studio。然後我再次構建我的應用程序進行測試,現在它立即崩潰!這就像Android Studio移動資源。我不確定是什麼導致了這個錯誤。我經歷了從頭開始重新構建應用程序,複製和粘貼代碼的麻煩,並且我也遇到了同樣的錯誤。將不勝感激社區的幫助。更新的Android Studio,現在錯誤膨脹類

07-03 12:02:25.134 6167-6167/? E/AndroidRuntime﹕ FATAL EXCEPTION: main 
Process: com.mystuff.test, PID: 6167 
java.lang.RuntimeException: Unable to start activity ComponentInfo{com.mystuff.test/com.mystuff.test.MainActivity}: android.view.InflateException: Binary XML file line #6: Error inflating class com.mystuff.test.BattleView 
     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2693) 
     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2758) 
     at android.app.ActivityThread.access$900(ActivityThread.java:177) 
     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1448) 
     at android.os.Handler.dispatchMessage(Handler.java:102) 
     at android.os.Looper.loop(Looper.java:145) 
     at android.app.ActivityThread.main(ActivityThread.java:5942) 
     at java.lang.reflect.Method.invoke(Native Method) 
     at java.lang.reflect.Method.invoke(Method.java:372) 
     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1399) 
     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1194) 
Caused by: android.view.InflateException: Binary XML file line #6: Error inflating class com.mystuff.test.BattleView 
     at android.view.LayoutInflater.createView(LayoutInflater.java:640) 
     at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:750) 
     at android.view.LayoutInflater.rInflate(LayoutInflater.java:813) 
     at android.view.LayoutInflater.inflate(LayoutInflater.java:511) 
     at android.view.LayoutInflater.inflate(LayoutInflater.java:415) 
     at android.view.LayoutInflater.inflate(LayoutInflater.java:366) 
     at com.android.internal.policy.impl.PhoneWindow.setContentView(PhoneWindow.java:435) 
     at android.app.Activity.setContentView(Activity.java:2267) 
     at com.mystuff.test.MainActivity.onCreate(MainActivity.java:41) 
     at android.app.Activity.performCreate(Activity.java:6289) 
     at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1119) 
     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2646) 
     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2758) 
     at android.app.ActivityThread.access$900(ActivityThread.java:177) 
     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1448) 
     at android.os.Handler.dispatchMessage(Handler.java:102) 
     at android.os.Looper.loop(Looper.java:145) 
     at android.app.ActivityThread.main(ActivityThread.java:5942) 
     at java.lang.reflect.Method.invoke(Native Method) 
     at java.lang.reflect.Method.invoke(Method.java:372) 
     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1399) 
     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1194) 
Caused by: java.lang.reflect.InvocationTargetException 
     at java.lang.reflect.Constructor.newInstance(Native Method) 
     at java.lang.reflect.Constructor.newInstance(Constructor.java:288) 
     at android.view.LayoutInflater.createView(LayoutInflater.java:614) 
     at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:750) 
     at android.view.LayoutInflater.rInflate(LayoutInflater.java:813) 
     at android.view.LayoutInflater.inflate(LayoutInflater.java:511) 
     at android.view.LayoutInflater.inflate(LayoutInflater.java:415) 
     at android.view.LayoutInflater.inflate(LayoutInflater.java:366) 
     at com.android.internal.policy.impl.PhoneWindow.setContentView(PhoneWindow.java:435) 
     at android.app.Activity.setContentView(Activity.java:2267) 
     at com.mystuff.test.MainActivity.onCreate(MainActivity.java:41) 
     at android.app.Activity.performCreate(Activity.java:6289) 
     at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1119) 
     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2646) 
     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2758) 
     at android.app.ActivityThread.access$900(ActivityThread.java:177) 
     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1448) 
     at android.os.Handler.dispatchMessage(Handler.java:102) 
     at android.os.Looper.loop(Looper.java:145) 
     at android.app.ActivityThread.main(ActivityThread.java:5942) 
     at java.lang.reflect.Method.invoke(Native Method) 
     at java.lang.reflect.Method.invoke(Method.java:372) 
     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1399) 
     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1194) 
Caused by: java.lang.VerifyError: com.mystuff.test.BattleView$BattleThread 
     at com.mystuff.test.BattleView.<init>(BattleView.java:1312) 
     at java.lang.reflect.Constructor.newInstance(Native Method) 
     at java.lang.reflect.Constructor.newInstance(Constructor.java:288) 
     at android.view.LayoutInflater.createView(LayoutInflater.java:614) 
     at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:750) 
     at android.view.LayoutInflater.rInflate(LayoutInflater.java:813) 
     at android.view.LayoutInflater.inflate(LayoutInflater.java:511) 
     at android.view.LayoutInflater.inflate(LayoutInflater.java:415) 
     at android.view.LayoutInflater.inflate(LayoutInflater.java:366) 
     at com.android.internal.policy.impl.PhoneWindow.setContentView(PhoneWindow.java:435) 
     at android.app.Activity.setContentView(Activity.java:2267) 
     at com.mystuff.test.MainActivity.onCreate(MainActivity.java:41) 
     at android.app.Activity.performCreate(Activity.java:6289) 
     at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1119) 
     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2646) 
     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2758) 
     at android.app.ActivityThread.access$900(ActivityThread.java:177) 
     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1448) 
     at android.os.Handler.dispatchMessage(Handler.java:102) 
     at android.os.Looper.loop(Looper.java:145) 
     at android.app.ActivityThread.main(ActivityThread.java:5942) 
     at java.lang.reflect.Method.invoke(Native Method) 
     at java.lang.reflect.Method.invoke(Method.java:372) 
     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1399) 
     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1194) 

這裏所引用的XML文件:

<?xml version="1.0" encoding="utf-8"?> 
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
android:orientation="vertical" android:layout_width="match_parent" 
android:layout_height="match_parent"> 

<com.mystuff.test.BattleView 
    android:id="@+id/pea" 
    android:layout_width="fill_parent" 
    android:layout_height="fill_parent"/> 

</LinearLayout> 

下面是視圖和線程引用的構造函數:

//constructor gets the surface holder, assigns a callback and creates an instance of the thread 
public BattleView (Context context, AttributeSet attrs) { 
    super(context, attrs); 
    SurfaceHolder holder = getHolder(); 
    holder.addCallback(this); 
    thread = new BattleThread(holder, context, new Handler() { 
     @Override 
     public void handleMessage(Message m) { 
     } 
    }); 
    setFocusable(true); 
} 
//method to return the thread in case you need to control it from the activity 
public BattleThread getThread() { 
    return thread; 
} 

class BattleThread extends Thread { 
    public BattleThread(SurfaceHolder surfaceHolder, Context context, Handler handler) { 
     mySurfaceHolder = surfaceHolder; 
     myContext = context; 
     backgroundImg = BitmapFactory.decodeResource(context.getResources(), R.drawable.nopeastitlecrackedstart); 
     backgroundOrigW = backgroundImg.getWidth(); 
     backgroundOrigH = backgroundImg.getHeight(); 
    } 

//the rest of the thread. Code I haven't changed before it broke. 
} 
+0

檢查您是否在BattleView的佈局中使用了正確的包名稱。我想它應該是' SubinM

+0

我沒有編輯,在我原來的帖子,我有。這是我的不好,但不是解決我的問題。 – Adam

+0

你有沒有試過清理和重建? – EpicPandaForce

回答

0

感謝大家誰率先通過了讀取時間代碼並給我一些建議。經過多次試驗和錯誤之後,事實證明,Battle Thread中的畫布繪製方法變得太大而且編譯不正確。它沒有超過方法限制的大小,所以我不知道它爲什麼拒絕它,但通過一個消除過程,結果是解決方案。令人沮喪的是,我沒有得到任何日誌中的特定錯誤,必須自己去找。

相關問題