From fc27f7cc1b56bcc9875711bbb1c967db3ca088e7 Mon Sep 17 00:00:00 2001 From: Brayan Oliveira <69634269+brayandso@users.noreply.github.com> Date: Sat, 23 Dec 2023 07:04:00 -0300 Subject: [PATCH] fix: not being able to seek videos --- .../java/com/ichi2/libanki/TemplateManager.kt | 18 +++++++++++++----- 1 file changed, 13 insertions(+), 5 deletions(-) diff --git a/AnkiDroid/src/main/java/com/ichi2/libanki/TemplateManager.kt b/AnkiDroid/src/main/java/com/ichi2/libanki/TemplateManager.kt index a9a19229519b..51b71ada2db7 100644 --- a/AnkiDroid/src/main/java/com/ichi2/libanki/TemplateManager.kt +++ b/AnkiDroid/src/main/java/com/ichi2/libanki/TemplateManager.kt @@ -184,16 +184,17 @@ class TemplateManager { * because of old webview codecs in python, and to allow extending the video player. * To simplify things and deliver a better result, * we use the webview player, like AnkiMobile does + * + * `file:///` is used to enable seeking the video */ - fun parseVideos(text: String): String { + fun parseVideos(text: String, mediaDir: String): String { return SOUND_RE.replace(text) { match -> val fileName = match.groupValues[1] val extension = fileName.substringAfterLast(".", "") if (extension in VIDEO_EXTENSIONS) { - @Suppress("HtmlUnknownAttribute") // controlsList is valid, but marked as invalid in the IDE @Language("HTML") val result = - """""" + """""" result } else { match.value @@ -201,11 +202,18 @@ class TemplateManager { } } - val qtext = parseVideos(applyCustomFilters(partial.qnodes, this, front_side = null)) + val mediaDir = col().media.dir + val qtext = parseVideos( + text = applyCustomFilters(partial.qnodes, this, front_side = null), + mediaDir = mediaDir + ) val qout = col().backend.extractAvTags(text = qtext, questionSide = true) var qoutText = qout.text - val atext = parseVideos(applyCustomFilters(partial.anodes, this, front_side = qout.text)) + val atext = parseVideos( + text = applyCustomFilters(partial.anodes, this, front_side = qout.text), + mediaDir = mediaDir + ) val aout = col().backend.extractAvTags(text = atext, questionSide = false) var aoutText = aout.text