首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >图像侦听器引发了以下StateError :坏状态:未来已完成

图像侦听器引发了以下StateError :坏状态:未来已完成
EN

Stack Overflow用户
提问于 2022-02-13 04:08:17
回答 1查看 320关注 0票数 1

为什么我会收到这个例外?

代码语言:javascript
运行
复制
════════ Exception caught by image resource service ════════════════════════════
The following StateError was thrown by an image listener:
Bad state: Future already completed

When the exception was thrown, this was the stack
#1      _xxxState.setup.<anonymous closure>
xxx/ui/xxx.dart:209
#2      ImageStreamCompleter.setImage
package:flutter/…/painting/image_stream.dart:633
#3      MultiImageStreamCompleter._emitFrame
package:cached_network_image/…/image_provider/multi_image_stream_completer.dart:156
#4      MultiImageStreamCompleter._decodeNextFrameAndSchedule
package:cached_network_image/…/image_provider/multi_image_stream_completer.dart:141
<asynchronous suspension>
(elided one frame from dart:async)

代码语言:javascript
运行
复制
initState(){
   _refresh();
}

_refresh() async {
   ...
   await setUp();
}

 setup() async {
  
    var data = await _bloc.selectFloorPlan(floorPlanId);

    Image image = Image(image: CachedNetworkImageProvider(data));

    Completer<ui.Image> completer = Completer<ui.Image>();
    image.image
        .resolve(ImageConfiguration())
        .addListener(ImageStreamListener((ImageInfo image, bool _) {
      completer.complete(image.image);

      if (completer.isCompleted) {
        if (mounted) {
          floorPlanAnnotationUtil.updateValues(
            containerHeight: containerFixedHeight,
            containerWidth: MediaQuery.of(context).size.width -
                20, // minus the container padding 10 * 2
            imageHeight:
                DevicePixelUtil.toDevicePixel(context, image.image.height),
            imageWidth:
                DevicePixelUtil.toDevicePixel(context, image.image.width),
          );
        }

        // setState(() {});
      }
    }));
  }

错误指向这一行

代码语言:javascript
运行
复制
 completer.complete(image.image);
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2022-02-13 16:34:46

看起来您使用的是https://pub.dev/packages/cached_network_image,它内部使用https://pub.dev/packages/flutter_cache_manager。默认的缓存管理器可以将多个(相关)事件添加到流中。例如,如果缓存中的图像陈旧,它首先发出缓存的映像,然后再发出新下载的映像。您可能在这里看到了效果,因为您的Completer只能完成一次。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/71097848

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档