我通过从View扩展创建了一个自定义View。在onDraw()中,我设法绘制了一些圆和其他东西。但是现在我想从资源(SD卡或流)添加背景,这实际上是我从服务器下载并绘制的 map 。适用于Android 8+

@Override
protected void onDraw(Canvas canvas) {
    Canvas g = canvas;
    String file = "/mnt/sdcard/download/tux.png";
    Bitmap bg = null;
    try {
        bg = BitmapFactory.decodeFile(file);
        g.setBitmap(bg);
    } catch (Exception e) {
        Log.d("MyGraphics", "setBitmap() failed according to debug");
    }
}

g.setBitmap(bg)一直以某种方式失败,我没有查看图像规范,但实际上,它只是PNG格式的Tux图像(无24位颜色)。
有人可以给我一些技巧来添加背景图像,以便我可以在上面绘画吗?
谢谢你。

最佳答案

实际上,您实际上不想使用加载的位图,而只想在Canvas上绘制它,因此应使用Canvas.drawBitmap()。您实际上也不应在每个onDraw()中加载位图,而应在构造函数中进行加载。试试这个类(class):

package com.example.android;

import android.content.Context;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.graphics.Canvas;
import android.util.AttributeSet;
import android.view.View;

public class CustomView extends View {
    private final Bitmap mBitmapFromSdcard;

    public CustomView(Context context) {
        this(context, null);
    }

    public CustomView(Context context, AttributeSet attrs) {
        super(context, attrs);
        mBitmapFromSdcard = BitmapFactory.decodeFile("/mnt/sdcard/download/tux.png");
    }

    @Override
    protected void onDraw(Canvas canvas) {
        Canvas g = canvas;
        if (mBitmapFromSdcard != null) {
            g.drawBitmap(mBitmapFromSdcard, 0, 0, null);
        }
    }
}

您还可以让Android在后台绘制位图:
package com.example.android;

import android.content.Context;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.graphics.drawable.BitmapDrawable;
import android.util.AttributeSet;
import android.view.View;

public class CustomView extends View {
    public CustomView(Context context) {
        this(context, null);
    }

    public CustomView(Context context, AttributeSet attrs) {
        super(context, attrs);
        Bitmap bm = BitmapFactory.decodeFile("/mnt/sdcard/download/tux.png");
        if (bm != null) {
            setBackgroundDrawable(new BitmapDrawable(bm));
        }
    }
}

09-26 21:41
查看更多