<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
  <meta name="description"
        content="A diffusion model learned from a single 3D textured shape.">
  <meta name="keywords" content="diffusion model, 3D generation, 3D textured shape">
  <meta name="viewport" content="width=device-width, initial-scale=1">
  <title>Sin3DM</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/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">
  <link rel="icon" href="./static/images/favicon.svg">
  <link rel="stylesheet" href="./static/css/bootstrap.min.css">

  <script type="module" src="./static/js/model-viewer.min.js"></script>
  <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/index.js"></script>

</head>


<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-2 publication-title">Sin3DM: Learning a Diffusion Model <br> from a Single 3D Textured Shape</h1>
          <div class="is-size-4 publication-authors">
            <span class="author-block">
              <p>Anonymous Authors</p>
            </span>
          </div>

          <p>This page contains limited assets due to file size limit. If you want to see more assets, please download <a href="https://drive.google.com/file/d/1lTHzWEd6S6FwPATO25F5NLzYp58gzGly/view?usp=drive_link">here</a>. </p>
        </div>
      </div>
    </div>
  </div>
</section>


<section class="section">
  <div class="container is-max-desktop">

    <h2 class="title is-3">Results gallery</h2>

    <div class="columns is-centered">
      <div class="column is-full-width">
        
        <h3 class="title is-4">Generation</h3>
        <p>Generate novel variations of the input. Click the button to switch between different examples.</p>

        <div class="tab" id="tab1">
          <button class="tablinks tab1-link" onclick="clickButton(event, 'Acropolis', 'tab1')" id="button-Acropolis">Acropolis</button>
          <button class="tablinks tab1-link" onclick="clickButton(event, 'House', 'tab1')" id="button-House">House</button>
        </div>
        

        <div id="Acropolis" class="tabcontent tab1-content" style="display: block;">
          <div class="model-block">
              <model-viewer exposure="0.5" camera-controls enable-pan shadow-intensity="2" camera-orbit="0deg 45deg"
                  src="./static/assets/akropolis/input.gltf">
                  <p>Input</p>
              </model-viewer>
          </div>

          <div class="model-block">
            <model-viewer exposure="0.5" camera-controls enable-pan shadow-intensity="2" camera-orbit="0deg 45deg"
                src="./static/assets/akropolis/007.gltf">
                <p>Generated 1</p>
            </model-viewer>
          </div>

          <div class="model-block">
            <model-viewer exposure="0.5" camera-controls enable-pan shadow-intensity="2" camera-orbit="0deg 45deg"
                src="./static/assets/akropolis/013.gltf">
                <p>Generated 2</p>
            </model-viewer>
          </div>

          <div class="model-block">
            <model-viewer exposure="0.5" camera-controls enable-pan shadow-intensity="2" camera-orbit="0deg 45deg"
                src="./static/assets/akropolis/016.gltf">
                <p>Generated 3</p>
            </model-viewer>
          </div>

        </div>


        <div id="House" class="tabcontent tab1-content">
          <div class="model-block">
              <model-viewer exposure="0.75" camera-controls enable-pan shadow-intensity="2" camera-orbit="-90deg 60deg"
                  src="./static/assets/indhouse/input.gltf">
                  <p>Input</p>
              </model-viewer>
          </div>

          <div class="model-block">
            <model-viewer exposure="0.75" camera-controls enable-pan shadow-intensity="2" camera-orbit="-90deg 60deg"
                src="./static/assets/indhouse/008.gltf">
                <p>Generated 1</p>
            </model-viewer>
          </div>

          <div class="model-block">
            <model-viewer exposure="0.75" camera-controls enable-pan shadow-intensity="2" camera-orbit="-90deg 60deg"
                src="./static/assets/indhouse/000.gltf">
                <p>Generated 2</p>
            </model-viewer>
          </div>

          <div class="model-block">
            <model-viewer exposure="0.75" camera-controls enable-pan shadow-intensity="2" camera-orbit="-90deg 60deg"
                src="./static/assets/indhouse/012.gltf">
                <p>Generated 3</p>
            </model-viewer>
          </div>

        </div>


        <div id="Fightingpillar" class="tabcontent tab1-content">
          <div class="model-block">
              <model-viewer exposure="0.5" camera-controls enable-pan shadow-intensity="2" camera-orbit="0deg 60deg"
                  src="./static/assets/fightingpillar/input.gltf">
                  <p>Input</p>
              </model-viewer>
          </div>

          <div class="model-block">
            <model-viewer exposure="0.5" camera-controls enable-pan shadow-intensity="2" camera-orbit="0deg 60deg"
                src="./static/assets/fightingpillar/004.gltf">
                <p>Generated 1</p>
            </model-viewer>
          </div>

          <div class="model-block">
            <model-viewer exposure="0.5" camera-controls enable-pan shadow-intensity="2" camera-orbit="0deg 60deg"
                src="./static/assets/fightingpillar/007.gltf">
                <p>Generated 2</p>
            </model-viewer>
          </div>

          <div class="model-block">
            <model-viewer exposure="0.5" camera-controls enable-pan shadow-intensity="2" camera-orbit="0deg 60deg"
                src="./static/assets/fightingpillar/038.gltf">
                <p>Generated 3</p>
            </model-viewer>
          </div>

        </div>


      </div>
    </div>


    <div class="columns is-centered">
      <div class="column is-full-width">
        <h3 class="title is-4">Retargeting</h3>
        <p>Generate new samples of different size and aspect ratios.</p>
        <div class="tab" id="tab2">
          <button class="tablinks tab2-link" onclick="clickButton(event, 'Smalltown', 'tab2')" id="button-Smalltown">Small town</button>
        </div>


        <div id="Smalltown" class="tabcontent tab2-content" style="display: block;">
          <div class="model-block">
              <model-viewer exposure="0.5" camera-controls enable-pan shadow-intensity="2" camera-orbit="0deg 45deg"
                  src="./static/assets/smalltown/input.gltf">
                  <p>Input</p>
              </model-viewer>
          </div>

          <div class="model-block">
            <model-viewer exposure="0.5" camera-controls enable-pan shadow-intensity="2" camera-orbit="0deg 45deg 80%"
                src="./static/assets/smalltown/resize_000.gltf">
                <p>Generated 1</p>
            </model-viewer>
          </div>

          <div class="model-block">
            <model-viewer exposure="0.5" camera-controls enable-pan shadow-intensity="2" camera-orbit="0deg 45deg"
                src="./static/assets/smalltown/resize_001.gltf">
                <p>Generated 2</p>
            </model-viewer>
          </div>

        </div>

      </div>
    </div>


    <div class="columns is-centered">
      <div class="column is-full-width">
        <h3 class="title is-4">Outpainting</h3>
        <p>Extend the input beyond its boundaries.</p>

        <div class="model-block">
          <model-viewer exposure="0.5" camera-controls enable-pan shadow-intensity="2" camera-orbit="0deg 45deg 150%" max-camera-orbit="auto auto 200%"
              src="./static/assets/stonetiles/input.gltf">
              <p>Input</p>
          </model-viewer>
        </div>


        <div class="model-block">
          <model-viewer exposure="0.5" camera-controls enable-pan shadow-intensity="2" camera-orbit="0deg 45deg" 
              src="./static/assets/stonetiles/outpaint_001.gltf">
              <p>Output</p>
          </model-viewer>
        </div>


    </div>
    </div>


    <div class="columns is-centered">
      <div class="column is-full-width">
        <h3 class="title is-4">PBR models</h3>
        <p>Our method also support PBR materials. Use the drop-down list to view base color, metallic roughness, normal map and geometry.</p>

        <div class="tab" id="tab3">
          <button class="tablinks tab3-link" onclick="clickButton(event, 'Cliffstone', 'tab3')" id="button-Cliffstone">Cliff stone</button>
        </div>


        <div id="Cliffstone" class="tabcontent tab3-content" style="display: block;">
          <div class="model-block">
              <model-viewer class="variants" id="cliffstone0" exposure="0.75" camera-controls enable-pan shadow-intensity="2" camera-orbit="0deg 60deg"
                  src="./static/assets/cliffstone1K_var/input.gltf">
                  <p>Input</p>
                  <div class="controls">
                    <div><select id="cliffstone0Select"></select></div>
                  </div>
              </model-viewer>
          </div>

          <div class="model-block">
            <model-viewer class="variants" id="cliffstone1" exposure="0.75" camera-controls enable-pan shadow-intensity="2" camera-orbit="0deg 60deg"
                src="./static/assets/cliffstone1K_var/006.gltf">
                <p>Generated 1</p>
                <div class="controls">
                  <div><select id="cliffstone1Select"></select></div>
                </div>
            </model-viewer>
          </div>

          <div class="model-block">
            <model-viewer class="variants" id="cliffstone2" exposure="0.75" camera-controls enable-pan shadow-intensity="2" camera-orbit="0deg 60deg"
                src="./static/assets/cliffstone1K_var/008.gltf">
                <p>Generated 2</p>
                <div class="controls">
                  <div><select id="cliffstone2Select"></select></div>
                </div>
            </model-viewer>
          </div>

        </div>


      </div>

    </div>

    <script>
      // Select the model-viewers with class="custom-model"
      const modelViewers = document.querySelectorAll("model-viewer.variants");
    
      modelViewers.forEach((modelViewer) => {
        const id = modelViewer.id;
        const select = document.querySelector(`#${id}Select`);
        
        modelViewer.addEventListener('load', () => {
          const names = modelViewer.availableVariants;
          for (const name of names) {
            const option = document.createElement('option');
            option.value = name;
            option.textContent = name;
            select.appendChild(option);
          }
          // // Adds a default option.
          // const option = document.createElement('option');
          // option.value = 'default';
          // option.textContent = 'Default';
          // select.appendChild(option);
        });
        
        select.addEventListener('input', (event) => {
          modelViewer.variantName = event.target.value === 'default' ? null : event.target.value;
        });
      });
    </script>
    


</section>


<footer class="footer">
  <div class="container">
    <div class="columns is-centered">
      <div class="column is-8">
        <div class="content">
          <p>
            Website template from <a href="https://github.com/nerfies/nerfies.github.io">Nerfies</a>
            under a <a rel="license" href="http://creativecommons.org/licenses/by-sa/4.0/">Creative
            Commons Attribution-ShareAlike 4.0 International License.
          </p>
        </div>
      </div>
    </div>
  </div>
</footer>

</body>
</html>
