- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
我正在尝试创建一个 flutter 应用程序,它将在 WebView 中显示一个网站,我希望能够设置一个 RefreshIndicator,当用户在 webview 上下拉并刷新 WebView 时触发。
我可以使 WebView 正常工作,但 RefreshIndicator 仅适用于可垂直滚动的 View 。我已尝试将 WebView 作为唯一的子项添加到 ListView,但 WebView 不会下拉 ListView。
我试过将 RefreshIndicator 放在 Webview 周围,我也试过使用 PageView 而不是 ListView
import 'dart:async';
import 'package:flutter/material.dart';
import 'package:flutter/foundation.dart';
import 'package:flutter/gestures.dart';
import 'package:webview_flutter/webview_flutter.dart';
class WebViewContainer extends StatefulWidget {
final url;
WebViewContainer(this.url);
@override
createState() => _WebViewContainerState(this.url);
}
class _WebViewContainerState extends State<WebViewContainer> {
final Completer<WebViewController> _controller =
Completer<WebViewController>();
var _url;
final _key = UniqueKey();
_WebViewContainerState(this._url);
// WebViewController _webViewController;
@override
Widget build(BuildContext context) {
return Scaffold(
body: RefreshIndicator(
child: ListView(children: [
Container(
child: Center(child: Text('Top')),
),
Container(
height: MediaQuery.of(context).size.height,
child: WebView(
key: _key,
initialUrl: _url,
javascriptMode: JavascriptMode.unrestricted,
onWebViewCreated: (WebViewController webViewController) {
_controller.complete(webViewController);
},
navigationDelegate: (navigationRequest) {
return NavigationDecision.navigate;
},
gestureRecognizers: Set()
..add(Factory<VerticalDragGestureRecognizer>(
() => VerticalDragGestureRecognizer())),
javascriptChannels: <JavascriptChannel>[
_toasterJavascriptChannel(context),
].toSet(),
onPageFinished: (String url) {
print('Page Finished loading: $url');
},
),
),
Container(
child: Center(child: Text('Bottom')),
),
]),
onRefresh: _refreshWebView,
),
);
}
我想要的是一种只显示 Webview 的方法,当他们下拉 Webview 时它会刷新。另一种选择是,如果您在 Webview 中滚动到页面顶部,Webview 是否会下拉 ListView。
最佳答案
嗯,这是可以做到的。
在创建 webView 时,将 gestureRecognizers 设置为 EagerGestureRecognizer();
实现一个扩展 VerticalDragGestureRecognizer 的 AllowMultipleGestureRecognizer,将 rejectGesture() 重写为 acceptGesture();
实现一个 RawGestureDetector,使用 AllowMultipleGestureRecognizer 作为“手势”;
在RawGestureDetector中放一个LayoutBuilder(),目的是获取子上下文;
将您的 webView 放入 LayoutBuilder。现在,webView 和 RawGestureDetector 都可以接收手势事件。
实现将手势转换为滚动通知的转换层。您可能感兴趣的滚动通知是:ScrollStartNotification、OverscrollNotification、ScrollUpdateNotification 和 ScrollEndNotification。 RefreshIndicator 不需要 UserScrollNotification。这一层可能需要一些时间才能把事情做好;
在RawGestureDetector 的回调函数:onStart()/onUpdte()/onEnd() 中,调用翻译层生成通知。然后使用您从 LayoutBuilder 获得的上下文来调用正在监听滚动事件的每个祖先小部件。使用 context.visitAncestorElements() 来实现这一点。
修改 webView 的平台代码(Android 和 iOS),以将监听器添加到 YOffset。监听器调用“ channel ”方法将偏移量传递给您的 flutter 代码。 6 中的转换层查看 YOffset 以生成正确的通知(例如 OverscrollNotification 或 ScrollUpdateNotification)。
将 RawGestureDetector 放入 RefreshIndicator 中,您就完成了!
结果:结果相当令人失望。RefreshIndicator 的动画会导致 webView 重绘几次,从而导致屏幕闪烁和相当大的延迟。这绝对不是一个好的用户体验。 Flutter 不能很好地处理重型“插件”小部件,应避免对 webView 进行任何与动画相关的操作(例如推送/弹出)。
浪费时间。
关于flutter - 有没有办法向 webview_flutter 小部件添加下拉刷新?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57171434/
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引起辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the he
在现代 IDE 中,有一个键盘快捷键可以通过键入文件名称来打开文件,而无需将手放在鼠标上。例如: Eclipse:Cmd|Ctrl + Shift + R -> 打开资源 IntelliJ:Cmd|C
有什么东西会等待事件发生(我正在等待的是 WebBrowser.DocumentCompleted),然后执行代码吗?像这样: If (WebBrowser.DocumentCompleted) 不会
我使用 PHP Minify,它很棒。但我的问题是,是否有任何 PHP 插件或其他东西可以自动检测 javascript/css 代码并自动缩小它?谢谢。 最佳答案 Javascript 压缩器? 看
有没有一种语言,类似什么CoffeeScript是JavaScript,编译成windows batch|cmd|command line的语言? 我指的cmd版本是基于NT的,尤其是XP sp3及以
我知道我可以 ,但是,我真的宁愿有一个任务,我可以从任何可以使用所有(或至少大部分)属性的操作系统调用 copy ,但这并没有消除 unix 上的权限。 我想知道是否已经有解决方案,或者我必须自己编
我正在使用 Vuejs(不使用 jQuery)开发一个项目,该项目需要像 jvectormap 这样的 map 但正如我所说,我没有使用 jQuery,那么是否有任何其他库可以在不使用 jQuery
想要进行一个简单的民意调查,甚至不需要基于 cookie,我不在乎投了多少票。有没有类似的插件或者简单的东西? 最佳答案 这是一个有用的教程 - 让我知道它是否适合您 using jQuery to
已结束。此问题正在寻求书籍、工具、软件库等的推荐。它不满足Stack Overflow guidelines 。目前不接受答案。 我们不允许提出寻求书籍、工具、软件库等推荐的问题。您可以编辑问题,以便
就目前情况而言,这个问题不太适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、民意调查或扩展讨论。如果您觉得这个问题可以改进并可能重新开放,visit
var FileBuff: TBytes; Pattern: TBytes; begin FileBuff := filetobytes(filename); Result := Co
我想要一个 vqmod xml 文件来添加一次上传多个图像的功能。身边有这样的事吗? 编辑:Opencart版本:2.1.0.1 最佳答案 最后我写了一个xml来添加到opencart 2.1.0.1
所以考虑这样的函数: public void setTemperature(double newTemperatureValue, TemperatureUnit unit) 其中Temperatur
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是偏离主题的,因为
我是 ggplot2 的新手,一直在尝试找到一个全面的美学列表。我想我理解它们的目的,但很难知道哪些可以在各种情况下使用(主要是几何图形?)。 Hadley 的网站偶尔会在各个几何图形的页面上列出可用
就目前情况而言,这个问题不太适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、民意调查或扩展讨论。如果您觉得这个问题可以改进并可能重新开放,visit
是否有任何 PHP 函数可以将整数转换为十万和千万? 900800 -> 9,00,800 500800 -> 5,00,800 最佳答案 由于您已在问题标签中添加了 Yii,因此您可以按照 Yii
使用 Clojure 一段时间后,我积累了一些关于它的惰性的知识。我知道诸如map之类的常用API是否是惰性的。然而,当我开始使用一个不熟悉的API(例如with-open)时,我仍然感到怀疑。 是否
我的项目需要一个像 AvalonDock 这样的对接系统,但它的最后一次更新似乎是在 2013 年 6 月。是否有更多...积极开发的东西可以代替它? 最佳答案 AvalonDock 实际上相当成熟并
我正在寻找一个可以逆转 clojure 打嗝的函数 所以 turns into [:html] 等等 根据@kotarak的回答,这现在对我有用: (use 'net.cgrand.enliv
我是一名优秀的程序员,十分优秀!