Проблема при вставке и получении данных изображения в базе данных sqlite с помощью Android - PullRequest
2 голосов
/ 27 октября 2010

Я новичок в разработке Android. В настоящее время я сталкиваюсь с проблемой, в то время как inserting/retrieving изображение на SQLite database с использованием Android.

//code for inserting image
InputStream in = OpenHttpConnection(imgurl);

byte[] bb = new byte[in.available()];

in.read(bb);//here the length of bb is 2040

//update query

myDataBase.execSQL("Update Product SET Image='"+bb+"' Where CatPID='"+pcpid+"'");

//function OpenHttpConnection
private InputStream OpenHttpConnection(String urlString)  throws IOException
{
    InputStream in = null;
    int response = -1;

    URL url = new URL(urlString); 
    URLConnection conn = url.openConnection();

    if (!(conn instanceof HttpURLConnection))                     
        throw new IOException("Not an HTTP connection");

    try{
        HttpURLConnection httpConn = (HttpURLConnection) conn;
        httpConn.setAllowUserInteraction(false);
        httpConn.setInstanceFollowRedirects(true);
        httpConn.setRequestMethod("GET");
        httpConn.connect(); 

        response = httpConn.getResponseCode();                 
        if (response == HttpURLConnection.HTTP_OK) {
            in = httpConn.getInputStream();                                 
        }                     
    }
    catch (Exception ex)
    {
        throw new IOException("Error connecting");            
    }
    return in;     
}

//code for retrieve image from database

byte[] bb = cursor.getBlob(cursor.getColumnIndex("Image"));//here length is only 12

ByteArrayInputStream imageStream = new ByteArrayInputStream(bb);

Bitmap theImage = BitmapFactory.decodeStream(imageStream);

img.setImageBitmap(theImage);

Но изображение не отображается. Журнал показывает, что "Фабрика вернула ноль"

Может ли кто-нибудь помочь мне выяснить, в чем я не прав, и предоставить мне фрагмент кода рабочего решения?

Заранее спасибо

1 Ответ

0 голосов
/ 27 октября 2010

Вы можете использовать decodeByteArray:

final byte[] image_byte = c.getBlob(0);
Bitmap image_bitmap = BitmapFactory.decodeByteArray(image_byte, 0, image_byte.length);

и, возможно, Bitmap.createScaledBitmap (), чтобы при необходимости изменить его масштаб.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...