getMedia method

  1. @override
Future<List<XFile>> getMedia({
  1. required MediaOptions options,
})

Returns a List<XFile> with the images and/or videos that were picked. The images and videos come from the gallery.

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.

In Android, the MainActivity can be destroyed for various reasons. If that happens, the result will be lost in this call. You can then call getLostData when your app relaunches to retrieve the lost data.

If no images or videos were picked, the return value is an empty list.

Implementation

@override
Future<List<XFile>> getMedia({required MediaOptions options}) async {
  const XTypeGroup typeGroup = XTypeGroup(
      label: 'images and videos',
      extensions: <String>['public.image', 'public.movie']);

  List<XFile> files;

  if (options.allowMultiple) {
    files = await fileSelector
        .openFiles(acceptedTypeGroups: <XTypeGroup>[typeGroup]);
  } else {
    final XFile? file = await fileSelector
        .openFile(acceptedTypeGroups: <XTypeGroup>[typeGroup]);
    files = <XFile>[
      if (file != null) file,
    ];
  }
  return files;
}