<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Dynamic Comparisons.</title>
    <style>
        h5 {
            margin-top: -20px;
        }

        .container {
            max-width: 1200px; /* or 100% for full width */
            margin: auto;
        }

        .row {
            display: flex;
            justify-content: space-between;
            margin-bottom: 24px; /* Adjust the space between rows */
            margin-top: -5px; /* Adjust the space between rows */
        }

        .cap {
            display: flex;
            justify-content: space-between;
            width: 100%; 
            margin-bottom: 20px;
            
        }
        .cap_in {
            flex: 1; 
            text-align: center;
            font-weight: bold;
        }

        .video-column {
            flex: 1; /* Each video column takes equal width */
            margin-right: 20px; /* Adjust the space between video columns */
        }

        .video-column:last-child {
            margin-right: 0; /* Remove right margin for the last video column */
        }

        img {
            width:256px;
            /* height: auto;  */
            display: block;
            /* border-bottom: 18px solid white; */
            border-radius: 6px;
        }

        .block-set {
            display: flex;
            justify-content: space-between;
            /* margin-bottom: 14px; */
            border: 1px dashed gray;
            border-radius: 8px;
            /* padding: 6px; */
            flex-direction: column; /* 允许垂直方向排列 */
        }

    </style>
    <script src="https://cdn.jsdelivr.net/npm/sortablejs@1.14.0/Sortable.min.js"></script>
</head>
<body>

<div class="container">
    <div>
        <h1 style="margin-top: 24px; margin-bottom: 50px; text-align: center">Dynamic Comparisons</h1>
        <h5>Note that the open-sourced SVD model itself does not perform very well in generating dynamic content and has limited capacity generating videos with drastic camera move.</h5>
        <h5>(It exhibits mostly static videos, which could be referred to through: <a href="https://huggingface.co/stabilityai/stable-video-diffusion-img2vid">https://huggingface.co/stabilityai/stable-video-diffusion-img2vid</a>)</h5>
        <h5>Our method can be directly plugged-in-and-played with more powerful base model and generate more dynamic results.</h5>    
    </div>
    <br>
    <div class="cap">
        <div class="cap_in">SVD</div>
        <div class="cap_in">MotionCtrl</div>
        <div class="cap_in">CameraCtrl</div>
        <div class="cap_in">CamTrol</div>
    </div>
    <div class="row">
        <!-- First video and its score blocks -->
        <div class="video-column">
            <img id="video1" src="second_rebuttal_dynamic_comparisons/svd/1.gif" alt="Description of GIF">
        </div>
        <!-- Second video and its score blocks -->
        <div class="video-column">
            <img id="video2" src="second_rebuttal_dynamic_comparisons/mc/1.gif" alt="Description of GIF">
        </div>
        <!-- Third video and its score blocks -->
        <div class="video-column">
            <img id="video3" src="second_rebuttal_dynamic_comparisons/cc/1.gif" alt="Description of GIF">
        </div>
        <!-- Fourth video and its score blocks -->
        <div class="video-column">
            <img id="video4" src="second_rebuttal_dynamic_comparisons/ct/1.gif" alt="Description of GIF">
        </div>

    </div>

    <div class="block-set">
        <div style="display: flex;">
            <p id="camera_ins" style="padding-left: 15px; margin: 7px; display: inline-block; font-weight: bold;">Camera Motion: </p>
            <p id="camera" style="padding-left: 15px; margin: 7px; display: inline-block"></p>
        </div>
        <div style="display: flex;">
        <p id="prompt_ins" style="padding-left: 40px; margin: 7px; display: inline-block; font-weight: bold;">Prompt: </p>
        <p id="prompt" style="padding-left: 52px; margin: 7px; display: inline-block"></p>
        </div>
    </div>

    <div style="margin-top: 30px; margin-bottom: 100px; display: flex; justify-content: end">
        <style>
            #next-page {
                padding: 6px 8px;
                font-size: 14px;
                height: 30px;
            }
        </style>
        <button id="next-page" style="margin-left: 10px; margin-right: 30px;">Next Page</button>
    </div>
</div>


<script>
    document.addEventListener('DOMContentLoaded', (event) => {

        let models = ["svd", "mc", "cc", "ct"];
        let currentPage = 0;
        const totalPages = 4;
        let prompts = [
        "A waterfall.",
        "A rocket.",
        "A person is sitting at a desk, typing on a keyboard. The person is wearing a black shirt and is focused on the task at hand. The keyboard is black and white, and the person is using it to input text or commands.",
        "A cat in a garden."
        ]
        let cameras = [
        "Zoom In",
        "Tilt Up",
        "Zoom Out",
        "Rotate Clockwise"
        ]
        function loadVideosForPage(pageNumber) {


            // if (pageNumber == 1) {
            //     const imgElements = document.querySelectorAll('img');
            //     imgElements.forEach(img => {
            //         img.style.width = '256px';
            //     });
            // } else {
            //     const imgElements = document.querySelectorAll('img');
            //     imgElements.forEach(img => {
            //         img.style.width = '256px';
            //     });
            // }


            const gifElement1 = document.getElementById('video1');
            gifElement1.src = `second_rebuttal_dynamic_comparisons/${models[0]}/${pageNumber + 1}.gif`;

            const gifElement2 = document.getElementById('video2');
            gifElement2.src = `second_rebuttal_dynamic_comparisons/${models[1]}/${pageNumber + 1}.gif`;

            const gifElement3 = document.getElementById('video3');
            gifElement3.src = `second_rebuttal_dynamic_comparisons/${models[2]}/${pageNumber + 1}.gif`;

            const gifElement4 = document.getElementById('video4');
            gifElement4.src = `second_rebuttal_dynamic_comparisons/${models[3]}/${pageNumber + 1}.gif`;

            // const videoElement2 = document.getElementById('video2');
            // const sourceElement2 = videoElement2.querySelector('source');
            // sourceElement2.src = `second_rebuttal_dynamic_comparisons/${models[1]}/${pageNumber + 1}.gif`;
            // videoElement2.load();

            // const videoElement3 = document.getElementById('video3');
            // const sourceElement3 = videoElement3.querySelector('source');
            // sourceElement3.src = `second_rebuttal_dynamic_comparisons/${models[2]}/${pageNumber + 1}.gif`;
            // videoElement3.load();

            // const videoElement4 = document.getElementById('video4');
            // const sourceElement4 = videoElement4.querySelector('source');
            // sourceElement4.src = `second_rebuttal_dynamic_comparisons/${models[3]}/${pageNumber + 1}.gif`;
            // videoElement4.load();

            let prompt = document.getElementById("prompt");
            prompt.innerHTML   = `<em>${prompts[pageNumber]}<\em>`;
            let camrea = document.getElementById("camera");
            camera.innerHTML = `${cameras[pageNumber]}`;
        }

        document.getElementById('next-page').addEventListener('click', () => {
            currentPage++;
            if (currentPage < totalPages) {
                loadVideosForPage(currentPage);
            } else {
                alert("For more dynamic generation, please check the file named 'second_rebuttal_more_dynamics'");
            }

        });

        loadVideosForPage(currentPage);
    });
</script>

</body>
</html>
