Моя таблица MySQL DB содержит BLOB-изображение с ключом image_id. Я пытаюсь сделать следующее.
1.HttpPost ("http://example.com/RetrieveImage.php") из приложения для Android с идентификатором image_id в парах значений имени.
PHP-скрипт выглядит следующим образом:
<?php
mysql_connect("host","userid","password");
mysql_select_db("database");
$q=mysql_query("SELECT image FROM testblob WHERE image_id =".$_REQUEST['image_id']."");
$e=mysql_fetch_assoc($q);
print($e);
mysql_close();
?>
httppost.setEntity(new UrlEncodedFormEntity(nameValuePairs));
InputStream is = entity.getContent();
response = httpclient.execute(httppost);
HttpEntity entity = response.getEntity();
is = entity.getContent();
Сохранить данные BLOB в объекте Inputstream в байтовом массиве
ByteArrayOutputStream baos = new ByteArrayOutputStream();
byte[] buf = new byte[10240];
int n = 0;
try {
while ((n=is.read(buf))>=0)
{
baos.write(buf, 0, n);
}
is.close();
byte[] bytes = baos.toByteArray();
Преобразование байтового массива в растровое изображение и установка ImageView виджета Android на Image
Bitmap bitmap;
RemoteViews updateViews = null;
bitmap = BitmapFactory.decodeByteArray(bytes, 0, bytes.length);
updateViews = new RemoteViews(context.getPackageName(), R.layout.tuwidget);
updateViews.setImageViewBitmap(R.id.tuwidget_img_btn, bitmap);
return updateViews;
После запуска я не знаю, почему виджет даже не отображается на эмуляторе и
даже не могу добавить виджет на экран. Что я делаю неправильно? Любая помощь очень ценится.
О, вот мой макет виджета.
<?xml version="1.0" encoding="utf-8"?>
<AbsoluteLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/tuwidget"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
>
<ImageView
android:id="@+id/tuwidget_img_btn"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
>
</ImageView>
</AbsoluteLayout>