我一直在尝试使用Android-L预览(Nexus 7)进行共享元素转换,并在与OutOfMemoryError
一起使用时遇到ViewPager
例外。但我也尝试过Romain的google-io-2014演示,并且在点击图片然后回击几次(10到15之间)之后也遇到了同样的问题。它是SDK中的错误,应该在应用程序端(recycle()
)完成某些事情吗?
java.lang.OutOfMemoryError: Failed to allocate a 1817612 byte allocation with 772936 free bytes
at dalvik.system.VMRuntime.newNonMovableArray(Native Method)
at android.graphics.Bitmap.nativeCreate(Native Method)
at android.graphics.Bitmap.createBitmap(Bitmap.java:810)
at android.graphics.Bitmap.createBitmap(Bitmap.java:787)
at android.graphics.Bitmap.createBitmap(Bitmap.java:754)
at android.app.ActivityTransitionCoordinator.captureSharedElementState(ActivityTransitionCoordinator.java:543)
at android.app.ActivityTransitionCoordinator.captureSharedElementState(ActivityTransitionCoordinator.java:511)
at android.app.EnterTransitionCoordinator.sendSharedElementDestination(EnterTransitionCoordinator.java:109)
at android.app.EnterTransitionCoordinator.onReceiveResult(EnterTransitionCoordinator.java:151)
at android.os.ResultReceiver$MyRunnable.run(ResultReceiver.java:43)
at android.os.Handler.handleCallback(Handler.java:738)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:135)
at android.app.ActivityThread.main(ActivityThread.java:5070)
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:836)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:631)
I/am_crash( 612): [17912,0,com.example.android.io2014,8961606,java.lang.OutOfMemoryError,Failed to allocate a 1817612 byte allocation with 772936 free bytes,VMRuntime.java,-2]
更新(2014年10月17日):全部使用SDK 21修复。无法关闭问题。
答案 0 :(得分:1)
显然,这已在API 21中修复(根据OP)。
另请注意,Romain Guy的示例项目只是一个例子......他没有编写代码来正确缩小他使用的图像(这是您通常在生产应用程序中执行的操作) )。如果您在低端设备上运行该示例,则可能会出现内存不足错误。为避免这种情况,我建议调整项目中包含的可绘制PNG的大小和缩小。