Ответ 1
Спустя три года кажется, что этот вопрос зафиксирован в Lollipop. (Последний комментарий к этой теме).
Поэтому я отвечаю на свой вопрос.
Рассмотрим сценарий, как на этом рисунке:
Три фотографии, один из которых - большой GIF файл (3MP).
Я запрашиваю MediaStore, чтобы получить соответствующие миниатюры. Если я инициализирую курсор через CursorLoader с помощью этого sortOrder:
MediaStore.Images.Media.DATE_ADDED + " DESC""
Что происходит:. MediaStore возвращает предыдущую удаленную эскиз:
Ожидаемое поведение:, когда MediaStore не может получить эскиз данного изображения по какой-либо причине, он должен вернуть NULL в соответствии с его Javadoc: "... Возвращает экземпляр Bitmap. Он может быть нулевым если исходное изображение, связанное с origId, не существует или памяти недостаточно."
Если я инициализирую курсор с помощью этого sortOrder:
MediaStore.Images.Media.DATE_ADDED + " ASC""
Он работает отлично:
Однако я не могу просто изменить sortOrder, так как требование состоит в том, чтобы сначала показывать самые новые фотографии.
Ниже мой пример кода и вот полный образец проекта, а также три изображения, используемые для воспроизведения.
package com.example.getimagefrommediastore;
import android.app.Activity;
import android.database.Cursor;
import android.graphics.Bitmap;
import android.os.Bundle;
import android.provider.MediaStore;
import android.support.v4.content.CursorLoader;
import android.widget.ImageView;
import android.widget.TextView;
public class GetThumbnailsFromMediaStoreSampleActivity extends Activity {
TextView mThumb_id_01;
TextView mThumb_id_02;
TextView mThumb_id_03;
ImageView mImg_01;
ImageView mImg_02;
ImageView mImg_03;
boolean isThumb01 = true; // Simple flag to control this example
boolean isThumb02 = true;
Cursor mCursorLoader;
int mColumnIndex;
long mOrigId; // Original image id associated with thumbnail of interest
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
// Just initializing views
mThumb_id_01 = (TextView) findViewById(R.id.thumb_id_01);
mThumb_id_02 = (TextView) findViewById(R.id.thumb_id_02);
mThumb_id_03 = (TextView) findViewById(R.id.thumb_id_03);
mImg_01 = (ImageView) findViewById(R.id.thumb_01);
mImg_02 = (ImageView) findViewById(R.id.thumb_02);
mImg_03 = (ImageView) findViewById(R.id.thumb_03);
// Initializing CursorLoader
mCursorLoader = initializeCursorLoader();
mColumnIndex = mCursorLoader.getColumnIndex(MediaStore.Images.Media._ID);
// Go thru all the images in the device (EXTERNAL_CONTENT_URI)
// In this example there are only three images
for (int i = 0; i < mCursorLoader.getCount(); i++) {
mCursorLoader.moveToPosition(i);
mOrigId = mCursorLoader.getInt(mColumnIndex);
// Update views
chooseViewToUpdate();
}
}
private Cursor initializeCursorLoader() {
String[] COLUMNS = {
MediaStore.Images.Thumbnails._ID, MediaStore.Images.Media.DATA
};
CursorLoader cursorLoader = new CursorLoader(
GetThumbnailsFromMediaStoreSampleActivity.this, // Context
MediaStore.Images.Media.EXTERNAL_CONTENT_URI, // Uri
COLUMNS, // Projection
null, // Selection
null, // Selection Args
// Sort Order: DESC = newest first
// Sort Order: ASC = oldest first
MediaStore.Images.Media.DATE_ADDED + " DESC");
// *** NOTE ***
// With:
//
// MediaStore.Images.Media.DATE_ADDED + " ASC"
//
// It runs just fine (MediaStore returns 'null' for invalid thumbnails)
// The problem seems to reside on the " DESC" tag.
//
// How bizarre is that?
return cursorLoader.loadInBackground();
}
private void chooseViewToUpdate() {
if (isThumb01) {
updateUI(mThumb_id_01, mImg_01);
isThumb01 = false;
} else if (isThumb02) {
updateUI(mThumb_id_02, mImg_02);
isThumb02 = false;
} else {
updateUI(mThumb_id_03, mImg_03);
}
}
private void updateUI(TextView textView, ImageView imgView) {
textView.setText("ID:" + String.valueOf(mOrigId));
Bitmap mediaStoreThumbmail = MediaStore.Images.Thumbnails.getThumbnail(
this.getContentResolver(),
mOrigId,
MediaStore.Images.Thumbnails.MICRO_KIND, null);
if (mediaStoreThumbmail != null) {
imgView.setImageBitmap(mediaStoreThumbmail);
}
}
Я что-то упустил? Кто-нибудь может понять, что может быть неправильным?
Я все равно заполнил ошибку для Android.
ИЗМЕНИТЬ
Кажется, что эта проблема исправлена в Lollipop. (Последний комментарий к этому потоку).
Спустя три года кажется, что этот вопрос зафиксирован в Lollipop. (Последний комментарий к этой теме).
Поэтому я отвечаю на свой вопрос.
Я просто догадываюсь здесь. Когда вы запрашиваете MICRO_KIND, os создает новое изображение, которое снова входит в строку на курсе DESC, воспроизводя то же изображение снова.
Одна работа заключается в загрузке ArrayList для идентификатора изображения. Затем пойдите после миниатюр, работающих с ArrayList.
Возможность попробовать свой код с помощью MINI_KIND и bmoptions.inSampleSize = 2;
final BitmapFactory.Options bmOptions = new BitmapFactory.Options();
bmOptions.inSampleSize =2;
Bitmap bm = MediaStore.Images.Thumbnails.getThumbnail(
context.getContentResolver(), newImageId,
MediaStore.Images.Thumbnails.MINI_KIND,
bmOptions);