Permisos de autorización obligatorios
El permiso photoslibrary.readonly
permite el acceso a todos los elementos multimedia de la biblioteca del usuario.
Para buscar y aplicar filtros al contenido creado por apps, se requiere el permiso photoslibrary.readonly.appcreateddata
. Para obtener más información sobre los permisos, consulta Permisos de autorización.
Filtros disponibles
Puedes buscar tipos específicos de contenido multimedia en la biblioteca de elementos multimedia creados por la app de un usuario. Por ejemplo, es posible que solo quieras elementos de animales, de un día determinado, o que quieras excluir fotos de recibos. Puedes excluir o incluir elementos específicos aplicando filtros a una ficha de álbum o biblioteca. Hay cinco filtros disponibles basados en las propiedades de los elementos multimedia:
- Categorías de contenido (
includedContentCategories
,excludedContentCategories
) - Fechas y períodos (
dates
,ranges
) - Funciones (
featureFilter
) - Tipos de medios (
mediaTypeFilter
) - Estado de archivo (
includeArchivedMedia
)
Los filtros no deben usarse en una solicitud mediaItems.search
si se configuró albumId
. Si se usa un filtro cuando se establece el albumId, se muestra un error INVALID_ARGUMENT
(400).
Los resultados se ordenan según la hora de creación del elemento multimedia. El orden de clasificación se puede modificar para las consultas que usan filtros de fecha.
Espera un tiempo para que los medios subidos recientemente aparezcan en tus búsquedas. El contenido multimedia aparecerá en las búsquedas sin filtrar de inmediato.
Los elementos multimedia que tienen una fecha futura no aparecen en las búsquedas filtradas. Aparecen en búsquedas sin filtro y en búsquedas de álbumes.
Aplicar un filtro
Para aplicar un filtro, llama a mediaItems.search
y especifica la propiedad filter
.
REST
Esta es una solicitud POST:
POST https://photoslibrary.googleapis.com/v1/mediaItems:search Content-type: application/json Authorization: Bearer oauth2-token { "pageSize": "100", "filters": { ... } }
La solicitud POST muestra la siguiente respuesta:
{ "mediaItems": [ ... ], "nextPageToken": "token-for-pagination" }
Java
try { // Create a new Filter object Filters filters = Filters.newBuilder() // .setContentFilter(...) // .setDateFilter(...) // ... .build(); // Specify the Filter object in the searchMediaItems call SearchMediaItemsPagedResponse response = photosLibraryClient.searchMediaItems(filters); for (MediaItem item : response.iterateAll()) { // ... } } catch (ApiException e) { // Handle error }
PHP
try { $filtersBuilder = new FiltersBuilder(); // $filtersBuilder->addIncludedCategory(...); // $filtersBuilder->addDate(...); // ... // Make a search call with the options set in the filters builder $response = $photosLibraryClient->searchMediaItems( ['filters' => $filtersBuilder->build()] ); foreach ($response->iterateAllElements() as $element) { // ... } } catch (\Google\ApiCore\ApiException $e) { // Handle error }
Para obtener más información, consulta Cómo enumerar contenido de la biblioteca, álbumes y elementos multimedia.
Categorías de contenido
Todos los elementos multimedia se procesan y se asignan etiquetas. Puedes incluir y excluir cualquiera de las siguientes categorías.
ANIMALS |
FASHION |
LANDMARKS |
RECEIPTS |
WEDDINGS |
ARTS |
FLOWERS |
LANDSCAPES |
SCREENSHOTS |
WHITEBOARDS |
BIRTHDAYS |
FOOD |
NIGHT |
SELFIES |
|
CITYSCAPES |
GARDENS |
PEOPLE |
SPORT |
|
CRAFTS |
HOLIDAYS |
PERFORMANCES |
TRAVEL |
|
DOCUMENTS |
HOUSES |
PETS |
UTILITY |
Las fotos de utilidad abarcan una amplia variedad de contenido multimedia. Por lo general, esta categoría incluye elementos que el usuario capturó para realizar una tarea y es poco probable que los necesite después de completarla. Incluye documentos, recibos, capturas de pantalla, notas adhesivas, menús y otros elementos multimedia similares.
Las categorías son tan precisas como las etiquetas equivalentes en Google Fotos. En ocasiones, es posible que los elementos estén etiquetados de forma incorrecta, por lo que no garantizamos la exactitud de los filtros de categorías de contenido.
Incluye categorías
Cuando incluyes varias categorías, se incluyen los elementos multimedia que coinciden con cualquiera de ellas. Se puede incluir un máximo de 10 categorías por solicitud.
Este filtro de ejemplo muestra todos los elementos de LANDSCAPES
o LANDMARKS
.
REST
{ "filters": { "contentFilter": { "includedContentCategories": [ "LANDSCAPES", "LANDMARKS" ] } } }
Java
// Create a content filter that includes landmarks and landscapes ContentFilter contentFilter = ContentFilter.newBuilder() .addIncludedContentCategories(ContentCategory.LANDMARKS) .addIncludedContentCategories(ContentCategory.LANDSCAPES) .build(); // Create a new Filters object Filters filters = Filters.newBuilder() .setContentFilter(contentFilter) .build(); // Specify the Filter object in the searchMediaItems call SearchMediaItemsPagedResponse response = photosLibraryClient.searchMediaItems(filters);
PHP
// Create a content filter that includes landmarks and landscapes $filtersBuilder = new FiltersBuilder(); $filtersBuilder->addIncludedCategory(ContentCategory::LANDMARKS); $filtersBuilder->addIncludedCategory(ContentCategory::LANDSCAPES); // Make a search call with the options set in the filters builder $response = $photosLibraryClient->searchMediaItems( ['filters' => $filtersBuilder->build()] );
Cómo excluir categorías
Solo se muestran los elementos multimedia que no coinciden con ninguna de las categorías excluidas. Al igual que con las categorías incluidas, se puede excluir un máximo de 10 categorías por solicitud.
Este filtro muestra todos los elementos que no son PEOPLE
ni SELFIES
:
REST
{ "filters": { "contentFilter": { "excludedContentCategories": [ "PEOPLE", "SELFIES" ] } } }
Java
// Create a content filter that excludes people and selfies ContentFilter contentFilter = ContentFilter.newBuilder() .addExcludedContentCategories(ContentCategory.PEOPLE) .addExcludedContentCategories(ContentCategory.SELFIES) .build(); // Create a new Filters object Filters filters = Filters.newBuilder() .setContentFilter(contentFilter) .build(); // Specify the Filter object in the searchMediaItems call SearchMediaItemsPagedResponse response = photosLibraryClient.searchMediaItems(filters);
PHP
// Create a content filter that excludes people and selfies $filtersBuilder = new FiltersBuilder(); $filtersBuilder->addExcludedCategory(ContentCategory::PEOPLE); $filtersBuilder->addExcludedCategory(ContentCategory::SELFIES); // Make a search call with the options set in the filters builder $response = $photosLibraryClient->searchMediaItems( ['filters' => $filtersBuilder->build()] );
Cómo incluir y excluir varias categorías
Puedes incluir algunas categorías y excluir otras. En el siguiente ejemplo, se muestran LANDSCAPES
y LANDMARKS
, pero se quitan los elementos multimedia que contienen PEOPLE
o que son SELFIES
:
REST
{ "filters": { "contentFilter": { "includedContentCategories": [ "LANDSCAPES", "LANDMARKS" ], "excludedContentCategories": [ "PEOPLE", "SELFIES" ] } } }
Java
// Create a content filter that excludes people and selfies and includes landmarks and landscapes ContentFilter contentFilter = ContentFilter.newBuilder() .addIncludedContentCategories(ContentCategory.LANDSCAPES) .addIncludedContentCategories(ContentCategory.LANDMARKS) .addExcludedContentCategories(ContentCategory.PEOPLE) .addExcludedContentCategories(ContentCategory.SELFIES) .build(); // Create a new Filters object Filters filters = Filters.newBuilder() .setContentFilter(contentFilter) .build(); // Specify the Filters object in the searchMediaItems call SearchMediaItemsPagedResponse response = photosLibraryClient.searchMediaItems(filters);
PHP
// Create a content filter that excludes people and selfies and includes landmarks and landscapes $filtersBuilder = new FiltersBuilder(); $filtersBuilder->addIncludedCategory(ContentCategory::LANDMARKS); $filtersBuilder->addIncludedCategory(ContentCategory::LANDSCAPES); $filtersBuilder->addExcludedCategory(ContentCategory::PEOPLE); $filtersBuilder->addExcludedCategory(ContentCategory::SELFIES); // Make a search call with the options set in the filters builder $response = $photosLibraryClient->searchMediaItems( ['filters' => $filtersBuilder->build()] );
Fechas y períodos
Los filtros de fecha restringen la fecha de los resultados mostrados a un conjunto específico de días. Existen dos maneras de especificar un filtro de fecha: fechas o períodos. Las fechas y los intervalos se pueden usar juntos. Se muestran los elementos multimedia que coinciden con cualquiera de las fechas o los períodos. De forma opcional, puedes modificar el orden de clasificación de los resultados.
Fechas
Una fecha contiene un año, un mes y un día. Se aceptan los siguientes formatos:
- Año
- Año y mes
- Año, mes, día
- Día, mes
- Mes
Cuando un componente de la fecha está vacío o se establece en cero, se considera como un comodín. Por ejemplo, si configuras el día y el mes, pero no el año, solicitas elementos de ese día y mes de cualquier año:
REST
{ "filters": { "dateFilter": { "dates": [ { "month": 2, "day": 15 } ] } } }
Java
// Create a new com.google.type.Date object using a builder // Note that there are different valid combinations as described above Date dayFebruary15 = Date.newBuilder() .setDay(15) .setMonth(2) .build(); // Create a new dateFilter. You can also set multiple dates here DateFilter dateFilter = DateFilter.newBuilder() .addDates(dayFebruary15) .build(); // Create a new Filters object Filters filters = Filters.newBuilder() .setDateFilter(dateFilter) .build(); // Specify the Filters object in the searchMediaItems call SearchMediaItemsPagedResponse response = photosLibraryClient.searchMediaItems(filters);
PHP
// Create a new Google\Type\Date object with a day and a month // Note that there are different valid combinations as described above $dateFebruary15 = new Date(); $dateFebruary15->setDay(15); $dateFebruary15->setMonth(2); $filtersBuilder = new FiltersBuilder(); // Add the date to the filter. You can also set multiple dates here $filtersBuilder->addDate($dateFebruary15); // Make a search call with the options set in the filters builder $response = $photosLibraryClient->searchMediaItems( ['filters' => $filtersBuilder->build()] );
Intervalos de fechas
Los períodos proporcionan más flexibilidad que las fechas. Por ejemplo, en lugar de agregar varias fechas, se puede usar un período para ver un conjunto de días dentro de un mes.
Un período tiene un startDate
y un endDate
, que se deben configurar. Cada fecha del intervalo tiene las mismas restricciones de formato que se describen en Fechas. Las fechas deben tener el mismo formato: si la fecha de inicio es un año y un mes, la fecha de finalización también debe ser un año y un mes. Los rangos se aplican de forma inclusiva, y las fechas de inicio y finalización se incluyen en el filtro aplicado:
REST
{ "filters": { "dateFilter": { "ranges": [ { "startDate": { "year": 2014, "month": 6, "day": 12 }, "endDate": { "year": 2014, "month": 7, "day": 13 } } ] } } }
Java
// Create new com.google.type.Date objects for two dates Date day2014June12 = Date.newBuilder() .setDay(12) .setMonth(6) .setYear(2014) .build(); Date day2014July13 = Date.newBuilder() .setDay(13) .setMonth(7) .setYear(2014) .build(); // Create a DateRange from these two dates DateRange dateRange = DateRange.newBuilder() .setStartDate(day2014June12) .setEndDate(day2014July13) .build(); // Create a new dateFilter with the date range. You can also set multiple date ranges here DateFilter dateFilter = DateFilter.newBuilder() .addRanges(dateRange) .build(); // Create a new Filters object Filters filters = Filters.newBuilder() .setDateFilter(dateFilter) .build(); // Specify the Filters object in the searchMediaItems call SearchMediaItemsPagedResponse response = photosLibraryClient.searchMediaItems(filters);
PHP
// Create two new Google\Type\Date objects $date2014June12 = new Date(); $date2014June12->setDay(12); $date2014June12->setMonth(6); $date2014June12->setYear(2014); $date2014July13 = new Date(); $date2014July13->setDay(13); $date2014July13->setMonth(7); $date2014July13->setYear(2014); // Add the two dates as a date range to the filter // You can also set multiple date ranges here $filtersBuilder = new FiltersBuilder(); $filtersBuilder->addDateRange($date2014June12, $date2014July13); // Make a search call with the options set in the filters builder $response = $photosLibraryClient->searchMediaItems( ['filters' => $filtersBuilder->build()] );
Cómo combinar fechas y períodos
Puedes utilizar varias fechas y varios períodos al mismo tiempo. Los elementos que se encuentran dentro de cualquiera de estas fechas se incluyen en los resultados. Las fechas y los períodos separados no tienen que seguir el mismo formato, pero las fechas de inicio y finalización de los períodos individuales sí:
REST
{ "filters": { "dateFilter": { "dates": [ { "year": 2013 }, { "year": 2011, "month": 11 } ], "ranges": [ { "startDate": { "month": 1 }, "endDate": { "month": 3 } }, { "startDate": { "month": 3, "day": 24 }, "endDate": { "month": 5, "day": 2 } } ] } } }
Java
// Create a new com.google.type.Date object for the year 2013 Date day2013 = Date.newBuilder() .setYear(2013) .build(); // Create a new com.google.type.Date object for November 2011 Date day2011November = Date.newBuilder() .setMonth(11) .setYear(2011) .build(); // Create a date range for January to March DateRange dateRangeJanuaryToMarch = DateRange.newBuilder() .setStartDate(Date.newBuilder().setMonth(1).build()) .setEndDate(Date.newBuilder().setMonth(3).build()) .build(); // Create a date range for March 24 to May 2 DateRange dateRangeMarch24toMay2 = DateRange.newBuilder() .setStartDate(Date.newBuilder().setMonth(3).setDay(24).build()) .setEndDate(Date.newBuilder().setMonth(5).setDay(2).build()) .build(); // Create a new dateFilter with the dates and date ranges DateFilter dateFilter = DateFilter.newBuilder() .addDates(day2013) .addDates(day2011November) .addRanges(dateRangeJanuaryToMarch) .addRanges(dateRangeMarch24toMay2) .build(); // Create a new Filters object Filters filters = Filters.newBuilder() .setDateFilter(dateFilter) .build(); // Specify the Filter object in the searchMediaItems call SearchMediaItemsPagedResponse response = photosLibraryClient.searchMediaItems(filters);
PHP
// Create a new Google\Type\Date object for the year 2013 $date2013 = new Date(); $date2013->setYear(2013); // Create a new Google\Type\Date object for November 2011 $dateNovember2011 = new Date(); $dateNovember2011->setMonth(11); $dateNovember2011->setYear(2011); $filtersBuilder = new FiltersBuilder(); // Create a date range for January to March $filtersBuilder->addDateRange((new Date())->setMonth(1), (new Date())->setMonth(3)); // Create a date range for March 24 to May 2 $filtersBuilder->addDateRange((new Date())->setMonth(3)->setDay(24), (new Date())->setMonth(5)->setDay(2)); $filtersBuilder->addDate($date2013); $filtersBuilder->addDate($dateNovember2011); // Make a search call with the options set in the filters builder $response = $photosLibraryClient->searchMediaItems( ['filters' => $filtersBuilder->build()] );
Funciones de los elementos multimedia
Los filtros de funciones restringen los resultados a elementos que tienen funciones específicas, por ejemplo, que se hayan marcado como favoritos en la aplicación de Google Fotos.
Favoritos
Incluye la función del elemento FAVORITES
en el objeto FeatureFilter
para mostrar solo los elementos multimedia que el usuario marcó como favoritos:
REST
{ "filters" : { "featureFilter": { "includedFeatures": [ "FAVORITES" ] } } }
Java
// Create a new FeatureFilter for favorite media items FeatureFilter featureFilter = FeatureFilter.newBuilder() .addIncludedFeatures(Feature.FAVORITES) .build(); // Create a new Filters object Filters filters = Filters.newBuilder() .setFeatureFilter(featureFilter) .build(); // Specify the Filters object in the searchMediaItems call SearchMediaItemsPagedResponse response = photosLibraryClient.searchMediaItems(filters);
PHP
// Create a new FeatureFilter for favorite media items $filtersBuilder = new FiltersBuilder(); $filtersBuilder->addIncludedFeature(Feature::FAVORITES); // Make a search call with the options set in the filters builder $response = $photosLibraryClient->searchMediaItems( ['filters' => $filtersBuilder->build()] );
Tipos de medios
Puedes limitar los resultados al tipo de contenido multimedia: foto o video.
Foto
Un PHOTO
puede ser cualquiera de los siguientes formatos de imagen:
BMP | JPG |
GIF | PNG |
HEIC | TIFF |
ICO | WEBP |
También incluye tipos de fotos especiales, como fotos en vivo de iOS, fotos en movimiento, panorámicas, fotos esféricas y fotos en VR.
Video
Una VIDEO
puede ser de varios formatos de video:
3GP | MMV |
3G2 | MOD |
ASF | MOV |
AVI | MP4 |
DIVX | MPG |
M2T | MTS |
M2TS | TOD |
M4V | WMV |
MKV |
VIDEO
también incluye formatos de video especiales, como los siguientes: videos de RV, videos en cámara lenta y animaciones creadas en la aplicación de Google Fotos.
En el siguiente ejemplo, se filtra por PHOTO
:
REST
{ "filters": { "mediaTypeFilter": { "mediaTypes": [ "PHOTO" ] } } }
Java
// Create a new MediaTypeFilter for Photo media items MediaTypeFilter mediaType = MediaTypeFilter.newBuilder() .addMediaTypes(MediaType.PHOTO) .build(); // Create a new Filters object Filters filters = Filters.newBuilder() .setMediaTypeFilter(mediaType) .build(); // Specify the Filters object in the searchMediaItems call SearchMediaItemsPagedResponse response = photosLibraryClient.searchMediaItems(filters);
PHP
// Create a new MediaTypeFilter for Photo media items $filtersBuilder = new FiltersBuilder(); $filtersBuilder->setMediaType(MediaType::PHOTO); // Make a search call with the options set in the filters builder $response = $photosLibraryClient->searchMediaItems( ['filters' => $filtersBuilder->build()] );
No se pueden combinar varios filtros de tipos de medios.
Estado de archivo
Es posible que tus usuarios hayan archivado algunas de sus fotos. De forma predeterminada, las fotos archivadas no se muestran en las búsquedas. Para incluir elementos archivados, puedes establecer una marca en el filtro, como se muestra en el siguiente ejemplo:
REST
{ "filters": { "includeArchivedMedia": true } }
Java
// Create a new Filters object that includes archived media Filters filters = Filters.newBuilder() .setIncludeArchivedMedia(true) .build(); // Specify the Filters object in the searchMediaItems call SearchMediaItemsPagedResponse response = photosLibraryClient.searchMediaItems(filters);
PHP
// Create a new Filters object that includes archived media $filtersBuilder = new FiltersBuilder(); $filtersBuilder->setIncludeArchivedMedia(true); // Make a search call with the options set in the filters builder $response = $photosLibraryClient->searchMediaItems( ['filters' => $filtersBuilder->build()] );
Combinación de filtros
Se pueden combinar diferentes tipos de filtros. Solo se muestran los elementos que coinciden con todas las funciones solicitadas.
Cuando se combinan filtros, las restricciones de formato para cada tipo de filtro son las mismas que cuando se usan de forma individual. En el siguiente ejemplo, solo se muestran las fotos que se categorizaron como SPORT
y que son del 2014 o del 2010:
REST
{ "filters": { "contentFilter": { "includedContentCategories": [ "SPORT" ] }, "dateFilter": { "dates": [ { "year": 2014 }, { "year": 2010 } ] }, "mediaTypeFilter": { "mediaTypes": [ "PHOTO" ] } } }
Java
// Create a new ContentFilter that only includes SPORT items ContentFilter contentFilter = ContentFilter.newBuilder() .addIncludedContentCategories(ContentCategory.SPORT) .build(); // Create a new media type filter that only includes PHOTO media items MediaTypeFilter mediaTypeFilter = MediaTypeFilter.newBuilder() .addMediaTypes(MediaType.PHOTO) .build(); // Create a new DateFilter that only includes items from 2010 or 2014 Date year2014 = Date.newBuilder().setYear(2014).build(); Date year2010 = Date.newBuilder().setYear(2010).build(); DateFilter dateFilter = DateFilter.newBuilder() .addDates(year2010) .addDates(year2014) .build(); // Create a new Filters object combining these filters Filters filters = Filters.newBuilder() .setDateFilter(dateFilter) .setMediaTypeFilter(mediaTypeFilter) .setContentFilter(contentFilter) .build(); // Specify the Filter object in the searchMediaItems call SearchMediaItemsPagedResponse response = photosLibraryClient.searchMediaItems(filters);
PHP
// Create a new ContentFilter $filtersBuilder = new FiltersBuilder(); // Only include SPORT items $filtersBuilder->addIncludedCategory(ContentCategory::SPORT); // Only include PHOTO media items $filtersBuilder->setMediaType(MediaType::PHOTO); // Only include items from 2010 or 2014 $year2014 = new Date(); $year2014->setYear(2014); $year2010 = new Date(); $year2010->setYear(2010); $filtersBuilder->addDateRange($year2010, $year2014); // Make a search call with the options set in the filters builder // Filters have been combined in the filter builder $response = $photosLibraryClient->searchMediaItems( ['filters' => $filtersBuilder->build()] );
Ordenar resultados
Solo se pueden ordenar las consultas que usan filtros de fecha.
Si no especificas una opción de orden, los resultados se ordenarán de forma descendente (los más recientes primero).
En esta tabla, se muestran las opciones compatibles para el parámetro orderBy
:
Parámetro orderBy |
|
---|---|
MediaMetadata.creation_time desc |
Muestra los elementos multimedia en orden descendente (los más recientes primero). |
MediaMetadata.creation_time |
Muestra los elementos multimedia en orden ascendente (los elementos más antiguos primero) |
En el siguiente ejemplo, se muestran todos los elementos multimedia de 2017, que muestran primero el más antiguo y el último.
REST
{ "filters": { "dateFilter": { "dates": [ { "year": 2017 } ] } }, "orderBy": "MediaMetadata.creation_time" }
Java
// Create a new dateFilter for the year 2017. DateFilter dateFilter = DateFilter.newBuilder() .addDates(Date.newBuilder().setYear(2017)) .build(); // Create a new Filters object Filters filters = Filters.newBuilder() .setDateFilter(dateFilter) .build(); // Sort results by oldest item first. final OrderBy newestFirstOrder = OrderBy.MEDIAMETADATA_CREATION_TIME; // Specify the filter and sort order in the searchMediaItems call. SearchMediaItemsPagedResponse response = photosLibraryClient.searchMediaItems(filters, newestFirstOrder);
PHP
// Create a new dateFilter for the year 2017. $filtersBuilder = new FiltersBuilder(); $filtersBuilder->addDate((new Date())->setYear(2017)); // Make a search call with the options set in the filters builder and sort // the results by oldest item first. $response = $photosLibraryClient->searchMediaItems( [ 'filters' => $filtersBuilder->build(), 'orderBy' => OrderBy::MEDIAMETADATA_CREATION_TIME ] );