<!doctype html>
<html lang="en">


<head>
  <title>Video Synchronization Results</title>
  <meta charset="UTF-8" />
  <meta name="viewport" content="width=device-width, initial-scale=1, minimum-scale=1" />
  <link rel="stylesheet" href="../files/styles.css">
</head>

<body>
  <nav class="nav-links">
    <a href="../supp.html">Qualitative Comparison</a>
    <a href="wild.html">In-the-wild Results</a>
    <a href="egohumans.html">Egohumans Results</a>
    <a href="panoptic.html">Panoptic Results</a>
    <a href="3dpop.html">3D-POP Results</a>
    <a href="blender.html" class="active">UDBD Results</a>
  </nav>

  <div class="selectors">
    <div class="scene-selector">
      <h3>Scene</h3>
      <ul class="nav-pills" id="scene-selector">
        <li class="active"><a href="javascript:void(0);" onclick="ChangeScene(0)">Deer</a></li>
        <li><a href="javascript:void(0);" onclick="ChangeScene(1)">Box</a></li>
      </ul>
    </div>

    <div class="method-selector">
      <h3>Method</h3>
      <ul class="nav-pills" id="method-selector">
        <li class="active"><a href="javascript:void(0);" onclick="ChangeMethod(0)">Unsync</a></li>
        <li><a href="javascript:void(0);" onclick="ChangeMethod(1)">VisualSync (Ours)</a></li>
      </ul>
    </div>
  </div>

  <div class="instructions">
    <h3>Top: multi-view videos. Bottom: timeline. Use the control bar to play/pause all videos in the group.</h3>
  </div>

  <div id="wrapper">

    <!-- Deer Videos -->
    <div class="video-container blenderdeer-video unsync-video" style="display: none;">
      <h3>Deer - Unsync - View 1</h3>
      <video class="sync-blenderdeer-unsync" autoplay loop muted playsinline controls>
        <source src="../videos/blender/blenderdeer/ours/blenderdeer_cam03_11_280_0/unsync.mp4" type="video/mp4">
        Your browser does not support the video tag.
      </video>
    </div>
    <div class="video-container blenderdeer-video unsync-video" style="display: none;">
      <h3>Deer - Unsync - View 2</h3>
      <video class="sync-blenderdeer-unsync" autoplay loop muted playsinline controls>
        <source src="../videos/blender/blenderdeer/ours/blenderdeer_cam07_10_279_1/unsync.mp4" type="video/mp4">
        Your browser does not support the video tag.
      </video>
    </div>
    <div class="video-container blenderdeer-video unsync-video" style="display: none;">
      <h3>Deer - Unsync - View 3</h3>
      <video class="sync-blenderdeer-unsync" autoplay loop muted playsinline controls>
        <source src="../videos/blender/blenderdeer/ours/blenderdeer_cam13_12_281_2/unsync.mp4" type="video/mp4">
        Your browser does not support the video tag.
      </video>
    </div>
    <div class="timeline-container blenderdeer-video unsync-video" style="display: none;">
      
      <video class="sync-blenderdeer-unsync" autoplay loop muted playsinline controls>
        <source src="../videos/blender/blenderdeer/ours/unsync_timelines.mp4" type="video/mp4">
        Your browser does not support the video tag.
      </video>
    </div>

    <div class="video-container blenderdeer-video visualsync-video" style="display: none;">
      <h3>Deer - VisualSync (ours) - View 1</h3>
      <video class="sync-blenderdeer-visualsync" autoplay loop muted playsinline controls>
        <source src="../videos/blender/blenderdeer/ours/blenderdeer_cam03_11_280_0/sync.mp4" type="video/mp4">
        Your browser does not support the video tag.
      </video>
    </div>
    <div class="video-container blenderdeer-video visualsync-video" style="display: none;">
      <h3>Deer - VisualSync (ours) - View 2</h3>
      <video class="sync-blenderdeer-visualsync" autoplay loop muted playsinline controls>
        <source src="../videos/blender/blenderdeer/ours/blenderdeer_cam07_10_279_1/sync.mp4" type="video/mp4">
        Your browser does not support the video tag.
      </video>
    </div>
    <div class="video-container blenderdeer-video visualsync-video" style="display: none;">
      <h3>Deer - VisualSync (ours) - View 3</h3>
      <video class="sync-blenderdeer-visualsync" autoplay loop muted playsinline controls>
        <source src="../videos/blender/blenderdeer/ours/blenderdeer_cam13_12_281_2/sync.mp4" type="video/mp4">
        Your browser does not support the video tag.
      </video>
    </div>
    <div class="timeline-container blenderdeer-video visualsync-video" style="display: none;">
      
      <video class="sync-blenderdeer-visualsync" autoplay loop muted playsinline controls>
        <source src="../videos/blender/blenderdeer/ours/sync_timelines.mp4" type="video/mp4">
        Your browser does not support the video tag.
      </video>
    </div>

    <!-- Box Videos -->
    <div class="video-container blenderbox-video unsync-video">
      <h3>Box - Unsync - View 1</h3>
      <video class="sync-blenderbox-unsync" autoplay loop muted playsinline controls>
        <source src="../videos/blender/blenderbox/ours/blenderbox_cam06_13_282_0/unsync.mp4" type="video/mp4">
        Your browser does not support the video tag.
      </video>
    </div>
    <div class="video-container blenderbox-video unsync-video">
      <h3>Box - Unsync - View 2</h3>
      <video class="sync-blenderbox-unsync" autoplay loop muted playsinline controls>
        <source src="../videos/blender/blenderbox/ours/blenderbox_cam10_15_284_1/unsync.mp4" type="video/mp4">
        Your browser does not support the video tag.
      </video>
    </div>
    <div class="video-container blenderbox-video unsync-video">
      <h3>Box - Unsync - View 3</h3>
      <video class="sync-blenderbox-unsync" autoplay loop muted playsinline controls>
        <source src="../videos/blender/blenderbox/ours/blenderbox_cam13_12_281_2/unsync.mp4" type="video/mp4">
        Your browser does not support the video tag.
      </video>
    </div>
    <div class="timeline-container blenderbox-video unsync-video">
      <video class="sync-blenderbox-unsync" autoplay loop muted playsinline controls>
        <source src="../videos/blender/blenderbox/ours/unsync_timelines.mp4" type="video/mp4">
        Your browser does not support the video tag.
      </video>
    </div>

    <div class="video-container blenderbox-video visualsync-video" style="display: none;">
      <h3>Box - VisualSync (ours) - View 1</h3>
      <video class="sync-blenderbox-visualsync" autoplay loop muted playsinline controls>
        <source src="../videos/blender/blenderbox/ours/blenderbox_cam06_13_282_0/sync.mp4" type="video/mp4">
        Your browser does not support the video tag.
      </video>
    </div>
    <div class="video-container blenderbox-video visualsync-video" style="display: none;">
      <h3>Box - VisualSync (ours) - View 2</h3>
      <video class="sync-blenderbox-visualsync" autoplay loop muted playsinline controls>
        <source src="../videos/blender/blenderbox/ours/blenderbox_cam10_15_284_1/sync.mp4" type="video/mp4">
        Your browser does not support the video tag.
      </video>
    </div>
    <div class="video-container blenderbox-video visualsync-video" style="display: none;">
      <h3>Box - VisualSync (ours) - View 3</h3>
      <video class="sync-blenderbox-visualsync" autoplay loop muted playsinline controls>
        <source src="../videos/blender/blenderbox/ours/blenderbox_cam13_12_281_2/sync.mp4" type="video/mp4">
        Your browser does not support the video tag.
      </video>
    </div>
    <div class="timeline-container blenderbox-video visualsync-video" style="display: none;">
      
      <video class="sync-blenderbox-visualsync" autoplay loop muted playsinline controls>
        <source src="../videos/blender/blenderbox/ours/sync_timelines.mp4" type="video/mp4">
        Your browser does not support the video tag.
      </video>
    </div>


  </div>

  <script>
    // Global variables for video synchronization
    let isUpdating = false;
    let activeVideoGroup = [];

    // Video synchronization functionality
    function clearAllVideoListeners() {
      document.querySelectorAll('video').forEach(video => {
        if (video._syncHandlers) {
          video.removeEventListener('play', video._syncHandlers.play);
          video.removeEventListener('pause', video._syncHandlers.pause);
          video.removeEventListener('seeked', video._syncHandlers.seeked);
          video.removeEventListener('timeupdate', video._syncHandlers.timeupdate);
          video._syncHandlers = null;
        }
      });
      activeVideoGroup = [];
    }

    function syncVideosInGroup(groupSelector) {
      clearAllVideoListeners();
      
      const videos = Array.from(document.querySelectorAll(groupSelector)).filter(video => 
        video.closest('.video-container, .timeline-container').style.display !== 'none'
      );
      
      if (videos.length === 0) return;
      
      activeVideoGroup = videos;

      videos.forEach((video, index) => {
        const handlers = {
          play: () => {
            if (isUpdating) return;
            isUpdating = true;
            videos.forEach((otherVideo, otherIndex) => {
              if (otherIndex !== index && otherVideo.paused) {
                otherVideo.currentTime = video.currentTime;
                otherVideo.play().catch(() => {}); // Ignore promise rejections
              }
            });
            isUpdating = false;
          },

          pause: () => {
            if (isUpdating) return;
            isUpdating = true;
            videos.forEach((otherVideo, otherIndex) => {
              if (otherIndex !== index && !otherVideo.paused) {
                otherVideo.pause();
              }
            });
            isUpdating = false;
          },

          seeked: () => {
            if (isUpdating) return;
            isUpdating = true;
            videos.forEach((otherVideo, otherIndex) => {
              if (otherIndex !== index && Math.abs(otherVideo.currentTime - video.currentTime) > 0.1) {
                otherVideo.currentTime = video.currentTime;
              }
            });
            isUpdating = false;
          },

          timeupdate: () => {
            // Light synchronization during playback to handle drift
            if (isUpdating || video.paused) return;
            
            const tolerance = 0.3; // Allow 300ms drift before correction
            videos.forEach((otherVideo, otherIndex) => {
              if (otherIndex !== index && !otherVideo.paused) {
                const timeDiff = Math.abs(otherVideo.currentTime - video.currentTime);
                if (timeDiff > tolerance) {
                  otherVideo.currentTime = video.currentTime;
                }
              }
            });
          }
        };

        video._syncHandlers = handlers;
        video.addEventListener('play', handlers.play);
        video.addEventListener('pause', handlers.pause);
        video.addEventListener('seeked', handlers.seeked);
        video.addEventListener('timeupdate', handlers.timeupdate);
      });
    }

    const videoContainers = document.querySelectorAll('.video-container');
    const colors = ['#3498DB', '#2ECC71', '#F39C12']; // Blue, Green, Orange

    videoContainers.forEach((container, index) => {
      const colorIndex = index % colors.length;
      container.style.borderColor = colors[colorIndex];
    });

    let currentScene = 0;
    let currentMethod = 0;

    const scenes = ['blenderdeer', 'blenderbox'];
    const methods = ['unsync', 'visualsync'];

    function updateView() {
      // Clear existing video synchronization
      clearAllVideoListeners();

      // Hide all videos
      document.querySelectorAll('.video-container, .timeline-container').forEach(container => {
        container.style.display = 'none';
      });

      // Show current scene and method
      const sceneClass = scenes[currentScene] + '-video';
      const methodClass = methods[currentMethod] + '-video';
      
      document.querySelectorAll('.' + sceneClass + '.' + methodClass).forEach(container => {
        container.style.display = 'block';
      });

      // Update active tab styles
      document.querySelectorAll('#scene-selector li').forEach((li, idx) =>
        li.classList.toggle('active', idx === currentScene)
      );
      document.querySelectorAll('#method-selector li').forEach((li, idx) =>
        li.classList.toggle('active', idx === currentMethod)
      );

      // Set up video synchronization for the currently visible videos
      setTimeout(() => {
        const currentSceneName = scenes[currentScene];
        const currentMethodName = methods[currentMethod];
        
        // Sync videos based on their class names
        const syncSelectors = {
          blenderbox: {
            unsync: '.sync-blenderbox-unsync',
            visualsync: '.sync-blenderbox-visualsync'
          },
          blenderdeer: {
            unsync: '.sync-blenderdeer-unsync',
            visualsync: '.sync-blenderdeer-visualsync'
          }
        };

        const selector = syncSelectors[currentSceneName]?.[currentMethodName];
        if (selector) {
          syncVideosInGroup(selector);
        }
      }, 150); // Increased delay to ensure DOM is fully updated
    }

    function ChangeScene(index) {
      currentScene = index;
      updateView();
    }

    function ChangeMethod(index) {
      currentMethod = index;
      updateView();
    }

    window.onload = updateView;
  </script>

</body>

</html>