diff options
author | Tor Lillqvist <tlillqvist@suse.com> | 2012-05-31 16:13:19 +0300 |
---|---|---|
committer | Tor Lillqvist <tlillqvist@suse.com> | 2012-05-31 16:20:54 +0300 |
commit | 8c803ef23294288001f9f1557c9777ffa3e5586e (patch) | |
tree | 916ff587eb66049c282dfe4ec79f2b505ecb7aa0 /android/experimental | |
parent | 9776138e973e22cfd4ae418782ab87d01335ad22 (diff) |
Display the rendered document
Change-Id: Ie0735d4eb903b38a44bef8110bf520cfde54cb09
Diffstat (limited to 'android/experimental')
-rw-r--r-- | android/experimental/DocumentLoader/src/org/libreoffice/android/examples/DocumentLoader.java | 69 |
1 files changed, 62 insertions, 7 deletions
diff --git a/android/experimental/DocumentLoader/src/org/libreoffice/android/examples/DocumentLoader.java b/android/experimental/DocumentLoader/src/org/libreoffice/android/examples/DocumentLoader.java index c39741e9f93d..0778ad95143e 100644 --- a/android/experimental/DocumentLoader/src/org/libreoffice/android/examples/DocumentLoader.java +++ b/android/experimental/DocumentLoader/src/org/libreoffice/android/examples/DocumentLoader.java @@ -29,8 +29,13 @@ package org.libreoffice.android.examples; import android.app.Activity; +import android.graphics.Bitmap; import android.os.Bundle; import android.util.Log; +import android.widget.ImageView; + +import java.nio.ByteBuffer; +import java.nio.ByteOrder; import com.sun.star.uno.UnoRuntime; @@ -128,12 +133,18 @@ public class DocumentLoader Log.i(TAG, " " + t.getTypeName()); } - static void dumpBytes(byte[] image) + static void dumpBytes(String imageName, byte[] image) { - for (int i = 0; i < 160; i += 16) { + if (image == null) { + Log.i(TAG, imageName + " is null"); + return; + } + Log.i(TAG, imageName + " is " + image.length + " bytes"); + + for (int i = 0; i < Math.min(image.length, 160); i += 16) { String s = ""; - for (int j = 0; j < 16; j++) - s = s + String.format(" %02x", image[i+j]); + for (int j = i; j < Math.min(image.length, i+16); j++) + s = s + String.format(" %02x", image[j]); Log.i(TAG, s); } @@ -202,13 +213,16 @@ public class DocumentLoader String[] inputs = input.split(":"); for (int i = 0; i < inputs.length; i++) { com.sun.star.beans.PropertyValue loadProps[] = - new com.sun.star.beans.PropertyValue[2]; + new com.sun.star.beans.PropertyValue[3]; loadProps[0] = new com.sun.star.beans.PropertyValue(); loadProps[0].Name = "Hidden"; loadProps[0].Value = new Boolean(true); loadProps[1] = new com.sun.star.beans.PropertyValue(); loadProps[1].Name = "ReadOnly"; loadProps[1].Value = new Boolean(true); + loadProps[2] = new com.sun.star.beans.PropertyValue(); + loadProps[2].Name = "Preview"; + loadProps[2].Value = new Boolean(true); String sUrl = "file://" + inputs[i]; @@ -278,9 +292,50 @@ public class DocumentLoader byte[] image = bitmap.getDIB(); - Log.i(TAG, "image is " + image.length + " bytes"); + dumpBytes("image", image); + + byte[] mask = bitmap.getMaskDIB(); + + dumpBytes("mask", mask); + + if (image[0] != 'B' || image[1] != 'M') { + Log.e(TAG, "getDIB() didn't return a BMP file"); + return; + } + + ByteBuffer imagebb = ByteBuffer.wrap(image); + imagebb.order(ByteOrder.LITTLE_ENDIAN); + + if (imagebb.getInt(0x0e) != 40) { + Log.e(TAG, "getDIB() didn't return a DIB with BITMAPINFOHEADER"); + return; + } + + if (imagebb.getShort(0x1c) != 24) { + Log.e(TAG, "getDIB() didn't return a 24 bpp DIB"); + return; + } + + if (imagebb.getInt(0x1e) != 0) { + Log.e(TAG, "getDIB() didn't return a BI_RGB DIB"); + return; + } + + int width = imagebb.getInt(0x12); + int height = imagebb.getInt(0x16); + + ByteBuffer argb = ByteBuffer.allocateDirect(width * height * 4); + + Bootstrap.twiddle_BGR_to_RGBA(image, imagebb.getInt(0x0a), width, height, argb); + + ImageView imageView = new ImageView(this); + + Bitmap bm = Bitmap.createBitmap(width, height, Bitmap.Config.ARGB_8888); + bm.copyPixelsFromBuffer(argb); + + imageView.setImageBitmap(bm); - dumpBytes(image); + setContentView(imageView); } } catch (Exception e) { |