Android: как запросить список имен ковша
Я хочу получить только имя ведра (Альбомы). Например. Камера, загрузка и т.д., Но не список камер, загрузка и т.д. Из всех фотографий, так как я могу получить по одной строке для каждого имени ведра?
Что я имею в виду, например, в приложении "Галерея", у вас есть альбомы сначала, например. Камера. Когда вы нажмете на него, он покажет все фотографии камеры.
Я могу запросить фотографии в Camera Roll с предложением Where в запросе. Но что, если я хочу только имя каждого из имен альбомов, а не фотографии, можно ли это запросить? Если я запрошу все фотографии и сделаю только одну строку для каждого набора фотографий, тогда это займет много времени.
Пожалуйста, помогите
Ответы
Ответ 1
У меня такая же проблема, и вот мое решение (после отслеживания исходного кода галереи), чтобы получить название альбома и первое изображение в нем (можно использовать в качестве миниатюры для этого альбома):
(Обратите внимание, что повторение ковша удаляется методом groupby и order)
// which image properties are we querying
String[] PROJECTION_BUCKET = {
ImageColumns.BUCKET_ID,
ImageColumns.BUCKET_DISPLAY_NAME,
ImageColumns.DATE_TAKEN,
ImageColumns.DATA};
// We want to order the albums by reverse chronological order. We abuse the
// "WHERE" parameter to insert a "GROUP BY" clause into the SQL statement.
// The template for "WHERE" parameter is like:
// SELECT ... FROM ... WHERE (%s)
// and we make it look like:
// SELECT ... FROM ... WHERE (1) GROUP BY 1,(2)
// The "(1)" means true. The "1,(2)" means the first two columns specified
// after SELECT. Note that because there is a ")" in the template, we use
// "(2" to match it.
String BUCKET_GROUP_BY =
"1) GROUP BY 1,(2";
String BUCKET_ORDER_BY = "MAX(datetaken) DESC";
// Get the base URI for the People table in the Contacts content provider.
Uri images = MediaStore.Images.Media.EXTERNAL_CONTENT_URI;
Cursor cur = getContentResolver().query(
images, PROJECTION_BUCKET, BUCKET_GROUP_BY, null, BUCKET_ORDER_BY);
Log.i("ListingImages"," query count=" + cur.getCount());
if (cur.moveToFirst()) {
String bucket;
String date;
String data;
int bucketColumn = cur.getColumnIndex(
MediaStore.Images.Media.BUCKET_DISPLAY_NAME);
int dateColumn = cur.getColumnIndex(
MediaStore.Images.Media.DATE_TAKEN);
int dataColumn = cur.getColumnIndex(
MediaStore.Images.Media.DATA);
do {
// Get the field values
bucket = cur.getString(bucketColumn);
date = cur.getString(dateColumn);
data = cur.getString(dataColumn);
// Do something with the values.
Log.i("ListingImages", " bucket=" + bucket
+ " date_taken=" + date
+ " _data=" + data);
} while (cur.moveToNext());
}
Ответ 2
Вот он. он работает для меня:
Uri images = MediaStore.Images.Media.EXTERNAL_CONTENT_URI;
String[] projection = new String[]{
MediaStore.Images.Media.BUCKET_ID,
MediaStore.Images.Media.BUCKET_DISPLAY_NAME,
MediaStore.Images.Media.DATE_TAKEN,
MediaStore.Images.Media.DATA
};
String BUCKET_ORDER_BY = MediaStore.Images.Media.DATE_MODIFIED + " DESC";
String BUCKET_GROUP_BY = "1) GROUP BY 1,(2";
Cursor imagecursor = managedQuery(images,
projection, // Which columns to return
BUCKET_GROUP_BY, // Which rows to return (all rows)
null, // Selection arguments (none)
BUCKET_ORDER_BY // Ordering
);
this.imageUrls = new ArrayList<String>();
this.imageBuckets = new ArrayList<String>();
for (int i = 0; i < imagecursor.getCount(); i++)
{
imagecursor.moveToPosition(i);
int bucketColumnIndex = imagecursor.getColumnIndex(MediaStore.Images.Media.BUCKET_DISPLAY_NAME);
String bucketDisplayName = imagecursor.getString(bucketColumnIndex);
imageBuckets.add(bucketDisplayName);
int dataColumnIndex = imagecursor.getColumnIndex(MediaStore.Images.Media.DATA);
imageUrls.add(imagecursor.getString(dataColumnIndex));
}
imageBuckets Arraylist содержит названия альбомов
imageUrls Arraylist содержит путь последнего измененного изображения альбома, вы можете использовать его как миниатюру
Ответ 3
Используйте следующую функцию для получения альбомов видео или изображений:
/*
*
* Author : @nieldeokar
* mediaType could be one of
*
* public static final int MEDIA_TYPE_IMAGE = 1;
*
* public static final int MEDIA_TYPE_VIDEO = 3;
*
* from android.provider.MediaStore class
*
*/
fun getAlbumList(mediaType: Int, contentResolver: ContentResolver) {
val countColumnName = "count"
var contentUri = MediaStore.Images.Media.EXTERNAL_CONTENT_URI
if (mediaType == MEDIA_TYPE_VIDEO) {
contentUri = MediaStore.Video.Media.EXTERNAL_CONTENT_URI
}
val projection = arrayOf(ImageColumns.BUCKET_ID, ImageColumns.BUCKET_DISPLAY_NAME, ImageColumns.DATE_TAKEN, ImageColumns.DATA)
val bucketGroupBy = "1) GROUP BY ${ImageColumns.BUCKET_ID}, (${ImageColumns.BUCKET_DISPLAY_NAME}"
val bucketOrderBy = MediaStore.Images.Media.DATE_MODIFIED + " DESC"
val cursor = contentResolver.query(contentUri, projection, bucketGroupBy, null, bucketOrderBy)
if (cursor != null) {
while (cursor.moveToNext()) {
val bucketId = cursor.getString(cursor.getColumnIndexOrThrow(MediaStore.Images.ImageColumns.BUCKET_ID))
val name = cursor.getString(cursor.getColumnIndexOrThrow(MediaStore.Images.ImageColumns.BUCKET_DISPLAY_NAME))
val path = cursor.getString(cursor.getColumnIndexOrThrow(MediaStore.MediaColumns.DATA)) // Thumb image path
val selection = MediaStore.Images.Media.BUCKET_ID + "='" + bucketId + "'"
val countCursor = contentResolver.query(contentUri, arrayOf( "count(" + MediaStore.Images.ImageColumns._ID + ")"), selection, null, null)
var count = 0
if (countCursor != null) {
countCursor.moveToFirst()
count = countCursor.getInt(0)
countCursor.close()
}
Log.d("AlbumScanner", "bucketId : $bucketId | name : $name | count : $count | path : $path")
}
cursor.close()
}
}
Это формирует SQL-выражение как:
SELECT bucket_id, bucket_display_name, datetaken, _data FROM images WHERE (1) GROUP BY bucket_id,(bucket_display_name) ORDER BY date_modified DESC
ОБНОВЛЕНИЕ:
Как отметил @PerracoLabs, этот код необходимо улучшить для таргетинга Android Q.
Ответ 4
Для этого вы можете запросить MediaStore.Images.Media.BUCKET_DISPLAY_NAME. Peter Knego отправил хороший пример. Это хороший пример, и вы можете обновить его с помощью query() из объекта ContentResolver, а не из managedQuery(), который устарел.
// which image properties are we querying
String[] projection = new String[]{
MediaStore.Images.Media._ID,
MediaStore.Images.Media.BUCKET_DISPLAY_NAME,
MediaStore.Images.Media.DATE_TAKEN
};
// Get the base URI for the People table in the Contacts content provider.
Uri images = MediaStore.Images.Media.EXTERNAL_CONTENT_URI;
// Make the query.
ContentResolver cr = getContentResolver();
Cursor cur = cr.query(images,
projection, // Which columns to return
"", // Which rows to return (all rows)
null, // Selection arguments (none)
"" // Ordering
);
Log.i("ListingImages"," query count="+cur.getCount());
if (cur.moveToFirst()) {
String bucket;
String date;
int bucketColumn = cur.getColumnIndex(
MediaStore.Images.Media.BUCKET_DISPLAY_NAME);
int dateColumn = cur.getColumnIndex(
MediaStore.Images.Media.DATE_TAKEN);
do {
// Get the field values
bucket = cur.getString(bucketColumn);
date = cur.getString(dateColumn);
// Do something with the values.
Log.i("ListingImages", " bucket=" + bucket
+ " date_taken=" + date);
} while (cur.moveToNext());
}
Ответ 5
Проецирование в запросе, как показано ниже:
String bucketProjection[] = {"Distinct "+ MediaStore.Images.Media.BUCKET_DISPLAY_NAME};