<!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" class="active">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">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)">NBA</a></li>
        <li><a href="javascript:void(0);" onclick="ChangeScene(1)">EFL</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>Use the control bar to play/pause all videos in the group.</h3>
  </div>

  <div id="wrapper">
    <!-- NBA Videos -->
    <div class="video-container nba-video unsync-video">
      <h3>NBA - Unsync - View 1</h3>
      <video class="sync-nba-unsync" autoplay loop muted playsinline controls>
        <source src="../videos/wild/nba/ours/oq7OWPL5F9E_540_620_0/unsync.mp4" type="video/mp4">
        Your browser does not support the video tag.
      </video>
    </div>
    <div class="video-container nba-video unsync-video">
      <h3>NBA - Unsync - View 2</h3>
      <video class="sync-nba-unsync" autoplay loop muted playsinline controls>
        <source src="../videos/wild/nba/ours/oq7OWPL5F9E_440_520_1/unsync.mp4" type="video/mp4">
        Your browser does not support the video tag.
      </video>
    </div>
    <div class="video-container nba-video unsync-video">
      <h3>NBA - Unsync - View 3</h3>
      <video class="sync-nba-unsync" autoplay loop muted playsinline controls>
        <source src="../videos/wild/nba/ours/oq7OWPL5F9E_730_820_2/unsync.mp4" type="video/mp4">
        Your browser does not support the video tag.
      </video>
    </div>
  
    <div class="video-container nba-video visualsync-video" style="display: none;">
      <h3>NBA - VisualSync (ours) - View 1</h3>
      <video class="sync-nba-visualsync" autoplay loop muted playsinline controls>
        <source src="../videos/wild/nba/ours/oq7OWPL5F9E_540_620_0/sync.mp4" type="video/mp4">
        Your browser does not support the video tag.
      </video>
    </div>
    <div class="video-container nba-video visualsync-video" style="display: none;">
      <h3>NBA - VisualSync (ours) - View 2</h3>
      <video class="sync-nba-visualsync" autoplay loop muted playsinline controls>
        <source src="../videos/wild/nba/ours/oq7OWPL5F9E_440_520_1/sync.mp4" type="video/mp4">
        Your browser does not support the video tag.
      </video>
    </div>
    <div class="video-container nba-video visualsync-video" style="display: none;">
      <h3>NBA - VisualSync (ours) - View 3</h3>
      <video class="sync-nba-visualsync" autoplay loop muted playsinline controls>
        <source src="../videos/wild/nba/ours/oq7OWPL5F9E_730_820_2/sync.mp4" type="video/mp4">
        Your browser does not support the video tag.
      </video>
    </div>

    <!-- EFL Videos -->
    <div class="video-container efl-video unsync-video" style="display: none;">
      <h3>EFL - Unsync - View 1</h3>
      <video class="sync-efl-unsync" autoplay loop muted playsinline controls>
        <source src="../videos/wild/efl/ours/Z5TlCImQNK0_800_860_0/unsync.mp4" type="video/mp4">
        Your browser does not support the video tag.
      </video>
    </div>
    <div class="video-container efl-video unsync-video" style="display: none;">
      <h3>EFL - Unsync - View 2</h3>
      <video class="sync-efl-unsync" autoplay loop muted playsinline controls>
        <source src="../videos/wild/efl/ours/Z5TlCImQNK0_150_200_1/unsync.mp4" type="video/mp4">
        Your browser does not support the video tag.
      </video>
    </div>
    <div class="video-container efl-video unsync-video" style="display: none;">
      <h3>EFL - Unsync - View 3</h3>
      <video class="sync-efl-unsync" autoplay loop muted playsinline controls>
        <source src="../videos/wild/efl/ours/Z5TlCImQNK0_575_625_2/unsync.mp4" type="video/mp4">
        Your browser does not support the video tag.
      </video>
    </div>
      
    <div class="video-container efl-video visualsync-video" style="display: none;">
      <h3>EFL - VisualSync (ours) - View 1</h3>
      <video class="sync-efl-visualsync" autoplay loop muted playsinline controls>
        <source src="../videos/wild/efl/ours/Z5TlCImQNK0_800_860_0/sync.mp4" type="video/mp4">
        Your browser does not support the video tag.
      </video>
    </div>
    <div class="video-container efl-video visualsync-video" style="display: none;">
      <h3>EFL - VisualSync (ours) - View 2</h3>
      <video class="sync-efl-visualsync" autoplay loop muted playsinline controls>
        <source src="../videos/wild/efl/ours/Z5TlCImQNK0_150_200_1/sync.mp4" type="video/mp4">
        Your browser does not support the video tag.
      </video>
    </div>
    <div class="video-container efl-video visualsync-video" style="display: none;">
      <h3>EFL - VisualSync (ours) - View 3</h3>
      <video class="sync-efl-visualsync" autoplay loop muted playsinline controls>
        <source src="../videos/wild/efl/ours/Z5TlCImQNK0_575_625_2/sync.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 = ['nba', 'efl'];
    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 = {
          nba: {
            unsync: '.sync-nba-unsync',
            visualsync: '.sync-nba-visualsync'
          },
          efl: {
            unsync: '.sync-efl-unsync',
            visualsync: '.sync-efl-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>