简体   繁体   English

如何在画布上绘制多个位图

[英]How to draw multiple bitmaps on a canvas

I am having trouble with the canvas function, I have no problem drawing 1 bitmap with the canvas but as soon as I add a 2nd bitmap, it only draws the last bitmap, does not show both. 我在使用canvas函数时遇到问题,我在使用画布绘制1位图时没有问题但是只要我添加第二个位图,它就会绘制最后一个位图,而不会同时显示两个位图。 please help. 请帮忙。 here is my code. 这是我的代码。 My intent, is to then animate these 2 different bitmaps independently on the screen. 我的意图是,然后在屏幕上独立地动画这两个不同的位图。

@Override
        protected void onDraw(Canvas canvas) {
          football = BitmapFactory.decodeResource(getResources(),
                    R.drawable.ballicon);

        receiver = BitmapFactory.decodeResource(getResources(),
                R.drawable.rec);


       canvas.drawBitmap(football, translate, null);
       canvas.drawBitmap(receiver, translate, null);


        Matrix m = canvas.getMatrix();
        Log.d(DEBUG_TAG, "Matrix: " + translate.toShortString());
        Log.d(DEBUG_TAG, "Canvas: " + m.toShortString());
    }

Thanks 谢谢

Here is a canvasview for drawing with multiple bitmaps 这是一个用于绘制多个位图的canvasview

public class AdvanceCanvasView extends View {
private Bitmap bitmap;
private Canvas bitmapCanvas;
private Bitmap mBitmapBrush;
private ArrayList<Bitmap> bitmapArrayList;
private Vector2 mBitmapBrushDimensions;
private Paint paintLine;
private List<Vector2> mPositions = new ArrayList<Vector2>(100);
private HashMap<Integer, Path> pathMap; // current Paths being drawn
private HashMap<Integer, Point> previousPointMap; // current Points
private int i = 0;

private static final class Vector2 {
    public Vector2(float x, float y) {
        this.x = x;
        this.y = y;
    }

    public final float x;
    public final float y;
}

@SuppressLint("UseSparseArrays")
public AdvanceCanvasView(Context context, AttributeSet attrs) {
    super(context, attrs); // pass context to View's constructor
}

public AdvanceCanvasView(Context c) {
    super(c);
    pathMap = new HashMap<>();
    previousPointMap = new HashMap<>();
    bitmapArrayList = new ArrayList<>();
    paintLine = new Paint();
}

@Override
public void onSizeChanged(int w, int h, int oldW, int oldH) {
    bitmap = Bitmap.createBitmap(getWidth(), getHeight(),
            Bitmap.Config.ARGB_8888);
    bitmapCanvas = new Canvas(bitmap);
}

@Override
protected void onDraw(Canvas canvas) {
    canvas.drawBitmap(bitmap, 0, 0, null);
    for (int i = 0; i < mPositions.size(); i++) {
        canvas.drawBitmap(bitmapArrayList.get(i), mPositions.get(i).x, mPositions.get(i).y, null);
    }

}

@Override
public boolean onTouchEvent(MotionEvent event) {
    int action = event.getActionMasked();
    int actionIndex = event.getActionIndex();

    if (action == MotionEvent.ACTION_DOWN
            || action == MotionEvent.ACTION_POINTER_DOWN) {
        touchStarted(event.getX(actionIndex), event.getY(actionIndex),
                event.getPointerId(actionIndex));
    }
    else if (action == MotionEvent.ACTION_UP
            || action == MotionEvent.ACTION_POINTER_UP) {
        touchEnded(event.getPointerId(actionIndex));
    }
    else {
        touchMoved(event);
    }

    invalidate();

    return true;
}

private void touchStarted(float x, float y, int lineID) {
    Path path;
    Point point;
    path = new Path(); // create a new Path
    pathMap.put(lineID, path); // add the Path to Map
    point = new Point(); // create a new Point
    previousPointMap.put(lineID, point); // add the Point to the Map
    path = new Path(); // create a new Path
    point = new Point(); // create a new Point
    path.moveTo(x, y);
    point.x = (int) x;
    point.y = (int) y;

} // end method touchStarted

private void touchMoved(MotionEvent event) {
    // for each of the pointers in the given MotionEvent
    for (int i = 0; i < event.getPointerCount(); i++) {
        final float posX = event.getX();
        final float posY = event.getY();
        mPositions.add(new Vector2(posX - mBitmapBrushDimensions.x / 2, posY - mBitmapBrushDimensions.y / 2));
        bitmapArrayList.add(mBitmapBrush);
    }
    invalidate();

}

private void touchEnded(int lineID) {
    Path path = pathMap.get(lineID);
    path.reset();
}

public void init(Bitmap bitmap) {
    mBitmapBrush = bitmap;
    BitmapShader shader = new BitmapShader(mBitmapBrush, Shader.TileMode.MIRROR, Shader.TileMode.MIRROR);
    paintLine.setShader(shader);
    mBitmapBrushDimensions = new Vector2(mBitmapBrush.getWidth(), mBitmapBrush.getHeight());
}

}

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM