我每隔一段时间就会从Market developer控制台得到这个堆栈跟踪;我找不到任何方法来重现这个错误。它发生在应用程序首次加载时显示一个闪屏ImageView,但堆栈跟踪没有我的任何代码。我甚至不认为我的活动已经达到了onCreate
,尽管没有日志很难判断。
实际上,我从来没有在代码中的任何地方使用过位图;我对图像的唯一引用是在我的layout.xml中。
<ImageView android:id="@+id/splashScreen"
android:layout_height="fill_parent"
android:layout_width="fill_parent"
android:src="@drawable/splashscreen"
android:scaleType="fitXY"
/>
我对这个ImageView所做的唯一一件事就是在我完成启动时将它的可见性设置为GONE
。
有什么我能做的吗?
java.lang.RuntimeException: Canvas: trying to use a recycled bitmap android.graphics.Bitmap@4721ec18
at android.graphics.Canvas.throwIfRecycled(Canvas.java:955)
at android.graphics.Canvas.drawBitmap(Canvas.java:1044)
at android.graphics.drawable.BitmapDrawable.draw(BitmapDrawable.java:323)
at android.widget.ImageView.onDraw(ImageView.java:923)
at android.view.View.draw(View.java:6761)
at android.view.ViewGroup.drawChild(ViewGroup.java:1663)
at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1390)
at android.view.View.buildDrawingCache(View.java:6517)
at android.view.View.getDrawingCache(View.java:6305)
at android.view.ViewGroup.drawChild(ViewGroup.java:1588)
at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1390)
at android.view.ViewGroup.drawChild(ViewGroup.java:1661)
at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1409)
at android.view.View.draw(View.java:6764)
at android.widget.FrameLayout.draw(FrameLayout.java:352)
at android.view.ViewGroup.drawChild(ViewGroup.java:1663)
at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1390)
at android.view.ViewGroup.drawChild(ViewGroup.java:1661)
at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1390)
at android.view.ViewGroup.drawChild(ViewGroup.java:1661)
at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1390)
at android.view.View.draw(View.java:6764)
at android.widget.FrameLayout.draw(FrameLayout.java:352)
at android.view.ViewGroup.drawChild(ViewGroup.java:1663)
at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1390)
at android.view.ViewGroup.drawChild(ViewGroup.java:1661)
at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1390)
at android.view.View.draw(View.java:6764)
at android.widget.FrameLayout.draw(FrameLayout.java:352)
at com.android.internal.policy.impl.PhoneWindow$DecorView.draw(PhoneWindow.java:1887)
at android.view.ViewRoot.draw(ViewRoot.java:1432)
at android.view.ViewRoot.performTraversals(ViewRoot.java:1167)
at android.view.ViewRoot.handleMessage(ViewRoot.java:1764)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:143)
at android.app.ActivityThread.main(ActivityThread.java:5068)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:521)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:858)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616)
at dalvik.system.NativeStart.main(Native Method)
发布于 2011-07-22 23:03:28
如果您在代码中的某个位置回收位图,则应确保在应用程序重新启动时,将重新创建您的位图。当您通过onCreate时,没有问题,但当应用程序暂停并重新启动时,它将不会再次通过onCreate,而只是通过onResume。我认为您可以在onResume方法中重新创建位图,但是使用一个标志在onCreate或onResume中创建位图,而不是两者都创建(当应用程序启动时,onCreate和onResume一起调用,这样会浪费CPU周期)。
发布于 2012-05-15 16:49:33
当其中一个活动正在回收其位图时,您不应将相同的图像资源用于不同的活动。
如果您遇到这种情况,请更改其中一个活动的图像资源。
发布于 2013-06-04 10:14:51
你有没有试过降低图像的压力?这在我身上发生过很多次。如果在重新调整图像后问题仍然存在,这意味着问题出在其他地方...我会在你的主活动中或者在闪屏代码中查看on create方法。
对不起,我的英语很烂:)
来吧!
https://stackoverflow.com/questions/6791742
复制相似问题