<!DOCTYPE html>
<html>
  <head>
    <meta charset="utf-8" />
    <meta name="keywords" content="3D inpainting, Empty Street Reconstruction" />
    <meta name="viewport" content="width=device-width, initial-scale=1" />
    <title>
      3D StreetUnveiler with Semantic-Aware 2DGS - a simple baseline
    </title>

    <link
      href="https://fonts.googleapis.com/css?family=Google+Sans|Noto+Sans|Castoro"
      rel="stylesheet"
    />

    <link rel="stylesheet" href="./static/css/bulma.min.css" />
    <link rel="stylesheet" href="./static/css/bulma-carousel.min.css" />
    <link rel="stylesheet" href="./static/css/bulma-slider.min.css" />
    <link rel="stylesheet" href="./static/css/fontawesome.all.min.css" />
    <link
      rel="stylesheet"
      href="https://cdn.jsdelivr.net/gh/jpswalsh/academicons@1/css/academicons.min.css"
    />
    <link rel="stylesheet" href="./static/css/index.css" />


    <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.5.1/jquery.min.js"></script>
    <script defer src="./static/js/fontawesome.all.min.js"></script>
    <script src="./static/js/bulma-carousel.min.js"></script>
    <script src="./static/js/bulma-slider.min.js"></script>


    <link rel="icon" href="data:image/svg+xml,<svg xmlns=%22http://www.w3.org/2000/svg%22 viewBox=%220 0 100 100%22><text y=%22.9em%22 font-size=%2290%22>🛣</text></svg>">

    <link rel="stylesheet" href="./static/css/bootstrap.min.css">
    <link rel="stylesheet" href="./static/css/app.css"/>
    <script src="./static/js/app.js"></script>
    <link rel="stylesheet" href="./static/css/dics.min.css"/>
    <script src="./static/js/dics.min.js"></script>
    <script src="./static/js/video_comparison.js"></script>

    <script>
        document.addEventListener('DOMContentLoaded', domReady);
        function domReady() {
            for (const e of document.querySelectorAll(".b-dics")) {
                new Dics({
                    container: e,
                    textPosition: "top"
                });
            }
        }
    </script>
    <script src="./static/js/index.js"></script>
  </head>

  <style>
    button {
      padding: 0.5em 0.75em;
      margin: 0.4em 0.4em;
      text-align: left;
      background-color: #ddd;
      color: #333;
      border-radius: 5px;
      border: none;
      cursor: pointer;
    
      @media screen and (-ms-high-contrast: active) {
        border: 2px solid currentcolor;
      }
    }
  </style>
  <body>

    <section class="hero">
      <div class="hero-body">
        <div class="container is-max-desktop">
          <div class="columns is-centered">
            <div class="column has-text-centered">
              <h1 class="title is-1 publication-title" style="font-size: 36px">
                  3D StreetUnveiler with Semantic-Aware 2DGS - a simple baseline
              </h1>
            </div>
          </div>
        </div>
      </div>
    </section>

    <section class="hero teaser">
      <div class="container is-max-desktop">
        <div class="hero-body">
          <img src="static/images/teaser.png" alt="StreetUnveiler" />
          <h2 class="subtitle has-text-centered" style="font-size: 16px">
            <b>StreetUnveiler</b>: We achieve accurate empty street reconstruction from in-car camera videos. With the aid of the proposed hard-label semantic 2D Gaussian Splatting and time-reversal inpainting framework, we remove the unwanted objects with satisfactory appearance and geometry of occluded regions. </h2>
        </div>
      </div>
    </section>


    <section class="section">


      <div class="columns is-centered has-text-centered" id="video">
        <div class="column is-four-fifths">
          <h2 class="title is-2">Main Experiment Comparison</h2>
          <h3> Select which methods to compare.</h3>
          <button id="Data">Training Data</button>
          <button id="LaMa">LaMa</button>
          <button id="SDXL">SDXL</button>
          <button id="ProPainter">ProPainter</button>
          <button id="SPIn-NeRF">SPIn-NeRF(in 2DGS)</button>
          <button id="Infusion">Infusion</button>
          <h4 >(Please refresh if you don't see the video. Switch video will need some time to process.)</h4>
          <h3 id="compareText">
            Training Data
            &nbsp;&nbsp; 
            VS
            &nbsp;&nbsp;
            Ours
          </h3>
          <video class="video" width=100% id="xyalias" loop playsinline autoplay muted src="./static/videos/Experiment/scene1/data_vs_ours.mp4" onplay="resizeAndPlay(this)"></video>
          <canvas height=0 class="videoMerge" id="xyaliasMerge"></canvas>

          <br>
          <button id="Scene1">Scene1</button>
          <button id="Scene2">Scene2</button>
          <button id="Scene3">Scene3</button>
          <br>
          <h4> (Click here to switch the scene)</h>

        </div>
      </div>

      <section class="section">
        <div class="columns is-centered has-text-centered" id="video">
          <div class="column is-four-fifths">
            <h2 class="title is-2">Novel View Synthesis</h2>
            <h4 >(Please refresh if you don't see the video. Switch video will need some time to process.)</h4>
            <video id="original", controls>
              <source src="./static/videos/NVS/nvs2.mp4" type="video/mp4">
              Your browser does not support the video tag.
            </video>
            <br>
            <button id="NVSScene1">Scene1</button>
            <button id="NVSScene2">Scene2</button>
            <br>
            <h4> (Click here to switch the scene)</h>
          </div>
        </div>

      <script>
        let sceneNumber = 1;
        let lastFile = 'data_vs_ours.mp4';
        let lastText = 'Training Data';
        const video = document.getElementById('xyalias');
        const buttonData = document.getElementById('Data');
        const buttonLaMa = document.getElementById('LaMa');
        const buttonSDXL = document.getElementById('SDXL');
        const buttonProPainter = document.getElementById('ProPainter');
        const buttonSPIn = document.getElementById('SPIn-NeRF');
        const buttonInfusion = document.getElementById('Infusion');

        const text = document.getElementById('compareText');
        const pathText = document.getElementById('pathText');

        const updateVideoSource = (source, name) => {
          video.src = `./static/videos/Experiment/scene${sceneNumber}/${source}`;
          text.innerHTML = `${name}&nbsp;&nbsp;VS&nbsp;&nbsp;Ours`;
          lastFile = source;
          lastText = name;
        };


        document.getElementById('Data').addEventListener('click', () => {
          updateVideoSource('data_vs_ours.mp4', 'Training Data');
        });

        document.getElementById('LaMa').addEventListener('click', () => {
          updateVideoSource('lama_vs_ours.mp4', 'LaMa');
        });

        document.getElementById('SDXL').addEventListener('click', () => {
          updateVideoSource('sdxl_vs_ours.mp4', 'SDXL');
        });

        document.getElementById('ProPainter').addEventListener('click', () => {
          updateVideoSource('propainter_vs_ours.mp4', 'ProPainter');
        });

        document.getElementById('SPIn-NeRF').addEventListener('click', () => {
          updateVideoSource('spin_vs_ours.mp4', 'SPIn-NeRF(in 2DGS)');
        });

        document.getElementById('Infusion').addEventListener('click', () => {
          updateVideoSource('infusion_vs_ours.mp4', 'Infusion');
        });

        document.getElementById('Scene1').addEventListener('click', () => {
          sceneNumber = 1; 
          updateVideoSource(lastFile, lastText)
        });

        document.getElementById('Scene2').addEventListener('click', () => {
          sceneNumber = 2; 
          updateVideoSource(lastFile, lastText)
        });

        document.getElementById('Scene3').addEventListener('click', () => {
          sceneNumber = 3; 
          updateVideoSource(lastFile, lastText)
        });
  

        let sceneNumberNVS = 2;
        const original_video = document.getElementById('original');

        const updateNVSVideoSource = () => {
            original_video.src = `./static/videos/NVS/nvs${sceneNumberNVS}.mp4`;
            pathText.innerHTML = `File path: <strong>"../videos/NVS/nvs${sceneNumberNVS}.mp4"</strong>`;
        };

        document.getElementById('NVSScene1').addEventListener('click', () => {
          sceneNumberNVS = 2; 
          updateNVSVideoSource()
        });

        document.getElementById('NVSScene2').addEventListener('click', () => {
          sceneNumberNVS = 1; 
          updateNVSVideoSource()
        });

  
        </script>
    </section>

   

    <script>
      bulmaCarousel.attach("#geo-carousel", {
        slidesToScroll: 1,
        slidesToShow: 1,
        infinite: true,
      });
      bulmaCarousel.attach("#novel-carousel", {
        slidesToScroll: 1,
        slidesToShow: 2,
        infinite: true,
      });
      bulmaCarousel.attach("#edit-carousel", {
        slidesToScroll: 1,
        slidesToShow: 2,
        infinite: true,
      });
    </script>
  </body>
</html>
