2011-02-18 59 views
4

我最近收到了相同的ANR报告。 当应用程序试图绘制一些位图时(当使用ImageView作为元素渲染GridView时),ANR发生。 我已经做了大量的调试,现在可以肯定地说,挂起既不依赖于位图,也不依赖于它被绘制的位置。ANR在Canvas.native_drawBitmap

堆是50%免费,图像不大于400px^2
网格元素没有任何自定义布局 - 只是简单的ImageView。
在HTC Desire(1 GHz CPU),英雄,模拟器等上测试。
ANR继续永远所以它就像绘制位图时运行一些无限循环。

还有什么可以导致这样的挂起?

报告如下:

DALVIK THREADS: 
"main" prio=5 tid=1 NATIVE 
    | group="main" sCount=1 dsCount=0 s=N obj=0x40020ba0 self=0xddd0 
    | sysTid=32366 nice=0 sched=0/0 cgrp=unknown handle=-1345025972 
    at android.graphics.Canvas.native_drawBitmap(Native Method) 
    at android.graphics.Canvas.drawBitmap(Canvas.java:1045) 
    at android.graphics.drawable.BitmapDrawable.draw(BitmapDrawable.java:323) 
    at android.widget.ImageView.onDraw(ImageView.java:860) 
    at android.view.View.draw(View.java:6740) 
    at android.view.ViewGroup.drawChild(ViewGroup.java:1640) 
    at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1367) 
    at android.view.ViewGroup.drawChild(ViewGroup.java:1638) 
    at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1367) 
    at android.view.View.draw(View.java:6743) 
    at android.widget.FrameLayout.draw(FrameLayout.java:352) 
    at android.view.ViewGroup.drawChild(ViewGroup.java:1640) 
    at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1367) 
    at android.view.View.draw(View.java:6743) 
    at android.widget.FrameLayout.draw(FrameLayout.java:352) 
    at com.android.internal.policy.impl.PhoneWindow$DecorView.draw(PhoneWindow.java:1847) 
    at android.view.ViewRoot.draw(ViewRoot.java:1407) 
    at android.view.ViewRoot.performTraversals(ViewRoot.java:1163) 
    at android.view.ViewRoot.handleMessage(ViewRoot.java:1727) 
    at android.os.Handler.dispatchMessage(Handler.java:99) 
    at android.os.Looper.loop(Looper.java:123) 
    at android.app.ActivityThread.main(ActivityThread.java:4627) 
    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:878) 
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:636) 
    at dalvik.system.NativeStart.main(Native Method) 
+0

这些位图有多大?我们在这里谈论多少个ImageView?您可以发布您尝试使用的布局吗?或生成布局的一些代码?我的怀疑只是图像太大(尺寸或密度),很难在较慢的手机上绘制这些图像。如果他们都在同一个屏幕上,它很可能会挤压和增长。 – 2011-02-19 06:37:54

回答

1

这是很难没有你的代码或至少一个小样本,以查明您的问题。您可能需要使用AsyncTask加载图像。同时开启StrictMode对于查找ANR错误非常有帮助。

public void onCreate() { 
if (DEVELOPER_MODE) { 
    StrictMode.setThreadPolicy(new StrictMode.ThreadPolicy.Builder() 
      .detectDiskReads() 
      .detectDiskWrites() 
      .detectNetwork() // or .detectAll() for all detectable problems 
      .penaltyLog() 
      .build()); 
    StrictMode.setVmPolicy(new StrictMode.VmPolicy.Builder() 
      .detectLeakedSqlLiteObjects() 
      .detectLeakedClosableObjects() 
      .penaltyLog() 
      .penaltyDeath() 
      .build()); 
} 
super.onCreate(); 
} 

确保在您释放之前删除StrictMode。它会在api级别9之前在设备上导致VerifyError。 这是在开发过程中使用的一个很好的功能。它会导致你的应用程序崩溃,当你做任何事情可能会阻止UI线程。