Почему Bitmap to Base64 String показывает черный фон в веб-просмотре в Android?

Я использую код, который объединяет изображения в 1 с помощью canvas. Я показываю это изображение в ImageView, оно выглядит нормально. Но когда я пытаюсь показать это в WebView, он показывает черный фон справа от этого изображения. Я пытаюсь изменить цвет фона в HTML, но он не меняет цвет. или сделать прозрачным. Кто-нибудь может помочь? Результат здесь Изображение выше находится в ImageView, а ниже — в WebView.

public class MyBimapTest extends Activity {
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);

    ImageView img1 = (ImageView) findViewById(R.id.ImageView01);

    img1.setVisibility(View.INVISIBLE);
    Drawable dra1 = img1.getDrawable();
    Bitmap map1 = ((BitmapDrawable) dra1).getBitmap();
    ImageView img2 = (ImageView) findViewById(R.id.ImageView02);
    img2.setVisibility(View.INVISIBLE);
    Drawable dra2 = img2.getDrawable();
    Bitmap map2 = ((BitmapDrawable) dra2).getBitmap();

    // ***
    ByteArrayOutputStream baos = new ByteArrayOutputStream();
    map1.compress(Bitmap.CompressFormat.JPEG, 100, baos);

    byte[] b = baos.toByteArray();
    String abc = Base64.encodeBytes(b);

    byte[] byt = null;
    try {
        byt = Base64.decode(abc);
    } catch (IOException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
    }
    map1 = BitmapFactory.decodeByteArray(byt, 0, byt.length);

    // ***
    Bitmap map = combineImages(map1, map2);
    ByteArrayOutputStream bbb = new ByteArrayOutputStream();
    map.compress(Bitmap.CompressFormat.JPEG, 100, bbb);

    byte[] bit = bbb.toByteArray();

    String imgToString = Base64.encodeBytes(bit);

    String imgTag = "<img src='data:image/jpg;base64," + imgToString
            + "' align='left' bgcolor='ff0000'/>";

    WebView webView = (WebView) findViewById(R.id.storyView);
    webView.loadData(imgTag, "text/html", "utf-8");
    Drawable end = new BitmapDrawable(map);

    ImageView img3 = (ImageView) findViewById(R.id.ImageView03);
    img3.setImageBitmap(map);
}

public Bitmap combineImages(Bitmap c, Bitmap s) { 
    Bitmap cs = null;
    int width, height = 0;

    width = c.getWidth() + (s.getWidth() / 2);
    height = c.getHeight() + (s.getHeight() / 2);

    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() - (s.getWidth() / 2), c
            .getHeight()
            - (s.getHeight() / 2), null);
    return cs;
}

}


person Arslan Anwar    schedule 27.02.2011    source источник


Ответы (1)


Формат JPEG не поддерживает альфа-прозрачность, поэтому прозрачный фон становится черным при преобразовании исходного изображения в формат JPEG.

Вместо этого используйте формат PNG:

 map1.compress(Bitmap.CompressFormat.PNG, 100, baos); 

и

String imgTag = "<img src='data:image/png;base64," + imgToString               
    + "' align='left' bgcolor='ff0000'/>";   
person MusiGenesis    schedule 27.02.2011
comment
Большое спасибо ... раньше использовал формат сжатия JPEG. получить более подробную информацию здесь developer.android.com/reference/android/graphics/ - person CoDe; 10.10.2013
comment
Однако идеальный ответ до сжатия(). Где применить imgTag? Не могли бы вы мне помочь? - person VVB; 10.11.2016
comment
@VVB: две строки, которые я добавил в свой ответ, являются модификациями кода, опубликованного OP. В его коде найдите строку webView.loadData(imgTag, "text/html", "utf-8"); — это место, где тег добавляется к создаваемой веб-странице. - person MusiGenesis; 11.11.2016