flutter_exif_rotation

Creator: coderz1093

Last updated:

Add to Cart

Description:

flutter exif rotation

Fix exif rotation for flutter #

Flutter plugin that fixes the picture orientation for some devices.
In some devices the exif data shows picture in landscape mode when they're actually in portrait.
This plugin fixes the orientation for pictures taken with those devices.
Every version of Android is supported.
iOS implemented by @Bhagatcliffex and currently supported
Android #
Add this in your AndroidManifest.xml (you don't need these permissions in case when you manipulate files from internal storage only (file are stored inside the app's directory ( /data/data/{your package}/ )) )
Example #
import 'dart:async';
import 'dart:io';

import 'package:flutter/material.dart';
import 'package:flutter_exif_rotation/flutter_exif_rotation.dart';
import 'package:image_picker/image_picker.dart';

void main() => runApp(MyApp());

/// The stateful widget
class MyApp extends StatefulWidget {
@override
_MyAppState createState() => _MyAppState();
}

/// The class with the scaffold
class _MyAppState extends State<MyApp> {
File _image;
final picker = ImagePicker();

Future getImage() async {
final image = await picker.getImage(source: ImageSource.gallery);
if (image != null && image.path != null) {
File rotatedImage =
await FlutterExifRotation.rotateImage(path: image.path);

if (image != null) {
setState(() {
_image = rotatedImage;
});
}
}
}

Future getImageAndSave() async {
final image = await picker.getImage(source: ImageSource.gallery);
if (image != null && image.path != null) {
File rotatedImage =
await FlutterExifRotation.rotateAndSaveImage(path: image.path);

if (image != null) {
setState(() {
_image = rotatedImage;
});
}
}
}

@override
void initState() {
super.initState();
}

@override
Widget build(BuildContext context) {
return MaterialApp(
home: Scaffold(
appBar: AppBar(
title: const Text('Exif flutter rotation image example app'),
),
body: new Center(
child: _image == null
? new Text('No image selected.')
: new Image.file(_image),
),
persistentFooterButtons: <Widget>[
new FloatingActionButton(
onPressed: getImageAndSave,
tooltip: 'Pick Image and save',
child: new Icon(Icons.save),
),
new FloatingActionButton(
onPressed: getImage,
tooltip: 'Pick Image without saving',
child: new Icon(Icons.add),
),
],
),
);
}
}

copied to clipboard

License

For personal and professional use. You cannot resell or redistribute these repositories in their original state.

Customer Reviews

There are no reviews.