image - Flutter - 将 Assets 图像转换并调整大小为 dart ui 图像

标签 image flutter dart

我正在尝试获取 Assets 图像,将图像调整为任意宽度和高度,并将图像转换为 dart ui 图像,以便我可以使用 drawImage 方法在 Canvas 上绘制图像。这样我就可以针对不同的屏幕尺寸调整图像。

但是,我遇到了调整图像大小的问题。我尝试了几种不同的方法,但我管理的最好的方法是绘制正确的图像数据并裁剪图像而不是调整大小,以正确的大小使数据无效(错误解码静态),或者在失败时使用正确的图像数据调整图像大小。

我命名的进口是

import 'dart:io' as io;
import 'dart:ui' as ui;
import 'package:flutter/widgets.dart' as widgets;
import 'package:image/image.dart' as image;

我的一些尝试如下:

显示正确的图像数据而无法调整大小:
Future<ui.Image> loadUiImage(String imageAssetPath) async {
  widgets.Image widgetsImage = widgets.Image.asset(imageAssetPath, scale: 0.5);
  Completer<ui.Image> completer = Completer<ui.Image>();
  widgetsImage.image
    .resolve(widgets.ImageConfiguration(size: ui.Size(10, 10)))
    .addListener(widgets.ImageStreamListener((widgets.ImageInfo info, bool _){
      completer.complete(info.image);
    }));
  return completer.future;
}

尽管图像数据正确,但在不调整大小的情况下错误地裁剪图像:
Future<ui.Image> loadUiImage(String imageAssetPath) async {
  final ByteData data = await rootBundle.load(imageAssetPath);
  List<int> bytes = data.buffer.asUint8List();
  image.Image iconImage = image.Image.fromBytes(100, 100, bytes);
  final Completer<ui.Image> completer = Completer();
  ui.decodeImageFromList(image.decodePng(image.encodePng(iconImage)).getBytes(), (ui.Image img) {
    return completer.complete(img);
  });
  return completer.future;
}

无效的图像数据,正确调整图像大小:
Future<ui.Image> loadUiImage(String imageAssetPath) async {
  final ByteData data = await rootBundle.load(imageAssetPath);
  List<int> bytes = data.buffer.asUint8List();
  image.Image iconImage = image.Image.fromBytes(100, 100, bytes);
  final Completer<ui.Image> completer = Completer();
  ui.decodeImageFromList(image.encodePng(iconImage), (ui.Image img) {
    return completer.complete(img);
  });
  return completer.future;
}

我也尝试使用 Bitmap 方法使用 here ,但在提供的函数中遇到错误

Failed assertion: line 274 pos 12: 'bitmap.length == size': is not true



在我尝试调整图像大小后尝试使用。

我将不胜感激任何帮助解决此问题,在此先感谢。

最佳答案

自从能够在这个副项目上工作已经有一段时间了,但是能够使用 image 包完成转换和调整大小:

import 'dart:ui' as ui;
import 'package:image/image.dart' as image;
import 'package:flutter/services.dart';

Future<ui.Image> getUiImage(String imageAssetPath, int height, int width) async {
  final ByteData assetImageByteData = await rootBundle.load(imageAssetPath);
  image.Image baseSizeImage = image.decodeImage(assetImageByteData.buffer.asUint8List());
  image.Image resizeImage = image.copyResize(baseSizeImage, height: height, width: width);
  ui.Codec codec = await ui.instantiateImageCodec(image.encodePng(resizeImage));
  ui.FrameInfo frameInfo = await codec.getNextFrame();
  return frameInfo.image;
}

关于image - Flutter - 将 Assets 图像转换并调整大小为 dart ui 图像,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59923245/

相关文章:

dart - 如何在 ListView 的顶部插入小部件?

html - 不同的图像 - 在响应式 Web 应用程序中调整大小、缩放 - 以适应不同的屏幕尺寸

dart - flutter '严格'模式?

android - 'NoSuchMethodError:当我尝试执行SQFLITE类时,对空调用了 'insert'方法,为什么会这样呢?

flutter - 我正面临着将嵌套对象列表的结果转换为概率树结果形式的困难。如下

dart - 从磁盘读取的文本不符合换行符

image - 如何调整敏捷图像小部件的大小?

java - 将图像文件路径保存到sqlite数据库

xml - 将 Google 图片集成到应用程序中

flutter - 抖动的边界生命周期