fluttercommunity / flutter_webview_plugin

Community WebView Plugin - Allows Flutter to communicate with a native WebView.
https://pub.dev/packages/flutter_webview_plugin
Other
1.48k stars 929 forks source link

The webview got blocked when the there is some heavy computation in onMessageReceived. #857

Open ishaan-puniani opened 3 years ago

ishaan-puniani commented 3 years ago

Hello, I am using webview in my application, and I am using postmessages from communication and maintaining state between flutter app and webview. The issue that I am struggling with is if there is some heavy computation is going on in onMessageReceived callback of JavascriptChannel then the webview stuck.

For Example:

javascriptChannels: <JavascriptChannel>[
          JavascriptChannel(
              name: 'Tts',
              onMessageReceived: (JavascriptMessage msg) {
                sleep(const Duration(seconds: 60)); <<-- something to mimic the computational delay.
                ttsMessagesReceived.add(msg.message);
              }),
        ].toSet(),

I was under impressions that webview has its own process and UI thread and flutter is executing in its own process. so, in that case this should not block each other.

Is there any way to make it async so that webview will continues its functioning smoothly and onMessageReceived will do its computation in parallel? I tried to wrap it with async / await but it didn't help..

Ref: https://github.com/flutter/plugins/blob/master/packages/webview_flutter/test/webview_flutter_test.dart#L581