pickMultipleMedia method
Returns a List<XFile> with the images and/or videos that were picked.
The images and videos come from the gallery.
The returned List<XFile> is intended to be used within a single app session. Do not save the file paths and use them across sessions.
Where iOS supports HEIC images, Android 8 and below doesn't. Android 9 and above only support HEIC images if used in addition to a size modification, of which the usage is explained below.
This method is not supported in iOS versions lower than 14.
If specified, the images will be at most maxWidth
wide and
maxHeight
tall. Otherwise the images will be returned at their
original width and height.
The imageQuality
argument modifies the quality of the images, ranging from 0-100
where 100 is the original/max quality. If imageQuality
is null, the images with
the original quality will be returned. Compression is only supported for certain
image types such as JPEG and on Android PNG and WebP, too. If compression is not
supported for the image that is picked, a warning message will be logged.
The limit
parameter modifies the maximum number of media that can be selected.
This value may be ignored by platforms that cannot support it.
Use requestFullMetadata
(defaults to true
) to control how much additional
information the plugin tries to get.
If requestFullMetadata
is set to true
, the plugin tries to get the full
image metadata which may require extra permission requests on some platforms,
such as Photo Library Usage
permission on iOS.
The method could throw PlatformException
if the app does not have permission to access
the photos gallery, plugin is already in use, temporary file could not be
created (iOS only), plugin activity could not be allocated (Android only)
or due to an unknown error.
If no images or videos were picked, the return value is an empty list.
Implementation
Future<List<XFile>> pickMultipleMedia({
double? maxWidth,
double? maxHeight,
int? imageQuality,
int? limit,
bool requestFullMetadata = true,
}) {
return platform.getMedia(
options: MediaOptions.createAndValidate(
allowMultiple: true,
imageOptions: ImageOptions.createAndValidate(
maxHeight: maxHeight,
maxWidth: maxWidth,
imageQuality: imageQuality,
requestFullMetadata: requestFullMetadata,
),
limit: limit,
),
);
}