Image size taken from Flutter Image_Picker plugin is way too big

Dai Dao picture Dai Dao · May 21, 2018 · Viewed 8.8k times · Source

I want to use auto-focus on the camera, which is available on the image_picker plugin. However, when I call:

var bytes = new File(imagePath);
var enc = await bytes.readAsBytes();
print(enc.length);

I got: 5121126

which takes at least 10 seconds when I want to encode into json to send to an API server:

var body = json.encode({
      'image' : enc
})

In contrast, with the camera plugin, my byte array is only 420685, which is 10 times smaller, but it doesn't have the auto-focus feature.

Can I get some advice on how to reduce the size of the byte array from image_picker? Thank you.

Answer

Richard Heap picture Richard Heap · May 21, 2018

The camera plugin has 3 default resolutions, and you are probably selecting or defaulting to a lower resolution (than the hardware's full resolution).

The image_picker plugin doesn't have these presets, but does have some optional arguments on the pickImage method (maxWidth and maxHeight). Experiment setting one or both of these to VGA type resolutions (640, 480, even 800, 600) to see if this reduces the size of the captured image.

There's also a package called image which would allow you to post-process the image. The sample on the main page does a resize, maintaining aspect ratio.