import 'package:flutter/material.dart'; import 'package:flutter_inappbrowser/flutter_inappbrowser.dart'; class InlineExampleScreen extends StatefulWidget { @override _InlineExampleScreenState createState() => new _InlineExampleScreenState(); } class User { String username; String password; User({this.username, this.password}); Map toJson() { return { 'username': this.username, 'password': this.password }; } } class _InlineExampleScreenState extends State { InAppWebViewController webView; String url = ""; double progress = 0; @override void initState() { super.initState(); } @override void dispose() { super.dispose(); } @override Widget build(BuildContext context) { return Container( child: Column(children: [ Container( padding: EdgeInsets.all(20.0), child: Text( "CURRENT URL\n${(url.length > 50) ? url.substring(0, 50) + "..." : url}"), ), Container( padding: EdgeInsets.all(10.0), child: progress < 1.0 ? LinearProgressIndicator(value: progress) : null ), Expanded( child: Container( margin: const EdgeInsets.all(10.0), decoration: BoxDecoration(border: Border.all(color: Colors.blueAccent)), child: InAppWebView( //initialUrl: "https://mottie.github.io/Keyboard/", initialFile: "assets/index.html", initialHeaders: {}, initialOptions: { //"useShouldOverrideUrlLoading": true, //"useOnLoadResource": true }, onWebViewCreated: (InAppWebViewController controller) { webView = controller; controller.addJavaScriptHandler('handlerTest', (args) { return new User(username: 'user', password: 'secret'); }); }, onLoadStart: (InAppWebViewController controller, String url) { print("started $url"); setState(() { this.url = url; }); }, onLoadStop: (InAppWebViewController controller, String url) async { print("stopped $url"); }, onProgressChanged: (InAppWebViewController controller, int progress) { setState(() { this.progress = progress / 100; }); }, shouldOverrideUrlLoading: (InAppWebViewController controller, String url) { print("override $url"); controller.loadUrl(url); }, onLoadResource: (InAppWebViewController controller, WebResourceResponse response, WebResourceRequest request) { print("resource " + request.url); }, onConsoleMessage: (InAppWebViewController controller, ConsoleMessage consoleMessage) { print(consoleMessage.message); }, ), ), ), ButtonBar( alignment: MainAxisAlignment.center, children: [ RaisedButton( child: Icon(Icons.arrow_back), onPressed: () { if (webView != null) { webView.goBack(); } }, ), RaisedButton( child: Icon(Icons.arrow_forward), onPressed: () { if (webView != null) { webView.goForward(); } }, ), RaisedButton( child: Icon(Icons.refresh), onPressed: () { if (webView != null) { webView.reload(); } }, ), ], ), ])); } }