flutter_image_editor 0.0.5
flutter_image_editor: ^0.0.5 copied to clipboard
A plugin for flutter made to edit images. Only 3 features available -> change the brightness, contrast and rotate image. Future versions will have more stuf. Dont work for IOS YET.
example/lib/main.dart
import 'dart:async';
import 'dart:io';
import 'package:flutter/material.dart';
import 'dart:typed_data';
import 'package:flutter_image_editor/flutter_image_editor.dart';
import 'package:flutter/services.dart';
import 'package:permission_handler/permission_handler.dart';
void main() async{
await PermissionHandler().checkPermissionStatus(PermissionGroup.storage);
ByteData bytes = await rootBundle.load('assets/naruto.jpg');
final buffer = bytes.buffer;
var image = buffer.asUint8List(bytes.offsetInBytes, bytes.lengthInBytes);
runApp(WidgetEditableImage(imagem: image));
}
class WidgetEditableImage extends StatefulWidget {
final Uint8List imagem;
WidgetEditableImage(
{Key key,
@required this.imagem,})
: super(key: key);
@override
_WidgetEditableImage createState() => _WidgetEditableImage();
}
class _WidgetEditableImage extends State<WidgetEditableImage> {
StreamController<Uint8List> _pictureStream;
double _contrast;
double _brithness;
ByteData pictureByteData;
Uint8List picture;
@override
void initState() {
super.initState();
_pictureStream = new StreamController<Uint8List>();
_brithness = 0;
_contrast = 1;
pictureByteData = ByteData.view(widget.imagem.buffer);
picture = pictureByteData.buffer.asUint8List(pictureByteData.offsetInBytes, pictureByteData.lengthInBytes);
}
@override
Widget build(BuildContext context) {
return MaterialApp(
home: Scaffold(
body: containerEditableImage(_pictureStream, picture, _contrast, _brithness, setBrithness,
setContrast, updatePicutre)
),
);
}
void updatePicutre(double contrast, double brithness) async {
var retorno = await PictureEditor.editImage(picture, contrast, brithness);
_pictureStream.add(retorno);
}
void setBrithness(double valor){
setState(() {
_brithness = valor;
});
}
void setContrast(double valor){
setState(() {
_contrast = valor;
});
}
}
Widget containerEditableImage(StreamController picutreStream, Uint8List picture,
double contrast, double brithness, Function setBrithness,
Function setContrast, Function updatePicutre){
var novaFoto = picture;
return Center(
child: Row(
children: <Widget>[
Column(
children: <Widget>[
Text(' Edição de imagem: '),
Container(
height: 300,
width: 300,
child: StreamBuilder(
stream: picutreStream.stream,
builder: (BuildContext context, snapshot) {
if(snapshot.connectionState == ConnectionState.active){
novaFoto = snapshot.data;
return Image.memory(snapshot.data, gaplessPlayback: true, fit: BoxFit.contain,);
} else{
return Image.memory(picture, gaplessPlayback: true, fit: BoxFit.contain,);
}
},
),
padding: EdgeInsets.symmetric(vertical: 16.0, horizontal: 16.0)
),
Row(
children: <Widget>[
Column(
children: <Widget>[
Text("Contraste"),
Slider(
label: 'Contraste',
min: 0,
max: 10,
value: contrast,
onChanged: (valor) {
setContrast(valor);
updatePicutre(contrast, brithness);
},
),
Text("Brilho"),
Slider(
label: 'Brilho',
min: -255,
max: 255,
value: brithness,
onChanged: (valor) {
setBrithness(valor);
updatePicutre(contrast, brithness);
},
)
],
)
],
),
],
)
],
),
);
}