<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8" />
  <title>Frequency-Aware Gaussian Splatting Decomposition</title>
  <style>
    /* ===== Global Styles ===== */
    body {
      margin: 0; 
      padding: 0;
      background: #f8f8f8;
      color: #333;
      font-family: Arial, sans-serif;
    }
    h1 {
      text-align: center;
      margin-top: 20px;
      font-weight: normal;
    }
    .description {
      max-width: 800px;
      margin: 10px auto 30px;
      font-size: 1rem;
      text-align: center;
      line-height: 1.4;
      color: #555;
    }
    /* Container + row layout */
    .container {
      width: 98%;
      max-width: 2000px;
      margin: 0 auto 40px;
    }
    .compare-row {
      display: flex;
      flex-wrap: wrap;
      gap: 20px;
      margin-bottom: 30px;
      justify-content: center;
    }
    /* Comparison blocks larger to reduce white space */
    .compare-block {
      display: flex;
      flex-direction: column;
      background: #fff;
      border: 2px solid #ccc;
      flex: 1 1 700px;
      max-width: 900px;
      margin: 0 auto;
    }
    .block-title {
      background: #eee;
      padding: 10px;
      margin: 0;
      text-align: center;
      font-size: 1rem;
      font-weight: bold;
      border-bottom: 2px solid #ccc;
      line-height: 1.3;
    }
    /* Video wrapper ensures 16:9 aspect ratio */
    .video-wrapper {
      position: relative;
      width: 100%;
      aspect-ratio: 16 / 9;
      overflow: hidden;
    }

    /********************************************************
     *  BACKGROUND / MIDDLE / TOP containers for videos
     *  We set pointer-events: none so they don't block slider drags
     ********************************************************/
    .vid-bg, .vid-mid, .vid-top,
    .vid-bg2, .vid-top2 {
      position: absolute;
      top: 0; left: 0; right: 0; bottom: 0;
      overflow: hidden;
      pointer-events: none; /* IMPORTANT: allows slider input beneath */
    }
    /* z-index layering for 3-video: bg=1, mid=2, top=3; slider=100 */
    .vid-bg  { z-index: 1; }
    .vid-mid { z-index: 2; }
    .vid-top { z-index: 3; }

    /* For 2-way: background=1, overlay=2 */
    .vid-bg2  { z-index: 1; }
    .vid-top2 { z-index: 2; }

    video {
      position: absolute;
      top: 0; left: 0;
      width: 100%; height: 100%;
      object-fit: cover;
    }

    /* The slider bars at z-index:100 so they appear above videos & labels */
    .slider-bar {
      position: absolute;
      top: 0;
      width: 4px;
      height: 100%;
      background: #333;
      z-index: 100;
      transform: translateX(-50%);
      pointer-events: none; 
    }

    /*
      Sliders:
      - 3-way has slider-half-left + slider-half-right
      - 2-way has slider-container-2way
      We give them pointer-events: none, but the <input> inside has pointer-events: all
    */
    .slider-half-left,
    .slider-half-right,
    .slider-container-2way {
      position: absolute;
      top: 0; 
      height: 100%;
      pointer-events: none;
    }
    /* 3-way left half => range 0..50 */
    .slider-half-left {
      left: 0; width: 50%;
    }
    /* 3-way right half => range 50..100 */
    .slider-half-right {
      right: 0; width: 50%;
    }
    .slider-half-left input[type="range"],
    .slider-half-right input[type="range"] {
      position: absolute;
      top: 0; left: 0;
      width: 100%; height: 100%;
      opacity: 0;
      pointer-events: all; /* critical: can drag the slider */
      cursor: ew-resize;
    }
    /* 2-way container => single slider spanning entire block */
    .slider-container-2way {
      left: 0; width: 100%;
    }
    .slider-container-2way input[type="range"] {
      position: absolute;
      width: 100%; height: 100%;
      opacity: 0;
      pointer-events: all;
      cursor: ew-resize;
    }

    /********************************************************
     * LABELS inside each container, so they get clipped 
     * with the video. They have pointer-events: none so 
     * they won't block the slider.
    ********************************************************/
    .label3-bg, .label3-mid, .label3-top,
    .label2-bg, .label2-top {
      position: absolute;
      top: 10px;
      padding: 4px 8px;
      border-radius: 4px;
      font-size: 0.9rem;
      font-weight: bold;
      color: #000;
      background: rgba(255,255,255,0.7);
      pointer-events: none; 
    }
    /* 3-way: place them left, center, right to clarify ownership */
    .label3-bg  { left: 10px; }
    .label3-mid { left: 50%; transform: translateX(-50%); }
    .label3-top { right: 10px; }
    /* 2-way: background label left, top label right */
    .label2-bg  { left: 10px; }
    .label2-top { right: 10px; }

    footer {
      text-align: center;
      margin: 20px 0;
      color: #999;
      font-size: 0.8rem;
    }
  </style>
</head>
<body>

  <h1>Frequency-Aware Gaussian Splatting Decomposition</h1>
  <div class="description">
    This showcase presents a visual comparison of our frequency-aware Gaussian splatting decomposition across different aspects. 
    The first row demonstrates how different levels of detail are progressively accumulated in both kitchen and garden scenes. 
    The second row highlights the decomposition into separate frequency bands, revealing the contribution of each level individually. 
    The third row illustrates selective 3D object focus, where different elements in the scene are emphasized based on the rendering prompt. 
    Finally, the fourth row showcases artistic effects applied through our method, introducing stylistic modifications to the original renderings. 
    Users can interact with the sliders to seamlessly transition between different levels and effects for better visualization.
  </div>

  <div class="container">

    <!-- ================= ROW 1: #1 & #2 (3-way LOD) ================= -->
    <div class="compare-row">
      <!-- #1 Kitchen LOD -->
      <div class="compare-block" id="compare3A">
        <div class="block-title">
          Kitchen scene - Level Of Detail
        </div>
        <div class="video-wrapper">
          <!-- BG: L1 -->
          <div class="vid-bg">
            <video src="kitchen_videos/kitchen_lod_1_fixed.mp4" autoplay loop muted></video>
            <div class="label3-bg">L1</div>
          </div>
          <!-- MID: L1+L2 -->
          <div class="vid-mid" id="compare3A_mid">
            <video src="kitchen_videos/kitchen_lod_2_fixed.mp4" autoplay loop muted></video>
            <div class="label3-mid">L1 + L2</div>
          </div>
          <!-- TOP: L1+L2+L3 -->
          <div class="vid-top" id="compare3A_top">
            <video src="kitchen_videos/kitchen_lod_3_fixed.mp4" autoplay loop muted></video>
            <div class="label3-top">L1 + L2 + L3</div>
          </div>
          <!-- Slider bars & inputs -->
          <div class="slider-bar" id="compare3A_bar1"></div>
          <div class="slider-bar" id="compare3A_bar2"></div>
          <div class="slider-half-left">
            <input type="range" id="compare3A_slider1" min="0" max="50" value="25">
          </div>
          <div class="slider-half-right">
            <input type="range" id="compare3A_slider2" min="50" max="100" value="75">
          </div>
        </div>
      </div>

      <!-- #2 Garden LOD -->
      <div class="compare-block" id="compare3B">
        <div class="block-title">
          Garden scene - Level Of Detail
        </div>
        <div class="video-wrapper">
          <div class="vid-bg">
            <video src="garden_videos/garden_lod_1_fixed.mp4" autoplay loop muted></video>
            <div class="label3-bg">L1</div>
          </div>
          <div class="vid-mid" id="compare3B_mid">
            <video src="garden_videos/garden_lod_2_fixed.mp4" autoplay loop muted></video>
            <div class="label3-mid">L1 + L2</div>
          </div>
          <div class="vid-top" id="compare3B_top">
            <video src="garden_videos/garden_lod_3_fixed.mp4" autoplay loop muted></video>
            <div class="label3-top">L1 + L2 + L3</div>
          </div>
          <div class="slider-bar" id="compare3B_bar1"></div>
          <div class="slider-bar" id="compare3B_bar2"></div>
          <div class="slider-half-left">
            <input type="range" id="compare3B_slider1" min="0" max="50" value="25">
          </div>
          <div class="slider-half-right">
            <input type="range" id="compare3B_slider2" min="50" max="100" value="75">
          </div>
        </div>
      </div>
    </div><!-- Row 1 -->

    <!-- ================= ROW 2: #3 & #4 (3-way Laplacian) ================= -->
    <div class="compare-row">
      <!-- #3 Kitchen Laplacian -->
      <div class="compare-block" id="compare3C">
        <div class="block-title">
          Kitchen scene - Laplacian Levels
        </div>
        <div class="video-wrapper">
          <div class="vid-bg">
            <video src="kitchen_videos/kitchen_lod_1_fixed.mp4" autoplay loop muted></video>
            <div class="label3-bg">L1</div>
          </div>
          <div class="vid-mid" id="compare3C_mid">
            <video src="kitchen_videos/kitchen_lap_1_fixed.mp4" autoplay loop muted></video>
            <div class="label3-mid">L2</div>
          </div>
          <div class="vid-top" id="compare3C_top">
            <video src="kitchen_videos/kitchen_lap_2_fixed.mp4" autoplay loop muted></video>
            <div class="label3-top">L3</div>
          </div>
          <div class="slider-bar" id="compare3C_bar1"></div>
          <div class="slider-bar" id="compare3C_bar2"></div>
          <div class="slider-half-left">
            <input type="range" id="compare3C_slider1" min="0" max="50" value="25">
          </div>
          <div class="slider-half-right">
            <input type="range" id="compare3C_slider2" min="50" max="100" value="75">
          </div>
        </div>
      </div>

      <!-- #4 Garden Laplacian -->
      <div class="compare-block" id="compare3D">
        <div class="block-title">
          Garden scene - Laplacian Levels
        </div>
        <div class="video-wrapper">
          <div class="vid-bg">
            <video src="garden_videos/garden_lod_1_fixed.mp4" autoplay loop muted></video>
            <div class="label3-bg">L1</div>
          </div>
          <div class="vid-mid" id="compare3D_mid">
            <video src="garden_videos/garden_lap_1_fixed.mp4" autoplay loop muted></video>
            <div class="label3-mid">L2</div>
          </div>
          <div class="vid-top" id="compare3D_top">
            <video src="garden_videos/garden_lap_2_fixed.mp4" autoplay loop muted></video>
            <div class="label3-top">L3</div>
          </div>
          <div class="slider-bar" id="compare3D_bar1"></div>
          <div class="slider-bar" id="compare3D_bar2"></div>
          <div class="slider-half-left">
            <input type="range" id="compare3D_slider1" min="0" max="50" value="25">
          </div>
          <div class="slider-half-right">
            <input type="range" id="compare3D_slider2" min="50" max="100" value="75">
          </div>
        </div>
      </div>
    </div><!-- Row 2 -->

    <!-- ================= ROW 3: #5 & #6 (2-way) ================= -->
    <div class="compare-row">
      <!-- #5 Kitchen - 3D Object Focus -->
      <div class="compare-block" id="compare2A">
        <div class="block-title">
          Kitchen scene - 3D Object Focus
        </div>
        <div class="video-wrapper">
          <div class="vid-bg2">
            <video src="kitchen_videos/kitchen_desk_mat_focus4_fixed.mp4" autoplay loop muted></video>
            <div class="label2-bg">Desk Mat</div>
          </div>
          <div class="vid-top2" id="compare2A_top">
            <video src="kitchen_videos/kitchen_lego_focus5_fixed.mp4" autoplay loop muted></video>
            <div class="label2-top">Lego</div>
          </div>
          <div class="slider-bar" id="compare2A_bar"></div>
          <div class="slider-container-2way">
            <input type="range" id="compare2A_slider" min="0" max="100" value="50">
          </div>
        </div>
      </div>

      <!-- #6 Garden - 3D Object Focus -->
      <div class="compare-block" id="compare2B">
        <div class="block-title">
          Garden scene - 3D Object Focus
        </div>
        <div class="video-wrapper">
          <div class="vid-bg2">
            <video src="garden_videos/garden_table_focus4_fixed.mp4" autoplay loop muted></video>
            <div class="label2-bg">Wooden Table</div>
          </div>
          <div class="vid-top2" id="compare2B_top">
            <video src="garden_videos/garden_vase_focus_fixed.mp4" autoplay loop muted></video>
            <div class="label2-top">Dried palm leaf arrangement in a round vase</div>
          </div>
          <div class="slider-bar" id="compare2B_bar"></div>
          <div class="slider-container-2way">
            <input type="range" id="compare2B_slider" min="0" max="100" value="50">
          </div>
        </div>
      </div>
    </div><!-- Row 3 -->

    <!-- ================= ROW 4: #7 & #8 (2-way) ================= -->
    <div class="compare-row">
      <!-- #7 Kitchen - Xray Effect -->
      <div class="compare-block" id="compare2C">
        <div class="block-title">
          Kitchen scene - Xray Effect
        </div>
        <div class="video-wrapper">
          <div class="vid-bg2">
            <video src="kitchen_videos/kitchen_lod_3_fixed.mp4" autoplay loop muted></video>
          </div>
          <div class="vid-top2" id="compare2C_top">
            <video src="kitchen_videos/kitchen_xray_effect_fixed.mp4" autoplay loop muted></video>
          </div>
          <div class="slider-bar" id="compare2C_bar"></div>
          <div class="slider-container-2way">
            <input type="range" id="compare2C_slider" min="0" max="100" value="50">
          </div>
        </div>
      </div>

      <!-- #8 Garden - 3D Brush Effect -->
      <div class="compare-block" id="compare2D">
        <div class="block-title">
          Garden scene - Brush Effect
        </div>
        <div class="video-wrapper">
          <div class="vid-bg2">
            <video src="garden_videos/garden_lod_3_fixed.mp4" autoplay loop muted></video>
          </div>
          <div class="vid-top2" id="compare2D_top">
            <video src="garden_videos/garden_brush_effect_fixed.mp4" autoplay loop muted></video>
          </div>
          <div class="slider-bar" id="compare2D_bar"></div>
          <div class="slider-container-2way">
            <input type="range" id="compare2D_slider" min="0" max="100" value="50">
          </div>
        </div>
      </div>
    </div><!-- Row 4 -->

  </div><!-- container -->

  <script>
    /* === 1) TWO-VIDEO COMPARISONS (single slider) === */
    function initTwoVideoCompare(prefix) {
      const slider = document.getElementById(prefix + '_slider');
      const overlayTop = document.getElementById(prefix + '_top');
      const bar = document.getElementById(prefix + '_bar');

      function update() {
        const val = parseInt(slider.value, 10);
        overlayTop.style.clipPath = `inset(0 0 0 ${val}%)`;
        bar.style.left = val + '%';
      }
      slider.addEventListener('input', update);
      update();
    }

    /* === 2) THREE-VIDEO COMPARISONS (two sliders) === */
    function initThreeVideoCompare(prefix) {
      const s1 = document.getElementById(prefix + '_slider1'); 
      const s2 = document.getElementById(prefix + '_slider2'); 
      const mid = document.getElementById(prefix + '_mid');
      const top = document.getElementById(prefix + '_top');
      const bar1 = document.getElementById(prefix + '_bar1');
      const bar2 = document.getElementById(prefix + '_bar2');

      function update() {
        let val1 = parseInt(s1.value, 10);
        let val2 = parseInt(s2.value, 10);
        if (val1 >= val2) {
          val1 = val2 - 1;
          s1.value = val1;
        }
        /* Middle is clipped from val1..val2, top from val2..100 */
        mid.style.clipPath = `inset(0 ${100 - val2}% 0 ${val1}%)`;
        top.style.clipPath = `inset(0 0 0 ${val2}%)`;
        bar1.style.left = val1 + '%';
        bar2.style.left = val2 + '%';
      }
      s1.addEventListener('input', update);
      s2.addEventListener('input', update);
      update();
    }

    /* Initialize all blocks */
    initThreeVideoCompare('compare3A');
    initThreeVideoCompare('compare3B');
    initThreeVideoCompare('compare3C');
    initThreeVideoCompare('compare3D');

    initTwoVideoCompare('compare2A');
    initTwoVideoCompare('compare2B');
    initTwoVideoCompare('compare2C');
    initTwoVideoCompare('compare2D');
  </script>
</body>
</html>
