Skip to content
  • Recent
  • Tags
  • Popular
  • Users
  • Search
Skins
  • Light
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Default (No Skin)
  • No Skin
Collapse

Lay Theme Forum

  1. Home
  2. General Discussion
  3. Image hover addon with video possible?

Image hover addon with video possible?

Scheduled Pinned Locked Moved General Discussion
5 Posts 3 Posters 131 Views
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • V Offline
    V Offline
    Verena
    wrote on last edited by
    #1

    I’d like to insert a video instead of image as hover. Is this possible? Gifs are juste too low in quality.

    1 Reply Last reply
    0
    • arminunruhA Offline
      arminunruhA Offline
      arminunruh
      Global Moderator
      wrote on last edited by
      #2

      ahh no its not possible :O
      but a good idea, i will write it down

      1 Reply Last reply
      1
      • V Offline
        V Offline
        Verena
        wrote on last edited by
        #3

        Would be nice to have in the future. Tanks a lot! :)

        1 Reply Last reply
        1
        • M Offline
          M Offline
          melo_lenosier
          wrote on last edited by
          #4

          I am also very interested in this. Video-hover would be great.
          Thank you!

          1 Reply Last reply
          0
          • M Offline
            M Offline
            melo_lenosier
            wrote on last edited by
            #5

            If anybody needs it, here is the script I used.
            It was tricky because there was an annoying phenomena between the hover and the scroll functions. Basically while scrolling the page, the browser (Chrome especially) doesn't send any other mouse coordinates, therefore the hovered video was constantly there till the scroll was stopped.

            Here is a script that avoid this problem:

            <script>
            let hoveredElement;
            let mouseX = 0, mouseY = 0;
            
            document.addEventListener('DOMContentLoaded', () => {
              document.addEventListener('mousemove', event => {
                mouseX = event.clientX;
                mouseY = event.clientY;
            
                hover(event.target);
              });
            
              document.addEventListener('scroll', () => {
                const hoverTarget = document.elementFromPoint(mouseX, mouseY);
                if (hoverTarget) {
                  hover(hoverTarget);
                }
              });
            });
            
            function hover(targetElement) {
              // If the target and stored element are the same, return early
              // because setting it again is unnecessary.
              if (hoveredElement === targetElement) {
                return;
              }
            // On first run, `hoveredElement` is undefined.
              if (hoveredElement) {
                if (hoveredElement.hasAttribute("data-videoid")) {
            document.getElementById(hoveredElement.getAttribute("data-videoid")).classList.remove('hoverscrolled');
                 console.log(hoveredElement.getAttribute("data-videoid"));
                 console.log(document.getElementById(hoveredElement.getAttribute("data-videoid")));
            
            }
            
              }
            
              hoveredElement = targetElement;
            if (hoveredElement.hasAttribute("data-videoid")) {
            document.getElementById(hoveredElement.getAttribute("data-videoid")).classList.add('hoverscrolled');
                  console.log(hoveredElement.getAttribute("data-videoid"));
                 console.log(document.getElementById(hoveredElement.getAttribute("data-videoid")));
            }
            
            }
            </script>
            

            HTML:

            <div data-videoid="one_data"  >
            </div>
            
            <video id="one_data" class="vid_background" autoplay muted loop>
              <source src="https://somevideo.mp4" type="video/mp4">  Your browser does not support HTML5 video.
            </video>
            
            

            CSS:

            video.vid_background{
                 opacity: 0;
                 left: 50%;
                top: 50%;
                transform: translate(-50%, -50%);
                z-index: -5;
                width: 40%;
                position: fixed;
                height: 50%;
                -webkit-transition: none;
                -o-transition: none;
                transition: none;
             }
             
            video.vid_background.hoverscrolled  {
                opacity: 1;
                left: 50%;
                top: 50%;
                transform: translate(-50%, -50%);
                z-index: -5;
                width: 40%;
                position: fixed;
                height: 50%; 
                -webkit-transition: none;
                -o-transition: none;
                transition: none;
             }
            
            1 Reply Last reply
            1
            Reply
            • Reply as topic
            Log in to reply
            • Oldest to Newest
            • Newest to Oldest
            • Most Votes


            I also code custom websites or custom Lay features.
            💿 Email me here: 💿
            info@laytheme.com

            Before you post:
            1. When using a WordPress Cache plugin, disable it or clear your cache.
            2. Update Lay Theme and all Lay Theme Addons
            3. Disable all Plugins
            4. Go to Lay Options → Custom CSS & HTML, click "Turn Off All Custom Code", click "Save Changes"

            This often solves issues you might run into

            When you post:
            1. Post a link to where the problem is
            2. Does the problem happen on Chrome, Firefox, Safari or iPhone or Android?
            3. If the problem is difficult to explain, post screenshots / link to a video to explain it
            Online Users
            C
            chrisboender
            Forgot your key, lost your files, need a previous Lay Theme or Addon version? Go to www.laykeymanager.com
            laytheme.com
            • Login

            • Don't have an account? Register

            • Login or register to search.
            • First post
              Last post
            0
            • Recent
            • Tags
            • Popular
            • Users
            • Search