-
Notifications
You must be signed in to change notification settings - Fork 609
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
fix(#865): BackgroundVideo.astro
not playing when changing combat
#866
fix(#865): BackgroundVideo.astro
not playing when changing combat
#866
Conversation
@AlejandroSuero is attempting to deploy a commit to the midudev pro Team on Vercel. A member of the Team first needs to authorize it. |
@AlejandroSuero Safari creo que no reproduce automáticamente ningún video si está en modo low power (o ahooro de energía). Será por eso que no te funciona en Safari? |
Aunque ahora que lo pienso, si fuese ese el problema, tampoco debería reproducirse la primera vez... |
@lucas-labs no ese no es el problema, además me asegurado ahora por si acaso y he conectado también el cargador, pero sigue igual. Además si recargo la página se reproduce igualmente. Tampoco cargan las fuentes en local, por algún motivo. |
He notado que se reduzco el script a esto: <script>
import { $ } from "@/lib/dom-selector"
const $bgVideoDiv = $("#bg-video")
if ($bgVideoDiv) $bgVideoDiv.querySelector("video")?.play()
</script> Tampoco hay diferencia en Chrome, pero en Safari sigue con el mismo problema. |
😒 Safari is the new IE6. Estuve googleando un poco y por ahora la única solución que estoy viendo repetida en distintas fuentes es el No estoy tan familiarizado con Astro, pero podría llegar a ser que el script solo se esté ejecutando la primera vez? Quizá habría que supeditar el script a algún evento (asegurarse de que el script se ejecute nuevamente al cambiar de página). |
Esta es mi primera vez trabajando con Astro también así que no me sé muy bien que eventos habría que tarjetear para conseguirlo. |
import { $ } from "@/lib/dom-selector"
- const $bgVideoDiv = $("#bg-video")
const playVideo = () => {
+ const $bgVideoDiv = $("#bg-video")
if ($bgVideoDiv) {
let video = $bgVideoDiv.querySelector("video")
if (video) {
video.play()
}
}
}
document.addEventListener("astro:page-load", playVideo) @AlejandroSuero podrías probar el script así? (yo estoy en situación de windows así que no tengo Safari 😅, por desgracia o por suerte) Creo que lo que puede estar pasando es que en tu script actual, estás tomando la referencia del En el script de arriba lo vuelvo a tomar cada vez que se dispare el evento. Seguramente la referencia al video que estamos haciéndo |
@lucas-labs he probado a hacer eso pero sigue el mismo resultado 😥.
|
Hay varios problemas con el reproductor de video.
El caso más facil es el de ios: video tiene un atributo En safari se puede solucionar en lugar de trabajar con el src de source, trabajar con el src de video... (no me preguntes 🙈) En firefox hay un problema con las transition view. Si se quiere que en firefox funcione hay que descartar la view transition de combates a combate |
Firefox doesnt accept it.
Firefox no está llevando muy bien el tema de view-transitions... He hecho una pr a tu fork con los cambios que he ido mencionando. Puedes mirar los cambios en cada commit para ir solucionando los problemas. En el caso de firefox he eliminado los atributos de De este modo, firefox hace todo el ciclo de load de la página y va a buscar el video... |
* add src on video tag for safari support * refactor url * remove transitions from combats to combat to fix video loading for firefox * remove script in backgroundvideo
@yurigo ahora ya funciona, gracias. Voy a ver si meto un poco de lógica para detectar si es firefox y añadir o no las view transitions y si no funciona o se rompe pues se queda así. |
@yurigo @lucas-labs creo que ahora ya funciona en todos, al menos lo he probado en: Firefox, Safari, Safari iOS, Google Chrome, Brave. Si veis algo que falla, decídmelo. |
@AlejandroSuero Estaba explorando otro camino para solucionar esto de las view transitions para firefox sin necesidad de consultar si es firefox o no. He hecho lo siguiente: He hecho un revert del commit que eliminaba las
height={combatData.titleSize[1]}
+ transition:name={`title-image-${combat.id}`}
loading={index < 2 ? "eager" : "lazy"}
height={imageHeight}
+ transition:name={`title-image-${id}`}
loading={"eager"} Y después, en <div class="fixed left-0 top-0 -z-10 aspect-video h-[100vh] w-screen" id="bg-video">
<video
+ id="video-player"
muted
loop
class="aspect-video size-full overflow-hidden object-cover opacity-0 transition-opacity duration-500"
style="mask-image: linear-gradient(to bottom, rgba(0,0,0,1) 70%, transparent);"
oncanplay="this.classList.add('opacity-70')"
playsinline
src={url}
>
<source type="video/mp4" src={url} />
</video>
</div>
+<script is:inline>
+ document.getElementById("video-player").load()
+</script> |
BackgroundVideo.astro
not playing when changing combat
A mi me pasa en Chrome Combates.-.La.Velada.del.Ano.IV.-.Google.Chrome.2024-04-11.20-10-14.mp4 |
El código de Firefox no puede funcionar tal y como está puesto ya que ese JavaScript se ejecutaría a nivel de servidor o build time y no en el cliente. Igualmente lo demás tiene buena pinta así que lo voy a mergear y en todo caso quitaré ese código de Firefox. Si al final el vídeo no funciona en Firefox, tampoco es grave, es una característica que estaría bien tener pero tampoco rompe la página. |
En el último commit (el que elimina el código de detección de firefox) has eliminado de |
Descripción
Soluciono un bug que introduje en #849
Problema solucionado
Closes #865.
Cambios propuestos
autoplay
en la etiquetavideo
.Capturas de pantalla (si corresponde)
Chrome: (No problem)
fix-video-background.mp4
Safari: (Problem)
video-problem-in-safari.mp4
@midudev sabes por qué puede estar pasando esto?
Comprobación de cambios
Impacto potencial
Contexto adicional
Enlaces útiles