ali*_*hur 4 canvas image custom-painting dart flutter
在我的 Flutter 应用程序中,我使用CustomPainter来允许用户在屏幕上绘制他们的签名。我需要找到一种方法将其保存为图像。
当您能够PictureRecorder按照之前的 StackOverflow 回答将对象传递到画布时,PictureRecorder工作得很好:
final recorder = new PictureRecorder();
Canvas(recorder).drawSomething;
final picture = recorder.endRecording();
Run Code Online (Sandbox Code Playgroud)
但是,当使用CustomPainter画布时是Paint()函数的参数。
class myPainter extends CustomPainter {
@override
void paint(Canvas canvas, Size size) {
drawToCanvas(canvas);
@override
bool shouldRepaint(CustomPainter old) {
return false;
}
Run Code Online (Sandbox Code Playgroud)
所以总结一下:
如何从 CustomPainter 生成图像?
如果答案是使用 PictureRecorder,我如何将记录器传递给画布?
您不需要PictureRecorder在CustomPainter paint方法中将传递给画布。相反,您可以使用具有图片记录器的不同画布直接调用paint。例如:
Future<Image> getImage() async {
final PictureRecorder recorder = PictureRecorder();
myPainter.paint(Canvas(recorder), mySize);
final Picture picture = recorder.endRecording();
return await picture.toImage(width, height);
}
Run Code Online (Sandbox Code Playgroud)