How to Save Image File in Flutter ? File selected using Image_picker plugin
I am really confused. Flutter is awesome but some time is stuck the mind
All the code are done. selected file also showing in preview but I try to save that file in local android storage. I can't get success in
Future getImage(ImageSource imageSource) async {
var image = await ImagePicker.pickImage(source: imageSource);
setState(() {
_image = image;
});
}
Select file using this code and my file in _image
now I try to store using path_provider and dart.io
but I can't get save methodology.
Using await ImagePicker.pickImage(...)
, you are already on the right track because the function returns a File
.
The File
class has a copy
method, which you can use to copy the file (which is already saved on disk by either the camera or by lying in gallery) and put it into your application documents directory:
// using your method of getting an image
final File image = await ImagePicker.pickImage(source: imageSource);
// getting a directory path for saving
final String path = await getApplicationDocumentsDirectory().path;
// copy the file to a new path
final File newImage = await image.copy('$path/image1.png');
setState(() {
_image = newImage;
});
You should also note that you can get the path of the image file from ImagePicker
using image.path
, which will also contain the file ending that you might want to extract and you can save your image path by using newImage.path
.
@creativecreatorormaybenot answer is really helpful but it missed one important part i.e retrieving the image for later use.
Saving Image
// Step 1: Retrieve image from picker
final File image = await ImagePicker.pickImage(source: imageSource);
// Step 2: Check for valid file
if (image == null) return;
// Step 3: Get directory where we can duplicate selected file.
final String path = await getApplicationDocumentsDirectory().path;
// Step 4: Copy the file to a application document directory.
final var fileName = basename(file.path);
final File localImage = await image.copy('$path/$fileName');
Tip: you can retrieve file name from original file using basename(file.path). Make sure you import 'package:path/path.dart';
Retrieving/Loading Image
// Step 1: Save image/file path as string either db or shared pref
SharedPreferences prefs = await SharedPreferences.getInstance();
prefs.setString('test_image', localImage.path)
// Step 2: Loading image by using the path that we saved earlier. We can create a file using path
// and can use FileImage provider for loading image from file.
CircleAvatar(
backgroundImage: FileImage(File(prefs.getString('test_image')),
radius: 50,
backgroundColor: Colors.white)