- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
尝试使用 image_picker
在 Flutter 中,我遇到以下问题:
当导航应该返回到 Widget Nr1 时,我无法再在 Widget Nr1 中调用 setState()
。这是因为当 Navigation.push
从 Widget-Nr1 到 Widget-Nr2 时调用了 dispose()
方法。
事实证明,我绝对需要调用此 dispose()
方法才能使 image_picker
插件正常工作。 (如果我不这样做,那么错误 ...was disposed with an active Ticker...
发生,可能是由于 image_picker
插件在迫切需要预先处理()的引擎盖。
反正我是蛇咬尾部的感觉。
作为总结,我执行以下操作(另请参见下面的代码):
image_picker
插件(让用户用相机拍照并要求用户提供一些描述图像的字符串文本)Navigation.pop
)setState()
很可能是因为两个 Widget 都已经调用了它们的 dispose()
方法<我在 Widget-Nr1 中得到错误:
Dart Error: Unhandled exception:
setState() called after dispose()
我该怎么做才能完成这项工作?
如何在 Widget-1 中再次使用 image_picker
的结果数据(在 Widget-1 中需要 dispose()
)作为 Navigation.pop 结果这在所有导航之后 setState()
仍然可行的方式 ??
或者还有其他方法可以使用吗?
这是我的代码:
StatefulWidget Nr1(摘录):
child: FloatingActionButton(
onPressed: () async {
_imagePickerResult = await navigateToImagePicker(context);
setState(() async {
this.itemBins.add(ItemBin(
_imagePickerResult.locationName,
_imagePickerResult.locationImage));
});
},
child: Icon(Icons.add),
),
// ...
Future<ImagePickerResult> navigateToImagePicker(BuildContext context) async {
return await Navigator.push(
context, MaterialPageRoute(builder: (context) => MyImagePickerView())
);
}
// ...
class ImagePickerResult {
String locationName;
Image locationImage;
ImagePickerResult({this.locationName, this.locationImage});
}
StatefulWidget Nr2:
import 'package:flutter/material.dart';
import 'dart:io';
import 'package:image_picker/image_picker.dart';
import './../../models/image_picker_location.dart';
class MyImagePickerView extends StatefulWidget {
_MyImagePickerViewState createState() => _MyImagePickerViewState();
}
class _MyImagePickerViewState extends State<MyImagePickerView> {
TextEditingController _myController = TextEditingController();
File _imageFile;
bool _pickImage = true;
@override
Widget build(BuildContext context) {
if (_pickImage) {
return FutureBuilder<File>(
future: ImagePicker.pickImage(source: ImageSource.camera),
builder: (BuildContext context, AsyncSnapshot<File> snapshot) {
if (snapshot.hasData) {
_pickImage = false;
_imageFile = snapshot.data;
return _showImage(snapshot.data);
} else {
return Scaffold(
body: Center(
child: Text('no image picker availalbe'),
),
);
}
},
);
} else {
return _showImage(_imageFile);
}
}
Widget _showImage(File imgFile) {
return Scaffold(
body: Stack(
alignment: AlignmentDirectional.topStart,
children: <Widget>[
Positioned(
left: 0.0,
bottom: 0.0,
width: MediaQuery.of(context).size.width,
height: MediaQuery.of(context).size.height,
child: Center(
child: imgFile == null
? Text('No image selected.')
: Image.file(imgFile),
),
),
Positioned(
left: 16.0,
bottom: 70.0,
width: MediaQuery.of(context).size.width - 32.0,
height: 50.0,
child: Container(
color: Colors.grey[100],
child: TextField(
autofocus: false,
keyboardType: TextInputType.text,
autocorrect: false,
style: TextStyle(
color: Colors.black,
fontSize: 22.0,
fontWeight: FontWeight.w600),
decoration: InputDecoration(
hintStyle: TextStyle(
color: Colors.black38,
fontSize: 22.0,
fontWeight: FontWeight.normal),
hintText: "depart From :",
contentPadding: const EdgeInsets.fromLTRB(6.0, 13.0, 0, 12.0),
enabledBorder: UnderlineInputBorder(
borderSide: BorderSide(color: Colors.red, width: 2.0),
),
),
maxLines: 1,
textAlign: TextAlign.left,
controller: _myController,
onEditingComplete: () {
FocusScope.of(context)
.requestFocus(FocusNode()); // dismiss keyboard
Navigator.pop(
context,
ImagePickerResult(
locationName: _myController.text,
locationImage: Image.file(imgFile),
),
);
},
),
),
),
],
),
);
}
}
Widget Nr1 的处理方法:
@override
void dispose() {
if (_debounce?.isActive ?? false) {
_debounce.cancel(); // if _debounce is active cancel it...
}
_debounce = Timer(const Duration(milliseconds: 200), () {
// security wait due to the fact that there are animations still running during setState()
});
// dispose AnimationController
controller.dispose();
_debounce.cancel();
super.dispose();
}
Widget-Nr2的dispose方法:
@override
void dispose() {
_myController.dispose();
super.dispose();
}
如果我不让 view1 在 image_picker 启动之前执行 dispose(),则会出现错误消息... ) 在 image_picker 的 segue 发生之前人工“等待”200 毫秒)...
flutter: ══╡ EXCEPTION CAUGHT BY WIDGETS LIBRARY ╞═══════════════════════════════════════════════════════════
flutter: The following assertion was thrown while finalizing the widget tree:
flutter: _HistoryViewState#a8eac(ticker active but muted) was disposed with an active Ticker.
flutter: _HistoryViewState created a Ticker via its SingleTickerProviderStateMixin, but at the time dispose()
flutter: was called on the mixin, that Ticker was still active. The Ticker must be disposed before calling
flutter: super.dispose(). Tickers used by AnimationControllers should be disposed by calling dispose() on the
flutter: AnimationController itself. Otherwise, the ticker will leak.
flutter: The offending ticker was: Ticker(created by _HistoryViewState#a8eac(lifecycle state: created))
flutter: The stack trace when the Ticker was actually created was:
flutter: #0 new Ticker.<anonymous closure>
package:flutter/…/scheduler/ticker.dart:64
flutter: #1 new Ticker
package:flutter/…/scheduler/ticker.dart:66
flutter: #2 __HistoryViewState&State&SingleTickerProviderStateMixin.createTicker
package:flutter/…/widgets/ticker_provider.dart:93
flutter: #3 new AnimationController
最佳答案
代替 setState(() {...})
,尝试 if (mounted) { setState(() {...}) }
代码可能在用户导航离开后运行。
关于image - Flutter Navigation 和同时对 dispose() 的要求,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54599561/
当我调用 png.Decode(imageFile) 时,它返回类型 image.Image。但我找不到将其转换为 image.NRGBA 或 image.RGBA 的记录方式,我可以在其上调用 At
image/jpeg 和 image/png 包有 Decode 和 Encode 函数,可以读取和写入 jpeg 和 png 图像,但 image/gif 包没有 - 只有 Decode 和 Dec
我正在尝试从一系列任意的非调色板图像创建动画 GIF。为了创建调色板图像,我需要以某种方式想出一个调色板。 // RGBA, etc. images from somewhere else var f
我在今年夏天的空闲时间使用 Go 镜像包进行一些练习。 package main import ( "os" "image" "image/png" "image/co
关闭。这个问题需要debugging details .它目前不接受答案。 想改进这个问题?将问题更新为 on-topic对于堆栈溢出。 1年前关闭。 Improve this question 今天
我正在尝试在 TilePane 中列出图像。当我尝试创建图像 new ImageView("address"); 时出现错误,地址如下: "file:D:/Chrysanthemum.jpeg/" 以
我有一个用于为画廊选择图像的表单,我希望允许用户仅选择 jpg、gif 和 png 图像格式。 现在,为了测试,我将图像的扩展名更改为 .bmp,例如“image1.bmp”,当我在输入文件中单击以选
我有创建图像的代码:(m_img 是 javafx.scene.image.Image) Image m_img = new Image("file:" + p_Fil.getAbsoluteFile
假设我有一个这样的 8 位灰度图像: var pixels []byte = ... width := 100 height := 100 如何将其转换为实现 image.Image 的东西? 最佳答
这段代码是我在localhost:8088 URL上的索引/主页的一部分,如果我想将用户发送到url localhost:8088/image/1,我应该写href='image/{{$image->
我正在尝试对图像进行简单的裁剪。这是代码 from PIL.Image import Image def get_image_half(image, half="upper"): if hal
我在这个问题上花了一整天,但在堆栈溢出中没有看到答案! 我试过了但是没用: >> pil_image = Image.frombytes('RGBA', wand_image.size, wa
所以,我是那些以始终使用最新版本的浏览器而自豪的人之一(当然 Internet Explorer 除外 - 我说的不是那个浏览器)。 我遇到了 this awesome CSS3 website详细介
如果 image_tag 无法从 url 加载图像,我想呈现默认图像: 因此,如果 image_tag 无法从 url 加载图像: 然后呈现默认值: 这将生成结果 HTML: 关于image -
我正在创建一个类似横幅的组件,并将图像设置为组件的背景,但我无法让它工作。我尝试了网上发布的不同建议,但没有成功,目前我不确定我的错误是否在 react 代码中,或者是 webpack 没有正确加载文
如何解决 Dart 中的这种歧义错误。 import 'dart:io'; import 'package:flutter/material.dart'; import 'package:camera
Center( child: CachedNetworkImage( imageUrl: "http:/ sosme link he
设置 www.website.com/sds/(index.htm) 以便鼠标悬停在不同位置时显示图像。 出于某种原因,当您将鼠标悬停在蓝色气球上时,图像 2.jpg 和 3.jpg(在蓝色气球上来回
社交网络在共享 URL 时可以很好地从网站中提取标题和描述,但对于图像,仍然需要创建自定义元标记:property="og:image" name="twitter:image" itemprop="
我正在尝试写一个简短的,它将读取一个 PNG 文件,并将一个 channel 与另一个 channel (R,G,B) 交换作为可能的选择。 但是,我无法找到如何从 image.At(x,y) 返回的
我是一名优秀的程序员,十分优秀!