2

私のアプリには、ImageView と TextView を持つウィジェットがあります。WidgetProvider の onUpdate() メソッドで、次のように ImageView 内に Bitmap を配置します。

Bitmap bitmap = BitmapFactory.decodeResource(context.getResources(), R.drawable.widget_btn);
Bitmap bitmap2 = BitmapManager.setColor(bitmap, red, green, blue);
views.setImageViewBitmap(R.id.image, bitmap2);

setColor() メソッドは次のとおりです。

public synchronized static Bitmap setColor(Bitmap org, float r, float g, float b)
{
    sColorMatrix.setScale(r, g, b, 1);
    sColorPaint.setColorFilter(new ColorMatrixColorFilter(sColorMatrix));
    // RGB_565 is faster, but loses transparency
    Bitmap ret = Bitmap.createBitmap(org.getWidth(), org.getHeight(), Bitmap.Config.ARGB_8888);
    try{
        sColorCanvas.setBitmap(ret);
        //sColorCanvas.drawColor(Color.);
        sColorCanvas.drawBitmap(org, 0, 0, sColorPaint);
    } catch (Throwable t){

    }

    return ret;
}

問題は、誰かがビットマップをリサイクルしたために、ウィジェットが RuntimeException をスローすることがあり、どうすればよいかわかりません。いくつかの提案?

役に立つ場合は、スタック トレースを添付できます。ありがとうございました!


これはスタックトレースです:

java.lang.RuntimeException: Canvas: trying to use a recycled bitmap android.graphics.Bitmap@462605a8
   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:6739)
   at android.view.ViewGroup.drawChild(ViewGroup.java:1648)
   at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1375)
   at android.view.ViewGroup.drawChild(ViewGroup.java:1646)
   at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1375)
   at android.view.ViewGroup.drawChild(ViewGroup.java:1646)
   at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1375)
   at android.widget.AbsListView.dispatchDraw(AbsListView.java:1365)
   at android.widget.ListView.dispatchDraw(ListView.java:3046)
   at android.view.View.draw(View.java:6845)
   at android.widget.AbsListView.draw(AbsListView.java:2257)
   at android.view.ViewGroup.drawChild(ViewGroup.java:1648)
   at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1375)
   at android.view.ViewGroup.drawChild(ViewGroup.java:1646)
   at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1375)
   at android.view.View.draw(View.java:6742)
   at android.widget.FrameLayout.draw(FrameLayout.java:352)
   at android.view.ViewGroup.drawChild(ViewGroup.java:1648)
   at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1375)
   at android.view.ViewGroup.drawChild(ViewGroup.java:1646)
   at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1375)
   at android.view.ViewGroup.drawChild(ViewGroup.java:1646)
   at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1375)
   at android.view.ViewGroup.drawChild(ViewGroup.java:1646)
   at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1375)
   at android.view.ViewGroup.drawChild(ViewGroup.java:1646)
   at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1375)
   at android.view.View.draw(View.java:6742)
   at android.widget.FrameLayout.draw(FrameLayout.java:352)
   at android.view.ViewGroup.drawChild(ViewGroup.java:1648)
   at android.view.ViewGroup.dispatchDraw(ViewGroup.java:1375)
   at android.view.View.draw(View.java:6742)
   at android.widget.FrameLayout.draw(FrameLayout.java:352)
   at com.android.internal.policy.impl.PhoneWindow$DecorView.draw(PhoneWindow.java:1872)
   at android.view.ViewRoot.draw(ViewRoot.java:1422)
   at android.view.ViewRoot.performTraversals(ViewRoot.java:1167)
   at android.view.ViewRoot.handleMessage(ViewRoot.java:1744)
   at android.os.Handler.dispatchMessage(Handler.java:99)
   at android.os.Looper.loop(Looper.java:144)
   at android.app.ActivityThread.main(ActivityThread.java:4937)
   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:868)
   at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
   at dalvik.system.NativeStart.main(Native Method)
4

2 に答える 2

0

bitmap2 が範囲外になり、GC が実行され、描画されるときに消えてしまったようです。

bitmap2 を静的フィールドにします。これにより、含まれているクラスが破棄されるまで、収集が停止されます。

于 2011-07-21T13:29:00.600 に答える
0

解決策は、コードから へのすべての呼び出しを削除することBitmap#recycleです。ガベージ コレクターは、参照されていないビットマップを処理します。

于 2010-08-23T23:10:27.583 に答える