56 lines
1.3 KiB
Dart
56 lines
1.3 KiB
Dart
|
import 'dart:html';
|
||
|
import 'package:image/image.dart';
|
||
|
|
||
|
CanvasElement input;
|
||
|
CanvasElement output;
|
||
|
|
||
|
ImageElement inputImg;
|
||
|
|
||
|
void main() {
|
||
|
inputImg = new ImageElement(src: 'kitten.jpg', width: 712, height: 470);
|
||
|
|
||
|
input = document.querySelector('#input');
|
||
|
print(input);
|
||
|
inputImg.onLoad.listen(imgLoaded);
|
||
|
|
||
|
output = document.querySelector('#output');
|
||
|
|
||
|
output.context2D.fillRect(0, 0, output.width, output.height);
|
||
|
}
|
||
|
|
||
|
void imgLoaded(Event e) {
|
||
|
print("image loaded");
|
||
|
input.context2D.drawImage(inputImg, 0, 0);
|
||
|
|
||
|
Image outputImg = editImage( getImageFromCanvas(input) );
|
||
|
|
||
|
drawImageToCanvas(output, outputImg ) ;
|
||
|
}
|
||
|
|
||
|
Image getImageFromCanvas(CanvasElement input) {
|
||
|
ImageData data = input.context2D.getImageData(0, 0, input.width, input.height);
|
||
|
return new Image.fromBytes(input.width, input.height, data.data);
|
||
|
}
|
||
|
|
||
|
void drawImageToCanvas(CanvasElement canvas, Image image) {
|
||
|
var imageData = canvas.context2D.createImageData(image.width, image.height);
|
||
|
imageData.data.setRange(0, imageData.data.length, image.getBytes());
|
||
|
|
||
|
canvas.context2D.putImageData(imageData, 0, 0);
|
||
|
}
|
||
|
|
||
|
Image editImage(Image image) {
|
||
|
|
||
|
|
||
|
image = contrast( image, 200);
|
||
|
|
||
|
for (var y = 0; y < image.height; y++) {
|
||
|
for (var x = 0; x < image.width; x++) {
|
||
|
// print(image.getPixel(x, y));
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
|
||
|
return image;
|
||
|
}
|