1- [ ![ pub package] ( https://img.shields.io/pub/v/flutter_webview_plugin.svg )] ( https://pub.dartlang.org/packages/flutter_webview_plugin )
1+ <img src="https://img.shields.io/badge/Flutter%20Communityflutter__webview__plugin-blue.svg?style=for-the-badge&logo=" width="800">
22
3+ [ Flutter Community] ( https://github.com/fluttercommunity/community )
34
4- # flutter_webview_plugin
5+ # Flutter WebView Plugin
56
6- Plugin that allow Flutter to communicate with a native WebView.
7+ [ ![ pub package ] ( https://img.shields.io/pub/v/flutter_webview_plugin.svg )] ( https://pub.dartlang.org/packages/flutter_webview_plugin )
78
8- *** Warning:***
9+ Plugin that allows Flutter to communicate with a native WebView.
10+
11+ ** _ Warning:_ **
912The webview is not integrated in the widget tree, it is a native view on top of the flutter view.
1013you won't be able to use snackbars, dialogs ...
1114
@@ -21,24 +24,57 @@ For help getting started with Flutter, view our online [documentation](http://fl
2124new MaterialApp(
2225 routes: {
2326 "/": (_) => new WebviewScaffold(
24- url: "https://www.google.com",
25- appBar: new AppBar(
26- title: new Text("Widget webview"),
27- ),
28- )
27+ url: "https://www.google.com",
28+ appBar: new AppBar(
29+ title: new Text("Widget webview"),
30+ ),
31+ ),
2932 },
3033 );
3134```
3235
36+ Optional parameters ` hidden ` and ` initialChild ` are available so that you can show something else while waiting for the page to load.
37+ If you set ` hidden ` to true it will show a default CircularProgressIndicator. If you additionally specify a Widget for initialChild
38+ you can have it display whatever you like till page-load.
39+
40+ e.g. The following will show a read screen with the text 'waiting.....'.
41+ ``` dart
42+ return new MaterialApp(
43+ title: 'Flutter WebView Demo',
44+ theme: new ThemeData(
45+ primarySwatch: Colors.blue,
46+ ),
47+ routes: {
48+ '/': (_) => const MyHomePage(title: 'Flutter WebView Demo'),
49+ '/widget': (_) => new WebviewScaffold(
50+ url: selectedUrl,
51+ appBar: new AppBar(
52+ title: const Text('Widget webview'),
53+ ),
54+ withZoom: true,
55+ withLocalStorage: true,
56+ hidden: true,
57+ initialChild: Container(
58+ color: Colors.redAccent,
59+ child: const Center(
60+ child: Text('Waiting.....'),
61+ ),
62+ ),
63+ ),
64+ },
65+ );
66+ ```
67+
3368` FlutterWebviewPlugin ` provide a singleton instance linked to one unique webview,
3469so you can take control of the webview from anywhere in the app
3570
3671listen for events
72+
3773``` dart
3874final flutterWebviewPlugin = new FlutterWebviewPlugin();
3975
4076flutterWebviewPlugin.onUrlChanged.listen((String url) {
41-
77+
4278});
4379```
4480
@@ -62,7 +98,7 @@ Note: Do note there is a slight difference is scroll distance between ios and an
6298#### Hidden WebView
6399
64100```dart
65- final flutterWebviewPlugin = new FlutterWebviewPlugin();
101+ final flutterWebviewPlugin = new FlutterWebviewPlugin();
66102
67103flutterWebviewPlugin.launch(url, hidden: true);
68104```
@@ -76,58 +112,98 @@ flutterWebviewPlugin.close();
76112#### Webview inside custom Rectangle
77113
78114``` dart
79- final flutterWebviewPlugin = new FlutterWebviewPlugin();
115+ final flutterWebviewPlugin = new FlutterWebviewPlugin();
80116
81117flutterWebviewPlugin.launch(url,
82- fullScreen: false,
83- rect: new Rect.fromLTWH(
84- 0.0,
85- 0.0,
86- MediaQuery.of(context).size.width,
87- 300.0));
118+ fullScreen: false,
119+ rect: new Rect.fromLTWH(
120+ 0.0,
121+ 0.0,
122+ MediaQuery.of(context).size.width,
123+ 300.0,
124+ ),
125+ );
88126```
89127
90128### Webview Events
91129
92130- ` Stream<Null> ` onDestroy
93131- ` Stream<String> ` onUrlChanged
94132- ` Stream<WebViewStateChanged> ` onStateChanged
133+ - ` Stream<double> ` onScrollXChanged
134+ - ` Stream<double> ` onScrollYChanged
95135- ` Stream<String> ` onError
96136
97- *** Don 't forget to dispose webview * **
137+ ** _ Don 't forget to dispose webview _ **
98138` flutterWebviewPlugin.dispose() `
99139
100140### Webview Functions
101141
102142``` dart
103- Future<Null> launch(String url,
104- {Map<String, String> headers: null,
105- bool withJavascript: true,
106- bool clearCache: false,
107- bool clearCookies: false,
108- bool hidden: false,
109- bool enableAppScheme: true,
110- Rect rect: null,
111- String userAgent: null,
112- bool withZoom: false,
113- bool withLocalStorage: true,
114- bool scrollBar: true});
143+ Future<Null> launch(String url, {
144+ Map<String, String> headers: null,
145+ bool withJavascript: true,
146+ bool clearCache: false,
147+ bool clearCookies: false,
148+ bool hidden: false,
149+ bool enableAppScheme: true,
150+ Rect rect: null,
151+ String userAgent: null,
152+ bool withZoom: false,
153+ bool withLocalStorage: true,
154+ bool withLocalUrl: true,
155+ bool scrollBar: true,
156+ bool supportMultipleWindows: false,
157+ bool appCacheEnabled: false,
158+ bool allowFileURLs: false,
159+ });
115160```
161+
116162``` dart
117163Future<String> evalJavascript(String code);
118164```
165+
119166``` dart
120167Future<Map<String, dynamic>> getCookies();
121168```
169+
170+ ``` dart
171+ Future<Null> cleanCookies();
172+ ```
173+
122174``` dart
123175Future<Null> resize(Rect rect);
124176```
177+
125178``` dart
126179Future<Null> show();
127180```
181+
128182``` dart
129183Future<Null> hide();
130184```
185+
131186``` dart
132187Future<Null> reloadUrl(String url);
133188```
189+
190+ ``` dart
191+ Future<Null> close();
192+ ```
193+
194+ ``` dart
195+ Future<Null> reload();
196+ ```
197+
198+ ``` dart
199+ Future<Null> goBack();
200+ ```
201+
202+ ``` dart
203+ Future<Null> goForward();
204+ ```
205+
206+ ``` dart
207+ Future<Null> stopLoading();
208+ ```
209+
0 commit comments