<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>ICLR2026 Submission</title>
    <style>
        body {
            font-family: Arial, sans-serif;
            margin: 20px;
            background-color: #f5f5f5;
        }
        
        .container {
            max-width: 1600px;
            margin: 0 auto;
        }
        
        .header {
            text-align: center;
            margin-bottom: 30px;
            padding: 20px;
            background-color: white;
            border-radius: 10px;
            box-shadow: 0 2px 5px rgba(0,0,0,0.1);
        }
        
        .result-item {
            margin-bottom: 40px;
            padding: 20px;
            background-color: white;
            border-radius: 10px;
            box-shadow: 0 2px 5px rgba(0,0,0,0.1);
        }
        
        .directory-title {
            font-size: 24px;
            font-weight: bold;
            color: #333;
            margin-bottom: 20px;
            padding: 15px;
            background-color: #e8f4f8;
            border-radius: 8px;
            border-left: 4px solid #2196F3;
            text-align: center;
        }
        
        .grids-container {
            display: flex;
            gap: 30px;
            justify-content: center;
            flex-wrap: wrap;
        }
        
        .grid-section {
            flex: 1;
            min-width: 600px;
            max-width: 800px;
        }
        
        .grid-title {
            font-size: 18px;
            font-weight: bold;
            color: #555;
            margin-bottom: 15px;
            padding: 12px;
            text-align: center;
            border-radius: 5px;
            background-color: #fff3e8;
        }
        
        .grid-4x4 {
            display: grid;
            grid-template-columns: repeat(4, 1fr);
            grid-template-rows: repeat(4, 1fr);
            gap: 8px;
            aspect-ratio: 1;
        }
        
        .grid-item {
            border: 2px solid #ddd;
            border-radius: 8px;
            overflow: hidden;
            display: flex;
            align-items: center;
            justify-content: center;
            background-color: #f9f9f9;
            position: relative;
        }
        
        .grid-item img {
            width: 100%;
            height: 100%;
            object-fit: cover;
            transition: transform 0.3s ease;
        }
        
        .grid-item:hover img {
            transform: scale(1.05);
        }
        
        .grid-item:hover {
            border-color: #2196F3;
            box-shadow: 0 4px 8px rgba(0,0,0,0.2);
        }
        
        .gif-label {
            position: absolute;
            bottom: 2px;
            left: 2px;
            background-color: rgba(0,0,0,0.7);
            color: white;
            padding: 2px 6px;
            border-radius: 3px;
            font-size: 10px;
            font-weight: bold;
        }
        
        .error-placeholder {
            color: #888;
            font-style: italic;
            text-align: center;
            padding: 10px;
            font-size: 12px;
        }
        
        .loading {
            color: #666;
            text-align: center;
            padding: 20px;
            font-style: italic;
        }
        
        @media (max-width: 1200px) {
            .grids-container {
                flex-direction: column;
            }
            
            .grid-section {
                min-width: unset;
                max-width: unset;
            }
        }
        
        @media (max-width: 768px) {
            .grid-4x4 {
                grid-template-columns: repeat(2, 1fr);
                grid-template-rows: repeat(8, 1fr);
            }
        }
    </style>
</head>
<body>
    <div class="container">
        <div class="header">
            <h1>Multi-view Point Tracking Visualization</h1>
            <!-- <p>Multi-view point tracking animations 4x4 grids</p> -->
        </div>
        
        <div id="content">
            <div class="loading">Loading point tracking GIF results...</div>
        </div>
        
        <script>
            // Directory structure - 10 subdirectories with 16 MP4 files each
            const directories = ['01', '02', '03', '04', '05', '06', '07', '08'];
            
            // Generate view names for 16 files (view_0_track.gif to view_15_track.gif)
            function generateViewNames() {
                const views = [];
                for (let i = 0; i < 16; i++) {
                    views.push(`view_${i}_track.gif`);
                }
                return views;
            }
            
            // Create a 4x4 grid for GIFs
            function create4x4Grid(basePath, directoryName, views, gridTitle) {
                const gridSection = document.createElement('div');
                gridSection.className = 'grid-section';
                
                const title = document.createElement('div');
                title.className = 'grid-title';
                title.textContent = gridTitle;
                gridSection.appendChild(title);
                
                const grid = document.createElement('div');
                grid.className = 'grid-4x4';
                
                views.forEach((viewName, index) => {
                    const gridItem = document.createElement('div');
                    gridItem.className = 'grid-item';
                    
                    const img = document.createElement('img');
                    img.src = `${basePath}/${directoryName}/${viewName}`;
                    img.alt = `View ${index}`;
                    
                    img.onerror = function() {
                        gridItem.innerHTML = `<div class="error-placeholder">GIF not found<br>${viewName}</div>`;
                    };
                    
                    const label = document.createElement('div');
                    label.className = 'gif-label';
                    label.textContent = `View ${index}`;
                    
                    gridItem.appendChild(img);
                    gridItem.appendChild(label);
                    grid.appendChild(gridItem);
                });
                
                gridSection.appendChild(grid);
                return gridSection;
            }
            
            // Generate content for each directory
            function generateContent() {
                const contentDiv = document.getElementById('content');
                contentDiv.innerHTML = ''; // Clear loading message
                
                const views = generateViewNames();
                
                // Process directories in pairs for side-by-side layout
                for (let i = 0; i < directories.length; i += 2) {
                    const resultItem = document.createElement('div');
                    resultItem.className = 'result-item';
                    
                    // Directory title
                    const directoryTitle = document.createElement('div');
                    directoryTitle.className = 'directory-title';
                    
                    if (i + 1 < directories.length) {
                        directoryTitle.textContent = `Examples ${directories[i]} & ${directories[i + 1]}`;
                    } else {
                        directoryTitle.textContent = `Examples ${directories[i]}`;
                    }
                    
                    resultItem.appendChild(directoryTitle);
                    
                    // Create grids container
                    const gridsContainer = document.createElement('div');
                    gridsContainer.className = 'grids-container';
                    
                    // First grid
                    const firstGrid = create4x4Grid('point_tracking_gifs', directories[i], views, `Example ${directories[i]} - Views 0-15`);
                    gridsContainer.appendChild(firstGrid);
                    
                    // Second grid (if exists)
                    if (i + 1 < directories.length) {
                        const secondGrid = create4x4Grid('point_tracking_gifs', directories[i + 1], views, `Example ${directories[i + 1]} - Views 0-15`);
                        gridsContainer.appendChild(secondGrid);
                    }
                    
                    resultItem.appendChild(gridsContainer);
                    contentDiv.appendChild(resultItem);
                }
                
                // // Add usage instructions
                // const instructionsDiv = document.createElement('div');
                // instructionsDiv.className = 'result-item';
                // instructionsDiv.innerHTML = `
                //     <div class="directory-title">Usage Instructions</div>
                //     <div style="padding: 15px; color: #666; line-height: 1.6;">
                //         <p><strong>Animated GIFs</strong> play automatically and loop continuously</p>
                //         <p><strong>Hover</strong> over any GIF to see slight zoom effect</p>
                //         <p><strong>Each grid</strong> shows 16 different camera views (View 0 to View 15) of the same tracking sequence</p>
                //         <p><strong>GIF files</strong> are loaded from the 'point_tracking_gifs' directory</p>
                //     </div>
                // `;
                // contentDiv.appendChild(instructionsDiv);
            }
            
            // Generate content when page loads
            document.addEventListener('DOMContentLoaded', generateContent);
        </script>
    </div>
</body>
</html>