<!DOCTYPE html>
<html>

<head lang="en">
    <meta charset="UTF-8">
    <meta http-equiv="x-ua-compatible" content="ie=edge">

    <title>G4Splat: Geometry-Guided Gaussian Splatting with Generative Prior</title>

    <meta name="description" content="G4Splat: Geometry-Guided Gaussian Splatting with Generative Prior">
    <meta name="viewport" content="width=device-width, initial-scale=1">

    <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.5/css/bootstrap.min.css">
    <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/font-awesome/4.4.0/css/font-awesome.min.css">
    <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/codemirror/5.8.0/codemirror.min.css">
    <link rel="stylesheet" href="css/app.css">
    <link rel="stylesheet" href="css/fontawesome.all.min.css">
    <link rel="stylesheet" href="https://cdn.jsdelivr.net/gh/jpswalsh/academicons@1/css/academicons.min.css">

    <script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.3/jquery.min.js"></script>
    <script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.5/js/bootstrap.min.js"></script>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/codemirror/5.8.0/codemirror.min.js"></script>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/1.5.3/clipboard.min.js"></script>
    <script type="text/javascript" async src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.7/MathJax.js?config=TeX-MML-AM_CHTML"></script>
    <script defer src="js/fontawesome.all.min.js"></script>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/Chart.js/2.5.0/Chart.min.js"></script>

    <style>
        /* Basic styles */
        .nav-pills > li.active > a, .nav-pills > li.active > a:hover, .nav-pills > li.active > a:focus {
            background-color: #337ab7;
        }
        .nav-pills > li > a {
            color: #337ab7;
        }
        .pill-row {
            display: flex;
            justify-content: center;
            gap: 10px;
            margin-top: 20px;
            flex-wrap: wrap;
        }
        .pill {
            cursor: pointer;
            border: 2px solid #ddd;
            border-radius: 5px;
            padding: 5px;
            transition: border-color 0.3s;
        }
        .pill.active {
            border-color: #337ab7;
        }
        .pill:hover {
            border-color: #337ab7;
        }
        .thumbnail-img {
            border-radius: 3px;
        }
        .video-container {
            margin: 20px 0;
        }
    </style>

    <!-- Move JavaScript function definitions to head to ensure priority loading -->
    <script>
        // Global variables
        let activeMethodPill, activeScenePill, activeModePill;
        let activeVidID = 0;
        let select = true;

        // Initialization function
        function initializeElements() {
            activeMethodPill = document.querySelector('.method-pill.active');
            activeScenePill = document.querySelector('.scene-pill.active');
            activeModePill = document.querySelector('.mode-pill.active');
        }

        // Any-View scene selection function
        function selectAnyViewScene(scenePill) {
            console.log('selectAnyViewScene called with:', scenePill);
            // Update active state
            document.querySelectorAll('.any-view-scene-pill').forEach(pill => pill.classList.remove('active'));
            scenePill.classList.add('active');
            
            // Get scene value
            const scene = scenePill.getAttribute('data-value');
            
            // Build video file path
            const videoPath = `videos/any-view/${scene}_ours.mp4`;
            
            console.log('Loading any-view video:', videoPath);
            
            // Update video source
            const anyViewVideo = document.getElementById('anyViewVideo');
            if (anyViewVideo) {
                anyViewVideo.src = videoPath;
            } else {
                console.error('anyViewVideo element not found');
            }
        }

        // Comparison video selection function
        function selectCompVideo(methodPill, scenePill, viewCount, modePill) {
            console.log('selectCompVideo called with:', methodPill, scenePill, viewCount, modePill);
            
            // Update active state
            if (methodPill) {
                document.querySelectorAll('.method-pill').forEach(pill => pill.classList.remove('active'));
                methodPill.classList.add('active');
                activeMethodPill = methodPill;
            }
            
            if (scenePill) {
                document.querySelectorAll('.scene-pill').forEach(pill => pill.classList.remove('active'));
                scenePill.classList.add('active');
                activeScenePill = scenePill;
            }
            
            if (modePill) {
                document.querySelectorAll('.mode-pill').forEach(pill => pill.classList.remove('active'));
                modePill.classList.add('active');
                activeModePill = modePill;
            }

            // Get current selected values
            const method = activeMethodPill ? activeMethodPill.getAttribute('data-value') : 'genfusion';
            const scene = activeScenePill ? activeScenePill.getAttribute('data-value') : 'scene2';
            const mode = activeModePill ? activeModePill.getAttribute('data-value') : 'rgb';

            // Build video file path
            const videoPath = `videos/comparison/${scene}_${method}_vs_ours_${mode}.mp4`;
            
            console.log('Loading comparison video:', videoPath);

            // Update video source
            const video0 = document.getElementById('compVideo0');
            const video1 = document.getElementById('compVideo1');
            
            if (mode === 'rgb') {
                if (video0) {
                    video0.src = videoPath;
                    video0.hidden = false;
                    video1.hidden = true;
                    activeVidID = 0;
                }
            } else {
                if (video1) {
                    video1.src = videoPath;
                    video0.hidden = true;
                    video1.hidden = false;
                    activeVidID = 1;
                }
            }

            // Update view count display
            if (viewCount) {
                const compVideoValue = document.getElementById('compVideoValue');
                if (compVideoValue) {
                    compVideoValue.textContent = viewCount;
                }
            }
        }
    </script>

</head>

<body style="padding: 1%; width: 100%">
    <div class="container-lg text-center" style="max-width: 1500px; margin: auto;" id="main">
        <div class="row">
            <h2 class="col-md-12 text-center">
                <b>G4Splat</b>: Geometry-Guided Gaussian Splatting with Generative Prior</br></br>
                <b>More Experiment Results</b>
            </h2>
        </div>
        </br>

        <div class="row">
            <div class="col-md-8 col-md-offset-2">
                <h3 style="text-align: left;"><b>1. Comparison with Baselines (5-View Input)</b><h3>

                <div class="text-center">
                    <ul class="nav nav-pills center-pills">
                        <li class="method-pill" data-value="matcha" onclick="selectCompVideo(this, activeScenePill)"><a>MAtCha</a></li>
                        <li class="method-pill" data-value="genfusion" onclick="selectCompVideo(this, activeScenePill)"><a>GenFusion</a></li>
                        <li class="method-pill" data-value="difix" onclick="selectCompVideo(this, activeScenePill)"><a>Difix3D+</a></li>
                        <li class="method-pill" data-value="guidedvd" onclick="selectCompVideo(this, activeScenePill)"><a>GuidedVD</a></li>
                        <li class="method-pill active" data-value="see3d" onclick="selectCompVideo(this, activeScenePill)"><a>See3D</a></li>
                    </ul>
                </div>
                
                <div class="text-center">
                    <div class="video-container">
                        <video class="video" style="height: 280px; max-width: 100%;" id="compVideo0" loop playsinline autoplay muted>
                            <source src="videos/comparison/scene1_see3d_vs_ours_rgb.mp4" />
                        </video>
                        <video class="video" style="height: 280px; max-width: 100%;" id="compVideo1" loop playsinline autoplay muted hidden>
                            <source src="videos/comparison/scene1_see3d_vs_ours_mesh.mp4" />
                        </video>
                    </div>
                    <div class="text-center" style="color: black;" id="mode-pills">
                        <div class="btn-group btn-group-sm">
                            <span class="btn btn-primary mode-pill active" data-value="rgb" onclick="selectCompVideo(activeMethodPill, activeScenePill, null, this)">
                                RGB
                            </span>
                            <span class="btn btn-primary mode-pill" data-value="mesh" onclick="selectCompVideo(activeMethodPill, activeScenePill, null, this)">
                                Mesh
                            </span>
                        </div>
                    </div>

                    <div class="pill-row scene-pills" id="scene-pills">
                        <span class="pill scene-pill active" data-value="scene1" onclick="selectCompVideo(activeMethodPill, this, 10)">
                            <img class="thumbnail-img" src="thumbnails/comparison/scene1_thumbnail.png" alt="Scene 1" width="64">
                        </span>
                        <span class="pill scene-pill" data-value="scene2" onclick="selectCompVideo(activeMethodPill, this, 10)">
                            <img class="thumbnail-img" src="thumbnails/comparison/scene2_thumbnail.png" alt="Scene 2" width="64">
                        </span>
                        <span class="pill scene-pill" data-value="scene3" onclick="selectCompVideo(activeMethodPill, this, 10)">
                            <img class="thumbnail-img" src="thumbnails/comparison/scene3_thumbnail.png" alt="Scene 3" width="64">
                        </span>
                        <span class="pill scene-pill" data-value="scene4" onclick="selectCompVideo(activeMethodPill, this, 10)">
                            <img class="thumbnail-img" src="thumbnails/comparison/scene4_thumbnail.png" alt="Scene 4" width="64">
                        </span>
                        <span class="pill scene-pill" data-value="scene5" onclick="selectCompVideo(activeMethodPill, this, 10)">
                            <img class="thumbnail-img" src="thumbnails/comparison/scene5_thumbnail.png" alt="Scene 5" width="64">
                        </span>
                        <span class="pill scene-pill" data-value="scene6" onclick="selectCompVideo(activeMethodPill, this, 10)">
                            <img class="thumbnail-img" src="thumbnails/comparison/scene6_thumbnail.png" alt="Scene 6" width="64">
                        </span>
                        <span class="pill scene-pill" data-value="scene7" onclick="selectCompVideo(activeMethodPill, this, 10)">
                            <img class="thumbnail-img" src="thumbnails/comparison/scene7_thumbnail.png" alt="Scene 7" width="64">
                        </span>
                    </div>
                    <br>

                    <p class="text-justify" style="text-align: left; font-size: 16px;">
                        Baseline (left) vs. Ours (right). Our method delivers more accurate geometry with fewer Gaussian floaters across both observed and unobserved regions. 
                        <b>Try exploring different methods, scenes, and modes (RGB/Mesh) to see the difference!</b>
                    </p>
                </div>
            </div>
        </div>

        <!-- Any-View Results Display Area -->
        <div class="row">
            <div class="col-md-8 col-md-offset-2">
                <h3 style="text-align: left;"><b>2. Any-View Reconstruction</b><h3>

                <div class="text-center">
                    <div class="video-container">
                        <video id="anyViewVideo" class="video" style="height: 280px; max-width: 100%;" loop playsinline autoplay muted controls>
                            <source src="videos/any-view/scene1_ours.mp4" />
                        </video>
                    </div>

                    <div class="pill-row any-view-scene-pills" id="any-view-scene-pills">
                        <span class="pill any-view-scene-pill active" data-value="scene1" onclick="selectAnyViewScene(this)">
                            <img class="thumbnail-img" src="thumbnails/any-view/scene1_thumbnail.png" alt="Scene 1" width="64">
                            <div class="caption" style="font-size:10px; margin-top:4px;">1 input view</div>
                        </span>
                        <span class="pill any-view-scene-pill" data-value="scene2" onclick="selectAnyViewScene(this)">
                            <img class="thumbnail-img" src="thumbnails/any-view/scene2_thumbnail.png" alt="Scene 2" width="64">
                            <div class="caption" style="font-size:10px; margin-top:4px;">1 input view</div>
                        </span>
                        <span class="pill any-view-scene-pill" data-value="scene3" onclick="selectAnyViewScene(this)">
                            <img class="thumbnail-img" src="thumbnails/any-view/scene3_thumbnail.png" alt="Scene 3" width="64">
                            <div class="caption" style="font-size:10px; margin-top:4px;">1 input view</div>
                        </span>
                        <span class="pill any-view-scene-pill" data-value="scene4" onclick="selectAnyViewScene(this)">
                            <img class="thumbnail-img" src="thumbnails/any-view/scene4_thumbnail.png" alt="Scene 4" width="64">
                            <div class="caption" style="font-size:10px; margin-top:10px;">5 input views</div>
                        </span>
                        <span class="pill any-view-scene-pill" data-value="scene5" onclick="selectAnyViewScene(this)">
                            <img class="thumbnail-img" src="thumbnails/any-view/scene5_thumbnail.png" alt="Scene 5" width="64">
                            <div class="caption" style="font-size:10px; margin-top:8px;">5 input views</div>
                        </span>
                        <span class="pill any-view-scene-pill" data-value="scene6" onclick="selectAnyViewScene(this)">
                            <img class="thumbnail-img" src="thumbnails/any-view/scene6_thumbnail.png" alt="Scene 6" width="64">
                            <div class="caption" style="font-size:10px; margin-top:2px;">5 input views</div>
                        </span>
                        <span class="pill any-view-scene-pill" data-value="scene7" onclick="selectAnyViewScene(this)">
                            <img class="thumbnail-img" src="thumbnails/any-view/scene7_thumbnail.png" alt="Scene 7" width="64">
                            <div class="caption" style="font-size:10px; margin-top:2px;">10 input views</div>
                        </span>
                        <span class="pill any-view-scene-pill" data-value="scene8" onclick="selectAnyViewScene(this)">
                            <img class="thumbnail-img" src="thumbnails/any-view/scene8_thumbnail.png" alt="Scene 8" width="64">
                            <div class="caption" style="font-size:10px; margin-top:2px;">10 input views</div>
                        </span>
                    </div>
                    <br>

                    <p class="text-justify" style="text-align: left; font-size: 16px;">
                        Our method shows strong generalization across diverse scenarios, including indoor and outdoor environments, unposed scenes, and even single-view inputs. 
                        <b>Try exploring different scenes!</b>
                    </p>
                </div>
            </div>
        </div>

        <div class="row">
            <div class="col-md-8 col-md-offset-2">
            <h3 style="text-align: left;"><b>3. Dense-View Comparison with Baselines (383-View Input)</b><h3>
                <video id="denseViewVideo" width="100%" autoplay loop muted controls>
                    <source src="videos/dense-view/dense-view.mp4" type="video/mp4" />
                </video>
                <br><br>
                <p class="text-justify" style="text-align: left; font-size: 16px;">
                    Our method significantly outperforms the baselines even with dense-view inputs, especially in regions with strong specularities and reflections.
                </p>
            </div>
        </div>
        <br>

    </div>

    <script>
        // Initialize after page loads
        document.addEventListener('DOMContentLoaded', function() {
            console.log('DOM loaded, initializing...');
            initializeElements();
            
            // Set up comparison video event listeners
            const video0 = document.getElementById("compVideo0");
            const video1 = document.getElementById("compVideo1");
            
            if (video0) {
                video0.addEventListener('loadedmetadata', function() {
                    if (activeVidID == 0 && select){
                        video0.play();
                        console.log('Video 0 loaded successfully:', video0.videoWidth, video0.videoHeight);
                        video0.hidden = false;
                        video1.hidden = true;
                    }
                });
            }
            
            if (video1) {
                video1.addEventListener('loadedmetadata', function() {
                    if (activeVidID == 1 && select){
                        video1.play();
                        console.log('Video 1 loaded successfully:', video1.videoWidth, video1.videoHeight);
                        video0.hidden = true;
                        video1.hidden = false;
                    }
                });
            }

            // Set up Any-View video event listeners
            const anyViewVideo = document.getElementById('anyViewVideo');
            
            if (anyViewVideo) {
                anyViewVideo.addEventListener('loadedmetadata', function() {
                    console.log('Any-view video loaded successfully:', anyViewVideo.videoWidth, anyViewVideo.videoHeight);
                });
                
                anyViewVideo.addEventListener('error', function(e) {
                    console.error('Any-view video error:', e);
                });
            }
        });
    </script>
</body>
</html>