<!DOCTYPE html>
<html lang="zh-CN">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>ADAVIEWPLANNER - 4D Scene Viewpoint Planning</title>
    <script src="https://cdn.tailwindcss.com"></script>
    <style>
        /* 自定义样式 */
        /* .gradient-bg {
            background: linear-gradient(135deg, #1e293b 0%, #334155 50%, #475569 100%);
        } */

        .gradient-bg {
            background: #000; /* 纯黑 */
        }
        
        .video-container {
            position: relative;
            width: 100%;
            height: 320px;
            border: 2px solid #d1d5db;
            border-radius: 0.75rem;
            overflow: hidden;
            background: #f3f4f6;
        }
        
        .video-container video {
            width: 100%;
            height: 100%;
            object-fit: cover;
        }

        /* 优化后的hover效果 - 更加subtle */
        .video-item:hover .video-container {
            border-color: #cbd5e1;
            box-shadow: 0 8px 25px -5px rgba(0, 0, 0, 0.1), 0 8px 10px -6px rgba(0, 0, 0, 0.1);
            transform: translateY(-2px);
        }

        /* 全屏样式优化 */
        .video-container video:fullscreen {
            object-fit: contain;
            background: #000;
        }

        /* 视频控制栏优化 */
        .video-container video::-webkit-media-controls {
            bottom: 0;
        }
        
        /* .section-card {
            background: white;
            border: 1px solid #e5e7eb;
            border-radius: 1rem;
            box-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.1);
            overflow: hidden;
            transition: all 0.3s ease;
        } */

        .section-card {
            background: #1f2937; /* 深灰色 */
            /* 或者使用 background: black; 黑色 */
            border: 1px solid #374151;
            border-radius: 1rem;
            box-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.1);
            overflow: hidden;
            transition: all 0.3s ease;
        }
        
        .section-card:hover {
            box-shadow: 0 10px 25px -3px rgba(0, 0, 0, 0.1);
            transform: scale(1.01);
        }
        
        .section-header {
            background: linear-gradient(90deg, #475569 0%, #64748b 50%, #475569 100%);
            padding: 1.5rem;
            color: white;
        }
        
        
        .index-indicator {
            position: absolute;
            top: 0.75rem;
            right: 0.75rem;
            background: rgba(0, 0, 0, 0.6);
            color: white;
            padding: 0.25rem 0.5rem;
            border-radius: 9999px;
            font-size: 0.75rem;
            font-weight: 500;
            backdrop-filter: blur(4px);
            z-index: 10;
        }
        
        .description-section {
            /* background: linear-gradient(135deg, #f9fafb 0%, #f3f4f6 100%);
            border-top: 1px solid #e5e7eb; */
            background: linear-gradient(135deg, #374151 0%, #4b5563 100%);
            border-top: 1px solid #6b7280;
            padding: 1.5rem;
        }


        /* 响应式视频高度 */
        @media (max-width: 768px) {
            .video-container {
                height: 240px;
            }
        }
        
        @media (max-width: 480px) {
            .video-container {
                height: 200px;
            }
        }
    </style>
</head>
<body class="bg-gray-950">
    <!-- Header Section -->
    <div class="relative overflow-hidden gradient-bg">
        <div class="absolute inset-0">
            <div class="absolute inset-0 bg-gradient-to-b from-transparent via-slate-800/50 to-slate-900/80"></div>
            <div class="absolute inset-0 bg-[radial-gradient(circle_at_50%_50%,rgba(120,119,198,0.1),transparent_50%)]"></div>
        </div>
        
        <div class="relative max-w-7xl mx-auto px-6 py-24 text-center">
            <div class="space-y-8">
                <h1 id="page-title" class="text-5xl md:text-6xl font-light text-white mb-8 tracking-wide">
                    <span class="bg-gradient-to-r from-white to-slate-200 bg-clip-text text-transparent">
                        AdaViewPlanner
                    </span>
                    <span id="page-subtitle" class="block text-slate-300 font-normal mt-4 text-2xl md:text-3xl">
                        Adapting Video Diffusion Models for Viewpoint Planning in 4D Scenes
                    </span>
                    <span id="page-subtitle" class="block text-slate-300 font-normal mt-4 text-2xl md:text-3xl">
                        Supplementary Material
                    </span>
                    <span id="page-subtitle" class="block text-slate-300 font-normal mt-4 text-2xl md:text-3xl">
                        Paper ID #2886
                    </span>
                </h1>
                
                <!-- <div class="space-y-4 text-slate-300 mb-10 font-light">
                    <p id="page-subtitle-text" class="text-xl">Visualization Results</p>
                </div> -->

                <!-- <div class="max-w-5xl mx-auto space-y-6 text-slate-100">
                    <p class="text-xl leading-relaxed font-light">
                        This page showcases the visualization results of the cases presented in the paper, as well as additional examples.
                    </p>
                </div> -->
            </div>
        </div>
    </div>

    <!-- Method Overview -->
    <div class="max-w-7xl mx-auto px-6 py-12">
        <!-- <div class="bg-gradient-to-br from-white to-slate-50 border border-slate-200 p-8 rounded-2xl shadow-lg"> -->
        <div class="bg-slate-900/60 border border-slate-700 p-8 rounded-2xl shadow-lg text-slate-200">

            <div class="flex items-start space-x-4">
                <div class="flex-shrink-0">
                    <div class="p-3 bg-gradient-to-br from-slate-100 to-slate-200 rounded-xl">
                        <svg class="h-6 w-6 text-slate-600" fill="currentColor" viewBox="0 0 20 20">
                            <path fill-rule="evenodd" d="M18 10a8 8 0 11-16 0 8 8 0 0116 0zm-7-4a1 1 0 11-2 0 1 1 0 012 0zM9 9a1 1 0 000 2v3a1 1 0 001 1h1a1 1 0 100-2v-3a1 1 0 00-1-1H9z" clip-rule="evenodd" />
                        </svg>
                    </div>
                </div>
                <div class="flex-grow">
                    <!-- <h3 class="text-lg font-semibold text-slate-800 mb-3">Method Overview</h3> -->
                    <!-- <p class="text-slate-700 leading-relaxed">
                        <span class="font-bold text-slate-900">ADAVIEWPLANNER</span> demonstrates a comprehensive approach to 4D scene understanding:
                    </p> -->
                    <div class="mt-4 space-y-2 text-white">
                        This page showcases the visualization results of the cases presented in the paper, as well as additional examples.
                        <div class="flex items-center">
                            <div class="w-2 h-2 bg-gray-300 rounded-full mr-3"></div>
                            <span><strong>Full Results</strong>: Motion -> Video + Camera</span>
                        </div>
                        <div class="flex items-center">
                            <div class="w-2 h-2 bg-emerald-400 rounded-full mr-3"></div>
                            <span><strong>Stage I</strong>: Motion -> video </span>
                        </div>
                        <div class="flex items-center">
                            <div class="w-2 h-2 bg-orange-400 rounded-full mr-3"></div>
                            <span><strong>Diverse Results</strong></span>
                        </div>
                    </div>
                    <!-- <p class="text-slate-600 mt-4 text-sm">
                        Each visualization shows different aspects of our adaptive viewpoint planning system.
                    </p> -->
                </div>
            </div>
        </div>
    </div>

    <!-- Video Results Container -->
    <div class="max-w-7xl mx-auto px-6 pb-20">
        <div id="video-container" class="space-y-16">
            <!-- 视频内容将通过 JavaScript 动态生成 -->
        </div>
    </div>

    <!-- Footer -->
    <div class="bg-slate-800 text-white py-8">
        <div class="max-w-7xl mx-auto px-6 text-center">
            <p class="text-slate-300">ADAVIEWPLANNER - Adapting Video Diffusion Models for Viewpoint Planning in 4D Scenes</p>
        </div>
    </div>

    <script>
        // 新的配置数据结构
        let videoConfig = {
            title: "",
            subtitle: "Visualization Results",
            description: "4D Scene Viewpoint Planning",
            videoGroups: [
                {
                    title: "Full Result",
                    // description: "Complete 4D scene viewpoint planning result showing depth, RGB, and surface information",
                    layout: "1-column",
                    videos: [
                        // complex_motion
                        {
                            method: "Depth View",
                            video: "videos/1 full result/0001.mp4",
                            type: "depth",
                        },
                        {
                            method: "Depth View",
                            video: "videos/1 full result/0002.mp4",
                            type: "depth",
                        },
                        {
                            method: "Depth View",
                            video: "videos/1 full result/0003.mp4",
                            type: "depth",
                        },
                        {
                            method: "Depth View",
                            video: "videos/1 full result/0004.mp4",
                            type: "depth",
                        },
                        {
                            method: "Depth View",
                            video: "videos/1 full result/0005.mp4",
                            type: "depth",
                        },
                        {
                            method: "Depth View",
                            video: "videos/1 full result/0006.mp4",
                            type: "depth",
                        },
                        {
                            method: "Depth View",
                            video: "videos/1 full result/0007.mp4",
                            type: "depth",
                        },
                        {
                            method: "Depth View",
                            video: "videos/1 full result/0008.mp4",
                            type: "depth",
                        },
                        {
                            method: "Depth View",
                            video: "videos/1 full result/0009.mp4",
                            type: "depth",
                        },
                        {
                            method: "Depth View",
                            video: "videos/1 full result/0010.mp4",
                            type: "depth",
                        },
                        {
                            method: "Depth View",
                            video: "videos/1 full result/0011.mp4",
                            type: "depth",
                        },
                        {
                            method: "Depth View",
                            video: "videos/1 full result/0012.mp4",
                            type: "depth",
                        },
                        {
                            method: "Depth View",
                            video: "videos/1 full result/0013.mp4",
                            type: "depth",
                        },
                        {
                            method: "Depth View",
                            video: "videos/1 full result/0014.mp4",
                            type: "depth",
                        },
                        {
                            method: "Depth View",
                            video: "videos/1 full result/0015.mp4",
                            type: "depth",
                        },
                        {
                            method: "Depth View",
                            video: "videos/1 full result/0016.mp4",
                            type: "depth",
                        },
                        {
                            method: "Depth View",
                            video: "videos/1 full result/0017.mp4",
                            type: "depth",
                        },
                        {
                            method: "Depth View",
                            video: "videos/1 full result/0018.mp4",
                            type: "depth",
                        },
                        {
                            method: "Depth View",
                            video: "videos/1 full result/0019.mp4",
                            type: "depth",
                        },
                        {
                            method: "Depth View",
                            video: "videos/1 full result/0020.mp4",
                            type: "depth",
                        },
                    ],
                },
                {
                    title: "Stage I Result",
                    // description: "Initial viewpoint planning stage showing depth estimation and RGB generation",
                    layout: "1-column",
                    videos: [
                        {
                            method: "Depth Estimation",
                            video: "videos/2 stage1 result/0001.mp4",
                            type: "depth",
                        },
                        {
                            method: "Depth Estimation",
                            video: "videos/2 stage1 result/0002.mp4",
                            type: "depth",
                        },
                        {
                            method: "Depth Estimation",
                            video: "videos/2 stage1 result/0003.mp4",
                            type: "depth",
                        },
                        {
                            method: "Depth Estimation",
                            video: "videos/2 stage1 result/0004.mp4",
                            type: "depth",
                        },
                        {
                            method: "Depth Estimation",
                            video: "videos/2 stage1 result/0005.mp4",
                            type: "depth",
                        },
                        {
                            method: "Depth Estimation",
                            video: "videos/2 stage1 result/0006.mp4",
                            type: "depth",
                        },
                        {
                            method: "Depth Estimation",
                            video: "videos/2 stage1 result/0007.mp4",
                            type: "depth",
                        },
                        {
                            method: "Depth Estimation",
                            video: "videos/2 stage1 result/0008.mp4",
                            type: "depth",
                        },
                        {
                            method: "Depth Estimation",
                            video: "videos/2 stage1 result/0009.mp4",
                            type: "depth",
                        },
                        {
                            method: "Depth Estimation",
                            video: "videos/2 stage1 result/0010.mp4",
                            type: "depth",
                        },
                    ],
                },
                {
                    title: "Diverse Result",
                    // description: "Demonstrating diverse viewpoint generation capabilities across different scenes and camera trajectories",
                    layout: "2-column",
                    videos: [
                        {
                            method: "Scene A - Diverse Views",
                            video: "videos/3 diverse result/0001.mp4",
                            type: "diverse",
                        },
                        {
                            method: "Scene A - Diverse Views",
                            video: "videos/3 diverse result/0002.mp4",
                            type: "diverse",
                        },
                        {
                            method: "Scene A - Diverse Views",
                            video: "videos/3 diverse result/0003.mp4",
                            type: "diverse",
                        },
                        {
                            method: "Scene A - Diverse Views",
                            video: "videos/3 diverse result/0004.mp4",
                            type: "diverse",
                        },
                        {
                            method: "Scene A - Diverse Views",
                            video: "videos/3 diverse result/0005.mp4",
                            type: "diverse",
                        },
                        {
                            method: "Scene A - Diverse Views",
                            video: "videos/3 diverse result/0006.mp4",
                            type: "diverse",
                        },
                        {
                            method: "Scene A - Diverse Views",
                            video: "videos/3 diverse result/0007.mp4",
                            type: "diverse",
                        },
                        {
                            method: "Scene A - Diverse Views",
                            video: "videos/3 diverse result/0008.mp4",
                            type: "diverse",
                        },
                        {
                            method: "Scene A - Diverse Views",
                            video: "videos/3 diverse result/0009.mp4",
                            type: "diverse",
                        },
                        {
                            method: "Scene A - Diverse Views",
                            video: "videos/3 diverse result/0010.mp4",
                            type: "diverse",
                        },
                        {
                            method: "Scene A - Diverse Views",
                            video: "videos/3 diverse result/0011.mp4",
                            type: "diverse",
                        },
                        {
                            method: "Scene A - Diverse Views",
                            video: "videos/3 diverse result/0012.mp4",
                            type: "diverse",
                        },
                        {
                            method: "Scene A - Diverse Views",
                            video: "videos/3 diverse result/0013.mp4",
                            type: "diverse",
                        },
                        {
                            method: "Scene A - Diverse Views",
                            video: "videos/3 diverse result/0014.mp4",
                            type: "diverse",
                        },
                        {
                            method: "Scene A - Diverse Views",
                            video: "videos/3 diverse result/0015.mp4",
                            type: "diverse",
                        },
                        {
                            method: "Scene A - Diverse Views",
                            video: "videos/3 diverse result/0016.mp4",
                            type: "diverse",
                        },
                    ],
                },
            ],
        };
        
        function getConfigData() {
            let stage_full_res = [
                'videos/1 full result/complex_motion/18/web_optimized_18_1_global_3.0_enhanced_cameras.mp4', 'videos/1 full result/complex_motion/18/web_optimized_18_1_global_in_predictcam.mp4', 'videos/1 full result/complex_motion/18/web_optimized_18_1.mp4', 'videos/1 full result/complex_motion/24/web_optimized_24_1_global_3.0_enhanced_cameras.mp4', 'videos/1 full result/complex_motion/24/web_optimized_24_1_global_in_predictcam.mp4', 'videos/1 full result/complex_motion/24/web_optimized_24_1.mp4', 'videos/1 full result/complex_motion/25/web_optimized_25_1_global_3.0_enhanced_cameras.mp4', 'videos/1 full result/complex_motion/25/web_optimized_25_1_global_in_predictcam.mp4', 'videos/1 full result/complex_motion/25/web_optimized_25_1.mp4', 'videos/1 full result/demo_cam_v1/147/web_optimized_147_1_global_6.0_enhanced_cameras.mp4', 'videos/1 full result/demo_cam_v1/147/web_optimized_147_1_global_in_predictcam.mp4', 'videos/1 full result/demo_cam_v1/147/web_optimized_147_1.mp4', 'videos/1 full result/demo_cam_v1/373/web_optimized_373_1_global_4.5_enhanced_cameras.mp4', 'videos/1 full result/demo_cam_v1/373/web_optimized_373_1_global_in_predictcam.mp4', 'videos/1 full result/demo_cam_v1/373/web_optimized_373_1.mp4', 'videos/1 full result/demo_cam_v1/427/web_optimized_427_1_global_3.0_enhanced_cameras.mp4', 'videos/1 full result/demo_cam_v1/427/web_optimized_427_1_global_in_predictcam.mp4', 'videos/1 full result/demo_cam_v1/427/web_optimized_427_1.mp4', 'videos/1 full result/demo_cam_v1/56/web_optimized_56_1_global_3.0_enhanced_cameras.mp4', 'videos/1 full result/demo_cam_v1/56/web_optimized_56_1_global_in_predictcam.mp4', 'videos/1 full result/demo_cam_v1/56/web_optimized_56_1.mp4', 'videos/1 full result/demo_v3/277/web_optimized_277_1_global_3.0_enhanced_cameras.mp4', 'videos/1 full result/demo_v3/277/web_optimized_277_1_global_in_predictcam.mp4', 'videos/1 full result/demo_v3/277/web_optimized_277_1.mp4', 'videos/1 full result/demo_v3/297/web_optimized_297_1_global_3.0_enhanced_cameras.mp4', 'videos/1 full result/demo_v3/297/web_optimized_297_1_global_in_predictcam.mp4', 'videos/1 full result/demo_v3/297/web_optimized_297_1.mp4', 'videos/1 full result/demo_v3/494/web_optimized_494_1_global_3.0_enhanced_cameras.mp4', 'videos/1 full result/demo_v3/494/web_optimized_494_1_global_in_predictcam.mp4', 'videos/1 full result/demo_v3/494/web_optimized_494_1.mp4', 'videos/1 full result/others/0/web_optimized_0_global_3.0_enhanced_cameras.mp4', 'videos/1 full result/others/0/web_optimized_0_global_in_predictcam.mp4', 'videos/1 full result/others/0/web_optimized_0.mp4', 'videos/1 full result/ours_240/126/web_optimized_126_global_3.0_enhanced_cameras.mp4', 'videos/1 full result/ours_240/126/web_optimized_126 2.mp4', 'videos/1 full result/ours_240/126/web_optimized_126.mp4', 'videos/1 full result/ours_240/176/web_optimized_176_global_3.0_enhanced_cameras.mp4', 'videos/1 full result/ours_240/176/web_optimized_176 2.mp4', 'videos/1 full result/ours_240/176/web_optimized_176.mp4', 'videos/1 full result/ours_240/192/web_optimized_192_global_3.0_enhanced_cameras.mp4', 'videos/1 full result/ours_240/192/web_optimized_192 2.mp4', 'videos/1 full result/ours_240/192/web_optimized_192.mp4', 'videos/1 full result/ours_70/5/web_optimized_5_global_3.0_enhanced_cameras.mp4', 'videos/1 full result/ours_70/5/web_optimized_5 2.mp4', 'videos/1 full result/ours_70/5/web_optimized_5.mp4', 'videos/1 full result/ours_70/52/web_optimized_52_global_4.5_enhanced_cameras.mp4', 'videos/1 full result/ours_70/52/web_optimized_52 2.mp4', 'videos/1 full result/ours_70/52/web_optimized_52.mp4'
            ]
            let stage_1_res_idx = [
                1, 5, 6, 12, 13, 14, 15, 17, 18, 19, 20, 22, 23, 24, 28
            ]

            let stage2_videos = ['videos/3 stage2 result/web_optimized_18_global_4.5_enhanced_cameras.mp4', 'videos/3 stage2 result/web_optimized_3_global_3.0_enhanced_cameras.mp4', 'videos/3 stage2 result/web_optimized_42_global_4.5_enhanced_cameras.mp4', 'videos/3 stage2 result/web_optimized_55_global_4.5_enhanced_cameras.mp4', 'videos/3 stage2 result/web_optimized_10_global_4.5_enhanced_cameras.mp4', 'videos/3 stage2 result/web_optimized_60_global_4.5_enhanced_cameras.mp4', 'videos/3 stage2 result/web_optimized_65_global_4.5_enhanced_cameras.mp4', 'videos/3 stage2 result/web_optimized_32_global_4.5_enhanced_cameras.mp4', 'videos/3 stage2 result/web_optimized_20_global_4.5_enhanced_cameras.mp4', 'videos/3 stage2 result/web_optimized_0_global_4.5_enhanced_cameras.mp4', 'videos/3 stage2 result/web_optimized_50_global_6.0_enhanced_cameras.mp4', 'videos/3 stage2 result/web_optimized_66_global_6.0_enhanced_cameras.mp4', 'videos/3 stage2 result/web_optimized_61_global_3.0_enhanced_cameras.mp4', 'videos/3 stage2 result/web_optimized_17_global_4.5_enhanced_cameras.mp4', 'videos/3 stage2 result/web_optimized_29_global_4.5_enhanced_cameras.mp4', 'videos/3 stage2 result/web_optimized_179_global_4.5_enhanced_cameras.mp4', 'videos/3 stage2 result/web_optimized_24_global_6.0_enhanced_cameras.mp4', 'videos/3 stage2 result/web_optimized_62_global_3.0_enhanced_cameras.mp4', 'videos/3 stage2 result/web_optimized_2_global_4.5_enhanced_cameras.mp4', 'videos/3 stage2 result/web_optimized_54_global_4.5_enhanced_cameras.mp4']
            
            
            
            videoGroups = videoConfig.videoGroups

            for (let index = 0; index < videoGroups.length; index++) {
                element = videoGroups[index];
                if (element.title == "Stage 1 Result") {
                    temp_videos = []
                    for (let idx2 = 0; idx2 < stage_1_res_idx.length; idx2++) {
                        temp_videos.push({
                            method: "Depth Estimation",
                            video: `videos/2 stage1 result/${stage_1_res_idx[idx2]}/web_optimized_combined_video.mp4`,
                            type: "depth",
                        })
                    }
                    videoGroups[index].videos = temp_videos
                } else if (element.title == "Stage 2 Result") {
                    temp_videos = []
                    for (let idx2 = 0; idx2 < stage2_videos.length; idx2++) {
                        temp_videos.push({
                            method: "Scene A - Diverse Views",
                            video: stage2_videos[idx2],
                            type: "diverse",
                        })
                    }
                    videoGroups[index].videos = temp_videos
                } else if (element.title == "Full Result") {
                    // temp_videos = []
                    // for (let idx2 = 0; idx2 < stage_full_res.length; idx2++) {
                    //     temp_videos.push({
                    //         method: "Scene B - Diverse Views",
                    //         video: stage_full_res[idx2],
                    //         type: "diverse",
                    //     })
                    // }
                    // videoGroups[index].videos = temp_videos
                }
            }
            
            // videoConfig.videoGroups = videoGroups
            return videoConfig
        }


        // 根据layout字段确定网格样式
        function getGridClassByLayout(layout, videoCount) {
            switch (layout) {
                case "1-column":
                    return 'grid-cols-1';
                case "2-column":
                    return 'grid-cols-1 md:grid-cols-2';
                case "3-column":
                    return 'grid-cols-1 sm:grid-cols-2 lg:grid-cols-3';
                case "4-column":
                    return 'grid-cols-1 sm:grid-cols-2 lg:grid-cols-3 xl:grid-cols-4';
                default:
                    // 自动根据视频数量确定布局
                    if (videoCount === 1) return 'grid-cols-1';
                    if (videoCount === 2) return 'grid-cols-1 md:grid-cols-2';
                    if (videoCount === 3) return 'grid-cols-1 sm:grid-cols-2 lg:grid-cols-3';
                    if (videoCount >= 4) return 'grid-cols-1 sm:grid-cols-2 lg:grid-cols-3 xl:grid-cols-4';
                    return 'grid-cols-1';
            }
        }

        // 生成单个视频项
        function createVideoItem(video, index, totalCount) {
            const videoDiv = document.createElement('div');
            videoDiv.className = 'relative group';
            
            let indexIndicator = '';
            if (totalCount > 1) {
                indexIndicator = `
                    <div class="index-indicator">
                        ${index + 1}/${totalCount}
                    </div>
                `;
            }
            
            videoDiv.innerHTML = `
                ${indexIndicator}
                <div class="overflow-hidden rounded-xl shadow-md hover:shadow-lg transition-all duration-300 transform hover:scale-[1.02] border-2 border-slate-200 hover:border-slate-300 bg-white p-2">
                    <div class="video-container">
                        <video
                            src="${video.video}"
                            controls
                            loop
                            muted
                            autoplay
                            class="w-full h-full object-cover"
                            onerror="this.parentElement.innerHTML='<div class=\\'w-full h-full bg-gray-200 flex items-center justify-center text-gray-600\\'>视频加载失败<br><small>${video.video}</small></div>'"
                        >
                            您的浏览器不支持视频播放。
                        </video>
                    </div>
                </div>
            `;
            
            return videoDiv;
        }

        // 生成视频组
        function createVideoGroup(group, groupIndex) {
            const videoCount = group.videos.length;
            const gridClass = getGridClassByLayout(group.layout, videoCount);
            
            const groupDiv = document.createElement('div');
            groupDiv.className = 'section-card';
            
            // 创建标题部分
            let titleSection = '';
            if (group.title) {
                titleSection = `
                    <div class="section-header">
                        <h2 class="text-xl font-semibold text-white tracking-wide">${group.title}</h2>
                    </div>
                `;
            }
            
            // 创建视频网格容器
            const videoGridDiv = document.createElement('div');
            videoGridDiv.className = `grid ${gridClass} gap-6 p-6`;
            
            // 添加所有视频
            group.videos.forEach((video, index) => {
                const videoItem = createVideoItem(video, index, videoCount);
                videoGridDiv.appendChild(videoItem);
            });
            
            // 创建描述部分
            const descriptionSection = `
                <div class="description-section">
                    <div class="flex items-start space-x-4">
                        <div class="flex-shrink-0 mt-2">
                            <div class="w-2 h-2 bg-gradient-to-r from-slate-500 to-slate-400 rounded-full shadow-sm"></div>
                        </div>
                        <div class="flex-grow">
                            <p class="text-gray-700 leading-relaxed text-sm">
                                <span class="font-semibold text-gray-800">Description:</span> 
                                <span class="italic text-gray-600 ml-1">${group.description}</span>
                            </p>
                        </div>
                    </div>
                </div>
            `;
            
            groupDiv.innerHTML = titleSection + descriptionSection;
            
            // 在描述部分之前插入视频网格
            const descSection = groupDiv.querySelector('.description-section');
            groupDiv.insertBefore(videoGridDiv, descSection);
            
            return groupDiv;
        }

        // 更新页面标题信息
        function updatePageTitle(config) {
            // 更新页面标题
            const pageTitle = document.getElementById('page-title');
            if (pageTitle && config.title) {
                const titleSpan = pageTitle.querySelector('span');
                if (titleSpan) {
                    titleSpan.textContent = config.title;
                }
            }

            // 更新副标题
            const pageSubtitle = document.getElementById('page-subtitle-text');
            if (pageSubtitle && config.subtitle) {
                pageSubtitle.textContent = config.subtitle;
            }

            // 更新描述
            const pageDescription = document.getElementById('page-description');
            if (pageDescription && config.description) {
                pageDescription.textContent = config.description;
            }

            // 更新浏览器标题
            if (config.title) {
                document.title = config.title;
            }
        }

        // 页面加载完成后生成内容
        document.addEventListener('DOMContentLoaded', function() {
            const container = document.getElementById('video-container');
            
            videoConfig = getConfigData();
            console.log(videoConfig)
            // 更新页面标题信息
            updatePageTitle(videoConfig);
            
            // 生成视频组
            videoConfig.videoGroups.forEach((group, index) => {
                const groupElement = createVideoGroup(group, index);
                container.appendChild(groupElement);
            });
            
            console.log('视频内容已通过新的配置数据动态生成');
            console.log('配置结构:', videoConfig);
        });
    </script>
</body>
</html>