我的用例是在出现错误时显示小吃店,但由于未调用load:flutter ,所以无法捕获SocketException 。
更新(示例堆栈跟踪):
I/flutter (11702): ??? EXCEPTION CAUGHT BY SERVICES ???????????????????????????????????????????????????????????????????
I/flutter (11702): The following SocketException was thrown resolving a single-frame image stream:
I/flutter (11702): Connection failed (OS Error: Network is unreachable, errno = 101), address = (( snip )), port
I/flutter (11702): = 443
I/flutter (11702): When the exception was thrown, this was the stack:
I/flutter (11702): #0 IOClient.send (package:http/src/io_client.dart:30:23)
I/flutter (11702): <asynchronous suspension>
I/flutter (11702): #1 BaseClient._sendUnstreamed (package:http/src/base_client.dart:171:38)
I/flutter (11702): <asynchronous suspension>
I/flutter (11702): #2 BaseClient.get (package:http/src/base_client.dart:34:5)
I/flutter (11702): #3 NetworkImage._loadAsync (package:flutter/src/services/image_provider.dart:431:54)
I/flutter (11702): <asynchronous suspension>
I/flutter (11702): #4 NetworkImage.load (package:flutter/src/services/image_provider.dart:417:7)
I/flutter (11702): #5 ImageProvider.resolve.<anonymous closure>.<anonymous closure> (package:flutter/src/services/image_provider.dart:253:61)
Run Code Online (Sandbox Code Playgroud)
我相对确定无法使用NetworkImage,这是因为据我了解,只有在您等待引发异常的结果时,才能捕获异常。
幸运的是,通过执行一些F12动作,代码看起来非常简单。因此,我的解决方案是在短短的几周内将NetworkImage的_loadAsync功能复制到我自己的课程中。(就像转动Uint8List而不是编解码器一样)
utils / network_image_loader.dart
import 'package:flutter/services.dart';
import 'package:http/http.dart' as http;
import 'dart:async';
import 'dart:typed_data';
class NetworkImageLoader {
String url;
Map<String, String> headers;
NetworkImageLoader(this.url, {this.headers});
static final http.Client _httpClient = createHttpClient();
Future<Uint8List> load() async {
final Uri resolved = Uri.base.resolve(this.url);
final http.Response response = await _httpClient.get(resolved, headers: headers);
if (response == null || response.statusCode != 200)
throw new Exception('HTTP request failed, statusCode: ${response?.statusCode}, $resolved');
final Uint8List bytes = response.bodyBytes;
if (bytes.lengthInBytes == 0)
throw new Exception('NetworkImage is an empty file: $resolved');
return bytes;
}
}
Run Code Online (Sandbox Code Playgroud)
一个简单的使用方法是(由于加载图像循环并显示默认值,所以我使用了不同的方法,因此我没有测试这种方法,但是它应该可以工作,或者很接近):
Widget img = new Text("Loading");
...
//Some function, ex constructor, init state, or a callback after you've done an http call
loadImage('http://imawesome.com');
...
@override
build(BuildContext context) {
return img;
}
Future<Uint8List> loadImage(String url) async {
try {
var netImg = new NetworkImageLoader(url);
var res = await netImg.load();
setState(() {
img = new Image(image: new MemoryImage(data),
height: 100.0,
width: 100.0,
fit: BoxFit.contain,
);
});
}
on Exception {
setState(() {
img = new Text("Load Failed");
}
}
}
Run Code Online (Sandbox Code Playgroud)
因此,如果您想执行以下任何一项操作,我的课非常好:
编辑:
您可能还希望查看图像的淡入淡出,这允许指定一个占位符,并且在许多情况下可能已足够:https : //flutter.io/cookbook/images/fading-in-images/
| 归档时间: |
|
| 查看次数: |
13728 次 |
| 最近记录: |