flutter_image_editor 2.0.0
flutter_image_editor: ^2.0.0 copied to clipboard
A plugin for flutter made to edit images. Change the brightness, contrast and rotate image.
// ignore_for_file: public_member_api_docs, depend_on_referenced_packages
import 'dart:async';
import 'package:flutter/material.dart';
import 'package:flutter/services.dart';
import 'package:flutter_image_editor/flutter_image_editor.dart';
void main() async {
WidgetsFlutterBinding.ensureInitialized();
final bytes = await rootBundle.load('assets/naruto.jpg');
final buffer = bytes.buffer;
final image = buffer.asUint8List(bytes.offsetInBytes, bytes.lengthInBytes);
runApp(WidgetEditableImage(imagem: image));
}
class WidgetEditableImage extends StatefulWidget {
const WidgetEditableImage({
@required this.imagem,
Key key,
}) : super(key: key);
final Uint8List imagem;
@override
WidgetEditableImageState createState() => WidgetEditableImageState();
}
class WidgetEditableImageState extends State<WidgetEditableImage> {
StreamController<Uint8List> _pictureStream;
double _contrast;
double _brightness;
ByteData pictureByteData;
Uint8List picture;
@override
void initState() {
super.initState();
_pictureStream = StreamController<Uint8List>();
_brightness = 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,
_brightness,
setBrightness,
setContrast,
updatePicutre,
),
),
);
}
Future<void> updatePicutre(double contrast, double brightness) async {
final retorno =
await PictureEditor.editImage(picture, contrast, brightness);
_pictureStream.add(retorno as Uint8List);
}
void setBrightness(double valor) {
setState(() {
_brightness = valor;
});
}
void setContrast(double valor) {
setState(() {
_contrast = valor;
});
}
}
Widget rotateImage(
Uint8List picture,
StreamController<Uint8List> picutreStream,
) {
return Column(
children: <Widget>[
const Text('If you want to rotate the image, use this on sccafold body'),
Container(
height: 300,
width: 300,
padding: const EdgeInsets.symmetric(vertical: 16, horizontal: 16),
child: StreamBuilder<Uint8List>(
stream: picutreStream.stream,
builder: (BuildContext context, snapshot) {
if (snapshot.connectionState == ConnectionState.active) {
return Image.memory(
snapshot.data,
gaplessPlayback: true,
fit: BoxFit.contain,
);
} else {
return Image.memory(
picture,
gaplessPlayback: true,
fit: BoxFit.contain,
);
}
},
),
),
OutlinedButton(
onPressed: () async {
final retorno = await PictureEditor.rotateImage(picture, 90);
picutreStream.add(retorno as Uint8List);
},
child: const Text('Button'),
)
],
);
}
Widget containerEditableImage(
StreamController<Uint8List> picutreStream,
Uint8List picture,
double contrast,
double brightness,
void Function(double brightness) setBrightness,
void Function(double contrast) setContrast,
void Function(double brightness, double contrast) updatePicutre,
) {
return Container(
padding: const EdgeInsets.only(top: 50),
child: Column(
children: <Widget>[
const Text(
'''
If you want to change the brightness and contrast of the image, use this on the body of sccafold''',
),
Container(
height: 300,
width: 300,
padding: const EdgeInsets.symmetric(vertical: 16, horizontal: 16),
child: StreamBuilder<Uint8List>(
stream: picutreStream.stream,
builder: (BuildContext context, snapshot) {
if (snapshot.connectionState == ConnectionState.active) {
return Image.memory(
snapshot.data,
gaplessPlayback: true,
fit: BoxFit.contain,
);
} else {
return Image.memory(
picture,
gaplessPlayback: true,
fit: BoxFit.contain,
);
}
},
),
),
Row(
children: <Widget>[
Column(
children: <Widget>[
const Text('Contraste'),
Slider(
label: 'Contraste',
max: 10,
value: contrast,
onChanged: (valor) {
setContrast(valor);
updatePicutre(contrast, brightness);
},
),
const Text('Brilho'),
Slider(
label: 'Brilho',
min: -255,
max: 255,
value: brightness,
onChanged: (valor) {
setBrightness(valor);
updatePicutre(contrast, brightness);
},
)
],
)
],
),
],
),
);
}