how to store and retrieve images in android SQLite database and display them on a gridview

前端 未结 2 1277
情话喂你
情话喂你 2020-12-28 09:29

I am new to android. I created a table that has an itemName,Price and image. I am trying to retrieve the image and name fields and display them on a gridview

Here is

相关标签:
2条回答
  • 2020-12-28 09:53

    It depends on how you want to store your Image, because you are storing as a byte array here is how to retrieve it

      public Cursor fetchAll() {
                return databaseHelper.query(ITEMS_TABLE, new String[] { COLUMN_ITEM_ID,   COLUMN_ITEM_NAME, COLUMN_ITEM_SPECS,COLUMN_ITEM_PRICE, COLUMN_ITEM_IMAGE,COLUMN_ITEM_QTY},null, null, null, null, null);
            }
    /*    this method will give you a cursor with all the records of your database table now you need to parse these records on to objects*/
    
    private List<ItemsPojo> parse(Cursor cursor) {
         List<ItemsPojo> toReturn = null;
         toReturn = new ArrayList<SignImage>();
         ItemsPojo obj;
         if (cursor.moveToFirst()) {
              while (cursor.isAfterLast() == false) {
                   obj = new ItemsPojo();
                   obj.setId(cursor.getInt(0));
                   obj.setItemName(cursor.getString(1));
                   obj.setItemSpecs(cursor.getString(2));
                   obj.setItemPrice(cursor.getDouble(3));
                   obj.setItemImg(cursor.getBlob(4));
                   obj.setItemQuantity(cursor.getInt(5));
                   toReturn.add(obj);
                   cursor.moveToNext();
                   }
         }return toReturn;
    }
    

    now you have a List with all your records on your database, now what you need to do is create a ListActivity and show all your objects on it, If you dont know how to do this please post your comment here or if you have any doubt about the procedure above

    0 讨论(0)
  • 2020-12-28 10:09

    The most efficient (and btw, most straight forward approach) is to save a bytearray of the image in your local database. For that you'll just need to use a TEXT datatype in your database. Like this:

    CREATE TABLE IF NOT EXISTS Your_table ( id INTEGER PRIMARY KEY NOT NULL UNIQUE, someOtherField TEXT, pictureData TEXT);
    

    There's one seamless way to avoid dealing with conversions: Just convert to Bitmap and back to bytearray in your setters and getters in such a way that you don't need to care about that in the whole dev cycle. Let's go for an example. Let's say you have an object user which is stored in your localDB for which you have an avatar.

    public class User {
    
        private String email;
        private String name;
        private Drawable pictureDataDrawable;
    
        public User() {}
    
        public void setPictureData(byte[] pictureData) {
            pictureDataDrawable = ImageUtils.byteToDrawable(pictureData);
        }
    
        public byte[] getPictureData(){
            return ImageUtils.drawableToByteArray(pictureDataDrawable);
        }
    
    }
    

    And wherever you retrieve your data from DB it'll be enough with adding something like that:

    user.setPictureData(cursor.getBlob(cursor.getColumnIndexOrThrow(DB_PICTURE_DATA_KEY)));
    

    For the opposite way (writing the drawable to DB):

    ContentValues c = new ContentValues();
    c.put(DB_PICTURE_DATA_KEY, user.getPictureData());
    ...
    

    Finally two easy methods in your ImageUtils to convert back and forth:

    public static byte[] drawableToByteArray(Drawable d) {
    
        if (d != null) {
            Bitmap imageBitmap = ((BitmapDrawable) d).getBitmap();
            ByteArrayOutputStream baos = new ByteArrayOutputStream();
            imageBitmap.compress(Bitmap.CompressFormat.PNG, 100, baos);
            byte[] byteData = baos.toByteArray();
    
            return byteData;
        } else
            return null;
    
    }
    
    
    public static Drawable byteToDrawable(byte[] data) {
    
        if (data == null)
            return null;
        else
            return new BitmapDrawable(BitmapFactory.decodeByteArray(data, 0, data.length));
    }
    

    And you're good to go.

    0 讨论(0)
提交回复
热议问题