package com.seafile.seadroid2.gallery; import java.util.HashMap; import java.util.List; import android.content.ContentResolver; import android.database.Cursor; import android.net.Uri; import android.provider.MediaStore.Images.Media; import com.google.common.base.Joiner; import com.google.common.collect.Lists; import com.google.common.collect.Maps; /** * Represents an ordered collection of Image objects. Provides an API to add * and remove an image. */ public class ImageList extends BaseImageList implements IImageList { @SuppressWarnings("unused") private static final String TAG = "ImageList"; private static final String[] ACCEPTABLE_IMAGE_TYPES = new String[] { "image/jpeg", "image/png", "image/gif" }; public HashMap<String, String> getBucketIds() { Uri uri = mBaseUri.buildUpon() .appendQueryParameter("distinct", "true").build(); Cursor cursor = Media.query( mContentResolver, uri, new String[] { Media.BUCKET_DISPLAY_NAME, Media.BUCKET_ID}, whereClause(), whereClauseArgs(), null); try { HashMap<String, String> hash = Maps.newHashMap(); while (cursor.moveToNext()) { hash.put(cursor.getString(1), cursor.getString(0)); } return hash; } finally { cursor.close(); } } /** * ImageList constructor. */ public ImageList(ContentResolver resolver, Uri imageUri, int sort, String bucketId) { super(resolver, imageUri, sort, bucketId); } private static final String WHERE_CLAUSE = "(" + Media.MIME_TYPE + " in (?, ?, ?))"; protected String whereClause() { int count = ImageManager.getAllBucketIds().size(); List<String> chars = Lists.newArrayList(); for (int i = 0; i < count; i++) { chars.add("?"); } String clause = WHERE_CLAUSE + " AND " + Media.BUCKET_ID + " in " + "(" + Joiner.on(", ").join(chars) + ")"; return clause; } protected String[] whereClauseArgs() { int count = ACCEPTABLE_IMAGE_TYPES.length; List<String> ids = ImageManager.getAllBucketIds(); int idsCount = ids.size(); String[] result = new String[count + idsCount]; System.arraycopy(ACCEPTABLE_IMAGE_TYPES, 0, result, 0, count); for (int i = 0; i < idsCount; i++) { result[count + i] = ids.get(i); } return result; } @Override protected Cursor createCursor() { Cursor c = Media.query( mContentResolver, mBaseUri, IMAGE_PROJECTION, whereClause(), whereClauseArgs(), sortOrder()); return c; } static final String[] IMAGE_PROJECTION = new String[] { Media._ID, Media.DATA, Media.DATE_TAKEN, Media.MINI_THUMB_MAGIC, Media.ORIENTATION, Media.TITLE, Media.MIME_TYPE, Media.DATE_MODIFIED}; private static final int INDEX_ID = 0; private static final int INDEX_DATA_PATH = 1; private static final int INDEX_DATE_TAKEN = 2; private static final int INDEX_MINI_THUMB_MAGIC = 3; private static final int INDEX_ORIENTATION = 4; private static final int INDEX_TITLE = 5; private static final int INDEX_MIME_TYPE = 6; private static final int INDEX_DATE_MODIFIED = 7; @Override protected long getImageId(Cursor cursor) { return cursor.getLong(INDEX_ID); } @Override protected BaseImage loadImageFromCursor(Cursor cursor) { long id = cursor.getLong(INDEX_ID); String dataPath = cursor.getString(INDEX_DATA_PATH); long dateTaken = cursor.getLong(INDEX_DATE_TAKEN); if (dateTaken == 0) { dateTaken = cursor.getLong(INDEX_DATE_MODIFIED) * 1000; } long miniThumbMagic = cursor.getLong(INDEX_MINI_THUMB_MAGIC); int orientation = cursor.getInt(INDEX_ORIENTATION); String title = cursor.getString(INDEX_TITLE); String mimeType = cursor.getString(INDEX_MIME_TYPE); if (title == null || title.length() == 0) { title = dataPath; } return new Image(this, mContentResolver, id, cursor.getPosition(), contentUri(id), dataPath, mimeType, dateTaken, title, orientation); } }