Yuvaraj
Yuvaraj

Reputation: 251

Combining two bitmap image (side by side)

Can any one help to combine two bitmap images into single bitmap

in android (Side by side).

Thanks, Yuvaraj

Upvotes: 22

Views: 29175

Answers (4)

MonOve
MonOve

Reputation: 1101

Here's a function that will merge an array of bitmaps horizontally or vertically:

public Bitmap combineBitmaps(ArrayList<Bitmap> bitmaps, Boolean isHorizontal) {
    int w = 0, h = 0;
    for (int i = 0; i < bitmaps.size(); i++) {
        if(i == 0 || isHorizontal){
            w += bitmaps.get(i).getWidth();
        } else if(!isHorizontal && bitmaps.get(i).getWidth() > w) {
            w = bitmaps.get(i).getWidth();
        }
        if(i == 0 || !isHorizontal){
            h += bitmaps.get(i).getHeight();
        } else if(isHorizontal && bitmaps.get(i).getHeight() > h) {
            h = bitmaps.get(i).getHeight();
        }
    }
    Bitmap bitmap = Bitmap.createBitmap(w, h, Bitmap.Config.ARGB_8888);
    Canvas canvas = new Canvas(bitmap);
    int pos = 0;
    for (int i = 0; i < bitmaps.size(); i++) {
        if(isHorizontal){
            canvas.drawBitmap(bitmaps.get(i), pos, 0f, null);
        } else {
            canvas.drawBitmap(bitmaps.get(i), 0f, pos, null);
        }
        pos += isHorizontal ? bitmaps.get(i).getWidth() : bitmaps.get(i).getHeight();
    }
    return bitmap;
}

Upvotes: 0

crobicha
crobicha

Reputation: 1835

I ended up modifying xil3's answer into a kotlin extension function, maybe it will be useful to someone. In my case I wanted the images stacked vertically

fun Bitmap?.combine(b: Bitmap?): Bitmap? =
when {
    b == null || this == null -> {
        this ?: b
    } else -> {
        val cs = Bitmap.createBitmap(
            max(this.width, b.width),
            this.height + b.height,
            Bitmap.Config.ARGB_8888
        )
        val canvas = Canvas(cs)
        canvas.drawBitmap(this, 0f, 0f, null)
        canvas.drawBitmap(b, 0f, this.height.toFloat(), null)
        cs
    }
}

Upvotes: 1

Farmaker
Farmaker

Reputation: 2790

Excellent work the selected answer. If you want to do it with array list of bitmaps and side by side look below:

private Bitmap combineImageIntoOneFlexWidth(ArrayList<Bitmap> bitmap) {
        int w = 0, h = 0;
        for (int i = 0; i < bitmap.size(); i++) {
            if (i < bitmap.size() - 1) {
                h = bitmap.get(i).getHeight() > bitmap.get(i + 1).getHeight() ? bitmap.get(i).getHeight() : bitmap.get(i + 1).getHeight();
            }
            w += bitmap.get(i).getWidth();
        }

        Bitmap temp = Bitmap.createBitmap(w, h, Bitmap.Config.ARGB_8888);
        Canvas canvas = new Canvas(temp);
        int top = 0;
        for (int i = 0; i < bitmap.size(); i++) {
            Log.e("HTML", "Combine: " + i + "/" + bitmap.size() + 1);

            top = (i == 0 ? 0 : top + bitmap.get(i).getWidth());
            //attributes 1:bitmap,2:width that starts drawing,3:height that starts drawing
            canvas.drawBitmap(bitmap.get(i), top, 0f, null);
        }
        return temp;
    }

Upvotes: 0

xil3
xil3

Reputation: 16439

You can use Canvas - check out this article:

http://www.jondev.net/articles/Combining_2_Images_in_Android_using_Canvas

Updated code to do it side by side:

public Bitmap combineImages(Bitmap c, Bitmap s) { // can add a 3rd parameter 'String loc' if you want to save the new image - left some code to do that at the bottom 
    Bitmap cs = null; 

    int width, height = 0; 

    if(c.getWidth() > s.getWidth()) { 
      width = c.getWidth() + s.getWidth(); 
      height = c.getHeight(); 
    } else { 
      width = s.getWidth() + s.getWidth(); 
      height = c.getHeight(); 
    } 

    cs = Bitmap.createBitmap(width, height, Bitmap.Config.ARGB_8888); 

    Canvas comboImage = new Canvas(cs); 

    comboImage.drawBitmap(c, 0f, 0f, null); 
    comboImage.drawBitmap(s, c.getWidth(), 0f, null); 

    // this is an extra bit I added, just incase you want to save the new image somewhere and then return the location 
    /*String tmpImg = String.valueOf(System.currentTimeMillis()) + ".png"; 

    OutputStream os = null; 
    try { 
      os = new FileOutputStream(loc + tmpImg); 
      cs.compress(CompressFormat.PNG, 100, os); 
    } catch(IOException e) { 
      Log.e("combineImages", "problem combining images", e); 
    }*/ 

    return cs; 
  } 

Upvotes: 75

Related Questions