<!DOCTYPE html>
<html>

<head>

  <meta name="viewport" content="width=device-width, initial-scale=1, minimum-scale=1" />

  <title>Toon3D</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="https://cdn.jsdelivr.net/gh/jpswalsh/academicons@1/css/academicons.min.css">
  <link rel="stylesheet" href="./static/css/index.css">
  <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>">

  <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>
  <script src="./static/js/index.js"></script>
</head>

<body>

  <nav class="navbar" role="navigation" aria-label="main navigation">
    <div class="navbar-brand">
      <a role="button" class="navbar-burger" aria-label="menu" aria-expanded="false">
        <span aria-hidden="true"></span>
        <span aria-hidden="true"></span>
        <span aria-hidden="true"></span>
      </a>
    </div>
  </nav>


  <section class="hero">
    <div class="hero-body">
      <div class="container is-max-widescreen">
        <div class="columns is-centered">
          <div class="column has-text-centered">
            <h1 class="title is-1 publication-title" style="font-family: Marker Felt; font-weight: bold">Supplementary Material for<br>Toon3D: Seeing
              Cartoons from New Perspectives</h1>

            <div class="column has-text-centered">
              <div class="publication-links">
                <span class="link-block">
                  <a href="Toon3D-supplement.pdf" class="external-link button is-normal is-rounded is-dark">
                    <span class="icon">
                      <i class="fa fa-file-pdf"></i>
                    </span>
                    <span>Supplemental PDF</span>
                  </a>
                </span>
                <!-- Toon3D Overview Video. -->
                <span class="link-block">
                  <a href="./static/assets/Toon3D-video.mp4" class="external-link button is-normal is-rounded is-dark">
                    <span class="icon">
                      <i class="fab fa-youtube"></i>
                    </span>
                    <span>Overview Video</span>
                  </a>
                </span>
              </div>
            </div>
          </div>
        </div>
      </div>
    </div>
  </section>

  <section class="hero">
    <div class="hero-body">
      <div class="container is-max-widescreen">
        <div class="columns is-centered">
          <div class="column has-text-centered">
            <h2 class="subtitle has-text-centered">
              <i>Humans can perceive 3D world from images that aren't 3D consistent, but machines cannot. Let's fix
                this!</i><br><br>COLMAP fails to reconstruct non-geometric hand-drawn images, even with perfect
              correspondences! Other methods, including Bundle Adjustment and DUSt3R, perform very badly. We compare
              with these baselines both qualitatively and quantitatiely, and we find our method to be superior. Please
              watch the video to understand our problem setting and read the paper for more details! We also include
              an ablation study in the paper to provide insights about our method.
            </h2>
            <h2 class="subtitle has-text-centered">Framework Overview</h2>
            <img src="static/images/teaser.png" style="height: auto;">
          </div>
        </div>
      </div>
    </div>
  </section>


  <section class="hero is-light">
    <div class="hero-body">
      <div class="container is-max-widescreen">
        <div class="content has-text-centered">
          <p style="text-align: center">
            <!-- We run <span class="my-method-name">Toon3D</span> on 12 popular cartoon scenes. -->
            <!-- We
            align backprojected monocular depth predictions with a piecewise-rigid deformation at 3D keypoints. We refine
            the aligned
            point clouds with Gaussian optimization. These scenes have sparse viewpoints as input,
            ranging from only 4 to as many as 12 hand-drawn images. Press the button to move the cameras between two
            viewpoints! -->
            Hand-drawn scenes are not 3D consistent, so we create <span class="my-method-name">Toon3D</span> to recover
            camera poses and dense geometry! We do this with a piecewise-rigid deformation optimization at hand-labeled
            keypoints and guide the process with structure inferred from monocular depth predictions. Now we can
            interpolate novel views never before seen! Press
            the button to move the cameras between two
            viewpoints! <i>Note that we reconstruct the scenes with more than two hand-drawn images, but this demo shows
              a smooth transition between just two of the inputs views.</i>
          </p>
          <button id="playAllVideos" class="button is-info is-rounded">Move Cameras</button>
        </div>
        <div id="results-carousel" class="carousel_teaser results-carousel">
          <div class="item">
            <div class="teaser-video-container">
              <video poster="" controls muted playsinline height="100%">
                <source src="./static/assets/interpolated-0-5-mystery-machine-loop.mp4" type="video/mp4">
              </video>
            </div>
            <br>
            <div class="teaser-video-container">
              <video poster="" controls muted playsinline height="100%">
                <source src="./static/assets/interpolated-0-6-bobs-burgers-loop.mp4" type="video/mp4">
              </video>
            </div>
          </div>
          <div class="item">
            <div class="teaser-video-container">
              <video poster="" controls muted playsinline height="100%">
                <source src="./static/assets/interpolated-0-2-smith-residence-loop.mp4" type="video/mp4">
              </video>
            </div>
            <br>
            <div class="teaser-video-container">
              <video poster="" controls muted playsinline height="100%">
                <source src="./static/assets/interpolated-1-5-krusty-krab-loop.mp4" type="video/mp4">
              </video>
            </div>
          </div>
          <div class="item">
            <div class="teaser-video-container">
              <video poster="" controls muted playsinline height="100%">
                <source src="./static/assets/interpolated-3-4-family-guy-dining-loop.mp4" type="video/mp4">
              </video>
            </div>
            <br>
            <div class="teaser-video-container">
              <video poster="" controls muted playsinline height="100%">
                <source src="./static/assets/interpolated-2-4-spirited-away-loop.mp4" type="video/mp4">
              </video>
            </div>
          </div>
          <div class="item">
            <div class="teaser-video-container">
              <video poster="" controls muted playsinline height="100%">
                <source src="./static/assets/interpolated-1-3-family-guy-house-loop.mp4" type="video/mp4">
              </video>
            </div>
            <br>
            <div class="teaser-video-container">
              <video poster="" controls muted playsinline height="100%">
                <source src="./static/assets/interpolated-1-7-avatar-house-loop.mp4" type="video/mp4">
              </video>
            </div>
          </div>
          <div class="item">
            <div class="teaser-video-container">
              <video poster="" controls muted playsinline height="100%">
                <source src="./static/assets/interpolated-2-3-magic-school-bus-loop.mp4" type="video/mp4">
              </video>
            </div>
            <br>
            <div class="teaser-video-container">
              <video poster="" controls muted playsinline height="100%">
                <source src="./static/assets/interpolated-4-9-bojack-room-loop.mp4" type="video/mp4">
              </video>
            </div>
          </div>
          <div class="item">
            <div class="teaser-video-container">
              <video poster="" controls muted playsinline height="100%">
                <source src="./static/assets/interpolated-2-4-simpsons-house-loop.mp4" type="video/mp4">
              </video>
            </div>
            <br>
            <div class="teaser-video-container">
              <video poster="" controls muted playsinline height="100%">
                <source src="./static/assets/interpolated-1-3-planet-express-loop.mp4" type="video/mp4">
              </video>
            </div>
          </div>
        </div>
      </div>
    </div>
  </section>
  <script>
    $(document).ready(function () {
      // When the "Play All Videos" button is clicked
      $('#playAllVideos').click(function () {
        // Find all video elements within the teaser-video-container and play them
        $('.teaser-video-container video').each(function () {
          this.play();
        });
      });
    });
  </script>


  <section class="section">
    <div class="container is-max-widescreen">
      <!-- Abstract. -->
      <div class="columns is-centered has-text-centered">
        <div class="column is-full-width">
          <h2 class="title is-3">Abstract</h2>
          <div class="content has-text-justified">
            <p>
              <!-- We propose <span class="my-method-name">Toon3D</span>. In this work, we recover the underlying 3D
              structure of non-geometrically consistent scenes. We focus our analysis on hand-drawn images from cartoons
              and anime. Many cartoons are created by artists without a 3D rendering engine, which means that any new
              image of a scene is hand-drawn. The hand-drawn images are usually faithful representations of the world,
              but only in a qualitative sense, since it is difficult for humans to draw multiple perspectives of an
              object or scene 3D consistently. Nevertheless, people can easily perceive 3D scenes from inconsistent
              inputs! In this work, we correct for 2D drawing inconsistencies to recover a plausible 3D structure such
              that the newly warped drawings are consistent with each other. Our pipeline consists of a user-friendly
              annotation tool, camera pose estimation, and image deformation to recover a dense structure. Our method
              warps images to obey a perspective camera model, enabling our aligned results to be plugged into
              novel-view synthesis reconstruction methods to experience cartoons from viewpoints never drawn before. -->
              We recover the underlying 3D structure from images of cartoons and anime depicting the same scene. This is
              an interesting problem domain because images in creative media are often depicted without explicit
              geometric consistency for storytelling and creative expression—they are only 3D in a qualitative sense.
              While humans can easily perceive the underlying 3D scene from these images, existing Structure-from-Motion
              (SfM) methods that assume 3D consistency fail catastrophically. We present <span
                class="my-method-name">Toon3D</span> for reconstructing geometrically inconsistent images. Our key
              insight is to deform the input images while recovering camera poses and scene geometry, effectively
              explaining away geometrical inconsistencies to achieve consistency. This process is guided by the
              structure inferred from monocular depth predictions. We curate a dataset with multi-view imagery from
              cartoons and anime that we annotate with reliable sparse correspondences using our user-friendly
              annotation tool. Our recovered point clouds can be plugged into novel-view synthesis methods to experience
              cartoons from viewpoints never drawn before. We evaluate against classical and recent learning-based SfM
              methods, where <span class="my-method-name">Toon3D</span> is able to obtain more reliable camera poses and
              scene geometry.
            </p>
          </div>
        </div>
      </div>
      <!--/ Abstract. -->
    </div>
  </section>

  <section class="section">
    <div class="container is-max-widescreen">
      <!-- Abstract. -->
      <div class="columns is-centered has-text-centered">
        <div class="column is-full-width">
          <h2 class="title is-3">Cartoon Reconstruction</h2>
          <div class="content has-text-centered">
            <p>
              (Left) We first recover camera poses and aligned point clouds. (Right) Then we initialize Gaussians from
              our dense point
              cloud and optimize Gaussian Splatting with the recovered
              cameras. Our method has depth regularization and is built on <a
                href="https://docs.nerf.studio/">Nerfstudio</a>. Here we show fly-through renders of our scenes.
          </div>
          <video poster="" autoplay controls muted loop playsinline height="100%">
            <source src="./static/assets/bobs-burgers-side-by-side.mp4" type="video/mp4">
          </video>
        </div>
      </div>
      <div class="container">
        <div class="content has-text-centered">
          <p>Here is the gallery of all our scenes. Can you guess which is which? Click to reveal names.</p>
          <button class="button is-info is-rounded" onclick="toggleCartoonNames()">Toggle Cartoon Names</button>
        </div>
        <div id="results-carousel" class="carousel_splats results-carousel">
          <div class="item">
            <h4 class="title is-4 has-text-centered cartoon-name is-hidden" style="margin-bottom: 4px;">Bob's Burgers
            </h4>
            <video poster="" autoplay controls muted loop playsinline height="100%">
              <source src="./static/assets/bobs-burgers.mp4" type="video/mp4">
            </video>
            <h4 class="title is-4 has-text-centered cartoon-name is-hidden" style="margin-bottom: 4px;">Family Guy</h4>
            <video poster="" autoplay controls muted loop playsinline height="100%">
              <source src="./static/assets/family-guy-house.mp4" type="video/mp4">
            </video>
          </div>
          <div class="item">
            <h4 class="title is-4 has-text-centered cartoon-name is-hidden" style="margin-bottom: 4px;">SpongeBob
              SquarePants</h4>
            <video poster="" autoplay controls muted loop playsinline height="100%">
              <source src="./static/assets/krusty-krab.mp4" type="video/mp4">
            </video>
            <br>
            <h4 class="title is-4 has-text-centered cartoon-name is-hidden" style="margin-bottom: 4px;">Rick and Morty
            </h4>
            <video poster="" autoplay controls muted loop playsinline height="100%">
              <source src="./static/assets/smith-residence.mp4" type="video/mp4">
            </video>
          </div>
          <div class="item">
            <h4 class="title is-4 has-text-centered cartoon-name is-hidden" style="margin-bottom: 4px;">Simpsons</h4>
            <video poster="" autoplay controls muted loop playsinline height="100%">
              <source src="./static/assets/simpsons-house.mp4" type="video/mp4">
            </video>
            <br>
            <h4 class="title is-4 has-text-centered cartoon-name is-hidden" style="margin-bottom: 4px;">Spirited Away
            </h4>
            <video poster="" autoplay controls muted loop playsinline height="100%">
              <source src="./static/assets/spirited-away.mp4" type="video/mp4">
            </video>
          </div>
          <div class="item">
            <h4 class="title is-4 has-text-centered cartoon-name is-hidden" style="margin-bottom: 4px;">Futurama</h4>
            <video poster="" autoplay controls muted loop playsinline height="100%">
              <source src="./static/assets/planet-express.mp4" type="video/mp4">
            </video>
            <br>
            <h4 class="title is-4 has-text-centered cartoon-name is-hidden" style="margin-bottom: 4px;">Family Guy</h4>
            <video poster="" autoplay controls muted loop playsinline height="100%">
              <source src="./static/assets/family-guy-dining.mp4" type="video/mp4">
            </video>
          </div>
          <div class="item">
            <h4 class="title is-4 has-text-centered cartoon-name is-hidden" style="margin-bottom: 4px;">Avatar</h4>
            <video poster="" autoplay controls muted loop playsinline height="100%">
              <source src="./static/assets/avatar-house.mp4" type="video/mp4">
            </video>
            <br>
            <h4 class="title is-4 has-text-centered cartoon-name is-hidden" style="margin-bottom: 4px;">BoJack Horseman
            </h4>
            <video poster="" autoplay controls muted loop playsinline height="100%">
              <source src="./static/assets/bojack-room.mp4" type="video/mp4">
            </video>
          </div>
          <div class="item">
            <h4 class="title is-4 has-text-centered cartoon-name is-hidden" style="margin-bottom: 4px;">Magic School Bus
            </h4>
            <video poster="" autoplay controls muted loop playsinline height="100%">
              <source src="./static/assets/magic-school-bus.mp4" type="video/mp4">
            </video>
            <br>
            <h4 class="title is-4 has-text-centered cartoon-name is-hidden" style="margin-bottom: 4px;">Scooby-Doo</h4>
            <video poster="" autoplay controls muted loop playsinline height="100%">
              <source src="./static/assets/mystery-machine.mp4" type="video/mp4">
            </video>
          </div>
        </div>
      </div>
    </div>
    <script>
      function toggleCartoonNames() {
        // Select all elements with the class 'cartoon-name'
        var names = document.querySelectorAll('.cartoon-name');

        // Toggle the 'is-hidden' class for each element
        names.forEach(function (name) {
          name.classList.toggle('is-hidden');
        });
      }
    </script>

  </section>

  <section class="section">
    <div class="container is-max-widescreen">
      <div class="columns is-centered has-text-centered">
        <div class="column is-full-width">
          <h2 class="title is-3">Method</h2>
          <div class="content has-text-justified">
            <p>
              We first predict the depth of each image with <a href="https://github.com/prs-eth/Marigold">Marigold</a>
              and obtain candidate transient masks with <a href="https://segment-anything.com/">SAM</a>. We then label
              images with the <span class="my-method-name">Toon3D Labeler
                Labeler</span> to obtain correspondences and mark transient regions. We optimize camera poses and warp
              images to obtain calibrated, perspective cameras. Finally, we can initialize Gaussians with the aligned
              dense point cloud and run refinement.
            </p>
          </div>
        </div>
      </div>
      <div class="columns">
        <div class="column is-half">
          <h4 class="title is-4 has-text-centered">Overview</h4>
          <div class="hero-body">
            <div class="container" style="display: flex;">
              <img src="static/images/method.png" style="height: auto;">
            </div>
          </div>
        </div>
        <div class="column is-half">
          <h4 class="title is-4 has-text-centered my-method-name"><a href="https://labeler.toon3d.studio/">Toon3D
              Labeler</a></h4>
          <div class="method-video">
            <video id="sparse-alignment-video" controls autoplay muted loop playsinline width="100%">
              <source src="./static/assets/toon3d-labeler.mp4" type="video/mp4">
            </video>
          </div>
        </div>
      </div>
      <div class="content has-text-centered" style="margin-bottom: 10px;">
        <p>Here you can see the two major objectives of our method. The camera alignment objective recovers camera
          parameter. The deformation alignment objective warps the meshes for closer alignment. In practice, we optimize
          for both objectives at the same time. In the Deformation Alignment video, we show various layers used in the
          method (e.g., cameras, sparse
          correspondences, warping meshes, point clouds, and gaussians) and observe their alignment in 3D.</p>
      </div>
      <!-- Columns container -->
      <div class="columns">
        <div class="column is-half">
          <h4 class="title is-4 has-text-centered">Camera Alignment</h4>
          <div class="method-video">
            <video id="sparse-alignment-video" controls autoplay muted loop playsinline width="100%">
              <source src="./static/assets/sparse-alignment.mp4" type="video/mp4">
            </video>
          </div>
        </div>
        <div class="column is-half">
          <h4 class="title is-4 has-text-centered">Deformation Alignment</h4>
          <div class="method-video">
            <video id="sparse-alignment-video" controls autoplay muted loop playsinline width="100%">
              <source src="./static/assets/dense-alignment.mp4" type="video/mp4">
            </video>
          </div>
        </div>
      </div>
    </div>
  </section>


  <section class="section">
    <div class="container is-max-widescreen">
      <div class="columns is-centered has-text-centered">
        <div class="column is-full-width">
          <h2 class="title is-3">Explore Inside Rick and Morty's House</h2>
          <div class="content has-text-centered" style="margin-bottom: 10px;">
            <p>We reconstruct inside the Rick and Morty house by labeling between walls and ceilings to connect the
              rooms. In the first video, we show the point cloud & cameras and our custom labeling interface. In the
              second video, you can scrub the slider to
              see a walkthrough inside the house! The closest camera's image is shown in the bottom right corner.</p>
          </div>
          <!-- Columns container -->
          <div class="columns">
            <div class="column is-half">
              <video id="labeling-rick-and-morty-video" controls autoplay muted loop playsinline width="100%">
                <source src="./static/assets/labeling-rick-and-morty.mp4" type="video/mp4">
              </video>
            </div>
            <div class="column is-half">
              <input type="range" id="video-scrubber" min="0" value="0" step="1" style="width: 100%;">
              <video id="rick-and-morty-video" autoplay muted loop playsinline width="100%">
                <source src="./static/assets/rick-and-morty.mp4" type="video/mp4">
              </video>
            </div>
          </div>
        </div>
      </div>
    </div>

    <script>
      document.addEventListener('DOMContentLoaded', function () {
        var video = document.getElementById('rick-and-morty-video');
        var scrubber = document.getElementById('video-scrubber');
        var wasPlaying = false; // Track whether the video was playing before scrubbing started

        video.addEventListener('loadedmetadata', function () {
          scrubber.max = video.duration;
        });

        scrubber.addEventListener('input', function () {
          video.currentTime = this.value;
        });

        video.addEventListener('timeupdate', function () {
          scrubber.value = video.currentTime;
        });

        // When user starts scrubbing, pause the video if it was playing
        scrubber.addEventListener('mousedown', function () {
          if (!video.paused) {
            video.pause();
            wasPlaying = true;
          }
        });

        // When user stops scrubbing, resume playing the video if it was playing before
        scrubber.addEventListener('mouseup', function () {
          if (wasPlaying) {
            video.play();
            wasPlaying = false; // Reset the flag
          }
        });

        // Optionally, for touch screens, you may want to handle touchstart and touchend
        scrubber.addEventListener('touchstart', function () {
          if (!video.paused) {
            video.pause();
            wasPlaying = true;
          }
        });

        scrubber.addEventListener('touchend', function () {
          if (wasPlaying) {
            video.play();
            wasPlaying = false; // Reset the flag
          }
        });
      });
    </script>

  </section>

  <section class="section">
    <div class="container is-max-widescreen">
      <div class="columns is-centered has-text-centered">
        <div class="column is-full-width">
          <h2 class="title is-3">Point Clouds and Cameras</h2>
          <div class="content has-text-centered">
            <p>
              Here we show point clouds and recovered cameras for the 12 cartoon scenes in the <span
                class="my-method-name">Toon3D Dataset</span>. Click the icons to explore our scenes!
            </p>
          </div>
        </div>
      </div>
      <div class="container is-max-widescreen">
        <div class="columns is-centered has-text-centered">
          <div class="column is-full-width">

            <div id="iframe-container">
              Click a scene icon to start!
            </div>

            <div class="control-buttons" style="display: none;">
              <button id="point-cloud-name" class="button is-info is-outlined" style="color: black;" disabled>Point
                cloud
                name</button>
              <button class="button is-info is-rounded" id="full-screen-button" onclick="fullscreen()">Fullscreen
                👐</button>
            </div>
            <script>
              // Create a function to open the iframe in fullscreen in a new tab
              function fullscreen() {
                var elem = document.getElementById('iframe-container').querySelector('iframe');
                window.open(elem.src, '_blank');
              }
            </script>

            <script>
              document.addEventListener('DOMContentLoaded', function () {
                function createAndDisplayIframe(iframeId, iframeSrc) {
                  let existingIframe = document.getElementById(iframeId);

                  // Hide all iframes first
                  document.querySelectorAll('.iframe').forEach(iframe => iframe.style.display = 'none');

                  if (!existingIframe) {
                    // If iframe does not exist, create and append it
                    const iframe = document.createElement('iframe');
                    iframe.id = iframeId;
                    iframe.src = iframeSrc;
                    iframe.style.display = 'block'; // Show the new iframe
                    iframe.setAttribute('class', 'iframe');
                    document.getElementById('iframe-container').innerHTML = ''; // Clear the container
                    document.getElementById('iframe-container').appendChild(iframe);
                  } else {
                    // If iframe exists, just display it
                    existingIframe.style.display = 'block';
                  }
                }

                // Event listener for thumbnail buttons
                document.querySelectorAll('.thumbnail-btn').forEach(button => {
                  button.addEventListener('click', () => {
                    const iframeId = button.getAttribute('data-iframe-id');
                    const iframeSrc = button.getAttribute('data-iframe-src');
                    createAndDisplayIframe(iframeId, iframeSrc);

                    // show control buttons
                    document.querySelector('.control-buttons').style.display = 'block';

                    // set the point cloud name to the button's alt text
                    document.getElementById('point-cloud-name').innerText = button.querySelector('img').alt;

                    // set the button to have the active class
                    document.querySelectorAll('.thumbnail-btn').forEach(btn => btn.classList.remove('is-active'));
                    button.classList.add('is-active');
                  });
                });
              });
            </script>

            <div class="thumbnails">
              <button class="thumbnail-btn" data-iframe-id="basingse-house"
                data-iframe-src="https://toonthree.github.io/viser-embed/?playbackPath=https://toonthree.github.io/viser-embed/toon3d/basingse-house.viser">
                <img src="./static/assets/thumbnails/basingse-house.png" alt="Ba Sing Se House" />
              </button>
              <button class="thumbnail-btn" data-iframe-id="bobs-burgers-dining"
                data-iframe-src="https://toonthree.github.io/viser-embed/?playbackPath=https://toonthree.github.io/viser-embed/toon3d/bobs-burgers-dining.viser">
                <img src="./static/assets/thumbnails/bobs-burgers-dining.jpeg" alt="Bob's Burgers" />
              </button>
              <button class="thumbnail-btn" data-iframe-id="bojak-inside"
                data-iframe-src="https://toonthree.github.io/viser-embed/?playbackPath=https://toonthree.github.io/viser-embed/toon3d/bojak-inside.viser">
                <img src="./static/assets/thumbnails/bojack-house.jpeg" alt="BoJack Room" />
              </button>
              <button class="thumbnail-btn" data-iframe-id="family-guy-dining"
                data-iframe-src="https://toonthree.github.io/viser-embed/?playbackPath=https://toonthree.github.io/viser-embed/toon3d/family-guy-dining.viser">
                <img src="./static/assets/thumbnails/family-guy-dining.jpg" alt="Family Guy Dining" />
              </button>
              <button class="thumbnail-btn" data-iframe-id="family-guy-house"
                data-iframe-src="https://toonthree.github.io/viser-embed/?playbackPath=https://toonthree.github.io/viser-embed/toon3d/family-guy-house.viser">
                <img src="./static/assets/thumbnails/family-guy-house.jpeg" alt="Family Guy House" />
              </button>
              <button class="thumbnail-btn" data-iframe-id="krusty-krab-inside"
                data-iframe-src="https://toonthree.github.io/viser-embed/?playbackPath=https://toonthree.github.io/viser-embed/toon3d/krusty-krab-inside.viser">
                <img src="./static/assets/thumbnails/krusty-krab-inside.jpeg" alt="Krusty Krab" />
              </button>
              <button class="thumbnail-btn" data-iframe-id="magic-school-bus"
                data-iframe-src="https://toonthree.github.io/viser-embed/?playbackPath=https://toonthree.github.io/viser-embed/toon3d/magic-school-bus.viser">
                <img src="./static/assets/thumbnails/magic-school-bus.jpeg" alt="Magic School Bus" />
              </button>
              <button class="thumbnail-btn" data-iframe-id="mystery-machine"
                data-iframe-src="https://toonthree.github.io/viser-embed/?playbackPath=https://toonthree.github.io/viser-embed/toon3d/mystery-machine.viser">
                <img src="./static/assets/thumbnails/mystery-machine.jpeg" alt="Mystery Machine" />
              </button>
              <button class="thumbnail-btn" data-iframe-id="planet-express"
                data-iframe-src="https://toonthree.github.io/viser-embed/?playbackPath=https://toonthree.github.io/viser-embed/toon3d/planet-express.viser">
                <img src="./static/assets/thumbnails/planet-express.jpeg" alt="Planet Express" />
              </button>
              <button class="thumbnail-btn" data-iframe-id="simpsons-house"
                data-iframe-src="https://toonthree.github.io/viser-embed/?playbackPath=https://toonthree.github.io/viser-embed/toon3d/simpsons-house.viser">
                <img src="./static/assets/thumbnails/simpsons-house.jpg" alt="The Simpsons' House" />
              </button>
              <button class="thumbnail-btn" data-iframe-id="smith-residence"
                data-iframe-src="https://toonthree.github.io/viser-embed/?playbackPath=https://toonthree.github.io/viser-embed/toon3d/smith-residence.viser">
                <img src="./static/assets/thumbnails/smith-residence.jpeg" alt="Smith Residence" />
              </button>
              <button class="thumbnail-btn" data-iframe-id="spirited-away-train"
                data-iframe-src="https://toonthree.github.io/viser-embed/?playbackPath=https://toonthree.github.io/viser-embed/toon3d/spirited-away-train.viser">
                <img src="./static/assets/thumbnails/spirited-away.jpeg" alt="Spirited Away" />
              </button>
            </div>

          </div>
        </div>
      </div>
    </div>
  </section>


  <section class="section">
    <div class="container is-max-widescreen">
      <div class="columns is-centered has-text-centered">
        <div class="column is-full-width">
          <h2 class="title is-3">Sparse-View Reconstruction</h2>
          <div class="content has-text-centered">
            <p>
              We can reconstruct scenes from few images and with large
              viewpoint changes. Where COLMAP may fail, we can intervene with the <span class="my-method-name">Toon3D
                Labeler</span> to obtain human-labeled correspondences. Here we show a
              fly-through rendering for two rooms ("Living room" and "Bedroom 2") of <a
                href="https://www.airbnb.com/rooms/833261990707199349">this Airbnb listing</a>.
            </p>
          </div>
        </div>
      </div>
      <div class="hero-body">
        <h2 class="subtitle has-text-centered">
          COLMAP fails badly and is unable to recover all the cameras. Our labels can make COLMAP succeed, but our
          Toon3D method performs the best at completing the scenes. Please see the paper for more details.
        </h2>
        <img src="static/assets/airbnb.jpg" style="height: auto;">
      </div>
      <div class="hero-body">
        <h2 class="subtitle has-text-centered">Here are our video results of Toon3D on two Airbnb rooms.</h2>
        <div class="container is-max-widescreen">
          <div id="blender-carousel" class="carousel1 results-carousel">
            <div class="item">
              <video poster="" autoplay controls muted loop playsinline height="100%">
                <source src="./static/assets/Living-room.mp4" type="video/mp4">
              </video>
            </div>
            <div class="item">
              <video poster="" autoplay controls muted loop playsinline height="100%">
                <source src="./static/assets/Bedroom-2.mp4" type="video/mp4">
              </video>
            </div>
          </div>
        </div>
      </div>
    </div>
  </section>

  <section class="section">
    <div class="container is-max-widescreen">
      <div class="columns is-centered has-text-centered">
        <div class="column is-full-width">
          <h2 class="title is-3">Visualizing Inconsistencies</h2>
          <div class="content has-text-centered">
            <p>
              Cartoons are hand-drawn so we need to warp the images to be 3D consistent. The first item is a video that
              shows the warp taking place during alignment optimization.
              The next two items are images which show the original and warped drawings, as well as the overlap between
              the two. Blurry
              regions indicate where a lot of warp occured.
            </p>
          </div>
        </div>
      </div>
      <div class="hero-body">
        <div class="container is-max-widescreen">
          <div id="blender-carousel" class="carousel2 results-carousel">
            <div class="item">
              <h4 class="title is-4 has-text-centered">Video</h4>
              <video poster="" autoplay controls muted loop playsinline height="100%">
                <source src="./static/assets/visualizing-inconsistencies-3.mp4" type="video/mp4">
              </video>
            </div>
            <div class="item">
              <h4 class="title is-4 has-text-centered">Image</h4>
              <img src="./static/assets/visualizing-inconsistencies-1.png" style="height: auto;">
            </div>
            <div class="item">
              <h4 class="title is-4 has-text-centered">Image</h4>
              <img src="./static/assets/visualizing-inconsistencies-2.png" style="height: auto;">
            </div>
          </div>
        </div>
      </div>
    </div>
  </section>

  <!-- Multi-View Consistent Inpainting. -->
  <section class="section">
    <div class="container is-max-widescreen">
      <!-- Abstract. -->
      <div class="columns is-centered has-text-centered">
        <div class="column is-full-width">
          <h2 class="title is-3">Reconstructing Paintings</h2>
          <div class="content has-text-justified">
            <p>
              We can reconstruct paintings with <span class="my-method-name">Toon3D</span> even though the paintings are
              hand-drawn. We predict the depth of each image, then align and warp point clouds. Finally we use Gaussian
              refinement to create the video shown below.
            </p>
          </div>
        </div>
      </div>
      <div class="hero-body">
        <div class="container is-max-widescreen">
          <video poster="" id="chair-tp" autoplay controls muted loop playsinline height="100%">
            <source src="./static/assets/reconstructing-paintings.mp4" type="video/mp4">
          </video>
        </div>
      </div>
    </div>
  </section>
  <!--/ Multi-View Consistent Inpainting. -->

</body>

</html>