Android: run canvas WebView loads on main
parent
c6421136f9
commit
fceab511b3
|
|
@ -3,6 +3,7 @@ package com.steipete.clawdis.node.node
|
|||
import android.graphics.Bitmap
|
||||
import android.os.Build
|
||||
import android.graphics.Canvas
|
||||
import android.os.Looper
|
||||
import android.webkit.WebView
|
||||
import kotlinx.coroutines.Dispatchers
|
||||
import kotlinx.coroutines.suspendCancellableCoroutine
|
||||
|
|
@ -33,18 +34,30 @@ class CanvasController {
|
|||
reload()
|
||||
}
|
||||
|
||||
private fun reload() {
|
||||
private inline fun withWebViewOnMain(crossinline block: (WebView) -> Unit) {
|
||||
val wv = webView ?: return
|
||||
when (mode) {
|
||||
if (Looper.myLooper() == Looper.getMainLooper()) {
|
||||
block(wv)
|
||||
} else {
|
||||
wv.post { block(wv) }
|
||||
}
|
||||
}
|
||||
|
||||
private fun reload() {
|
||||
val currentMode = mode
|
||||
val currentUrl = url
|
||||
withWebViewOnMain { wv ->
|
||||
when (currentMode) {
|
||||
Mode.WEB -> {
|
||||
// Match iOS behavior: if URL is missing/invalid, keep the current page (canvas scaffold).
|
||||
val trimmed = url.trim()
|
||||
if (trimmed.isBlank()) return
|
||||
val trimmed = currentUrl.trim()
|
||||
if (trimmed.isBlank()) return@withWebViewOnMain
|
||||
wv.loadUrl(trimmed)
|
||||
}
|
||||
Mode.CANVAS -> wv.loadDataWithBaseURL(null, canvasHtml, "text/html", "utf-8", null)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
suspend fun eval(javaScript: String): String =
|
||||
withContext(Dispatchers.Main) {
|
||||
|
|
|
|||
Loading…
Reference in New Issue