232 lines
11 KiB
HTML
232 lines
11 KiB
HTML
<!DOCTYPE html>
|
||
<html lang="zh-CN">
|
||
<head>
|
||
<meta charset="UTF-8">
|
||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||
<title>智能星球计划 - 现实层宇宙全息感知</title>
|
||
<script type="importmap">
|
||
{
|
||
"imports": {
|
||
"three": "https://esm.sh/three@0.128.0",
|
||
"simplex-noise": "https://esm.sh/simplex-noise@4.0.1",
|
||
"satellite.js": "https://esm.sh/satellite.js@5.0.0"
|
||
}
|
||
}
|
||
</script>
|
||
<link rel="stylesheet" href="css/base.css">
|
||
<link rel="stylesheet" href="css/info-panel.css">
|
||
<link rel="stylesheet" href="css/coordinates-display.css">
|
||
<link rel="stylesheet" href="css/legend.css">
|
||
<link rel="stylesheet" href="css/earth-stats.css">
|
||
<link rel="stylesheet" href="https://fonts.googleapis.com/css2?family=Material+Symbols+Rounded:opsz,wght,FILL,GRAD@24,500,0,0">
|
||
</head>
|
||
<body>
|
||
<svg aria-hidden="true" width="0" height="0" style="position:absolute; width:0; height:0; pointer-events:none;">
|
||
<defs>
|
||
<filter id="liquid-glass-distortion" x="-20%" y="-20%" width="140%" height="140%">
|
||
<feTurbulence type="fractalNoise" baseFrequency="0.012 0.02" numOctaves="2" seed="7" result="noise" />
|
||
<feGaussianBlur in="noise" stdDeviation="0.45" result="softNoise" />
|
||
<feDisplacementMap in="SourceGraphic" in2="softNoise" scale="5.5" xChannelSelector="R" yChannelSelector="G" />
|
||
</filter>
|
||
</defs>
|
||
</svg>
|
||
<div id="container">
|
||
<div id="info-panel">
|
||
<h1>智能星球计划</h1>
|
||
<div class="subtitle">
|
||
<span class="subtitle-main">现实层宇宙全息感知系统</span>
|
||
<span class="subtitle-meta">卫星 · 海底光缆 · 算力基础设施</span>
|
||
</div>
|
||
|
||
<div id="info-card" class="info-card" style="display: none;">
|
||
<div class="info-card-header">
|
||
<span class="info-card-icon" id="info-card-icon">🛰️</span>
|
||
<h3 id="info-card-title">详情</h3>
|
||
</div>
|
||
<div id="info-card-content"></div>
|
||
</div>
|
||
|
||
<div id="error-message" class="error-message"></div>
|
||
</div>
|
||
|
||
<div id="right-toolbar-group">
|
||
<div id="control-toolbar">
|
||
<div class="toolbar-items">
|
||
<button id="search-action" class="toolbar-btn floating-btn liquid-glass-surface" title="搜索功能(待开发)">
|
||
<span class="icon" aria-hidden="true">
|
||
<span class="material-symbols-rounded">search</span>
|
||
</span>
|
||
<span class="tooltip">搜索功能(待开发)</span>
|
||
</button>
|
||
<button id="rotate-toggle" class="toolbar-btn floating-btn liquid-glass-surface" title="自动旋转">
|
||
<span class="icon rotate-icon icon-pause" aria-hidden="true">
|
||
<span class="material-symbols-rounded">pause</span>
|
||
</span>
|
||
<span class="icon rotate-icon icon-play" aria-hidden="true">
|
||
<span class="material-symbols-rounded">play_arrow</span>
|
||
</span>
|
||
<span class="tooltip">自动旋转</span>
|
||
</button>
|
||
<div id="info-control-group" class="floating-popover-group">
|
||
<button id="info-trigger" class="toolbar-btn floating-btn liquid-glass-surface" title="显示控制">
|
||
<span class="icon" aria-hidden="true">
|
||
<span class="material-symbols-rounded">info</span>
|
||
</span>
|
||
<span class="tooltip">显示控制</span>
|
||
</button>
|
||
<div id="info-toolbar" class="stack-toolbar">
|
||
<button id="toggle-terrain" class="toolbar-btn floating-btn liquid-glass-surface" title="显示/隐藏地形">
|
||
<span class="icon" aria-hidden="true">
|
||
<span class="material-symbols-rounded">terrain</span>
|
||
</span>
|
||
<span class="tooltip">显示/隐藏地形</span>
|
||
</button>
|
||
<button id="toggle-trails" class="toolbar-btn floating-btn liquid-glass-surface active" title="显示/隐藏轨迹">
|
||
<span class="icon" aria-hidden="true">
|
||
<span class="material-symbols-rounded">timeline</span>
|
||
</span>
|
||
<span class="tooltip">隐藏轨迹</span>
|
||
</button>
|
||
<button id="toggle-satellites" class="toolbar-btn floating-btn liquid-glass-surface" title="显示/隐藏卫星">
|
||
<span class="icon" aria-hidden="true">
|
||
<span class="material-symbols-rounded">satellite_alt</span>
|
||
</span>
|
||
<span class="tooltip">显示卫星</span>
|
||
</button>
|
||
<button id="toggle-bgp" class="toolbar-btn floating-btn liquid-glass-surface active" title="显示/隐藏BGP观测">
|
||
<span class="icon" aria-hidden="true">
|
||
<span class="material-symbols-rounded">radar</span>
|
||
</span>
|
||
<span class="tooltip">隐藏BGP观测</span>
|
||
</button>
|
||
<button id="toggle-cables" class="toolbar-btn floating-btn liquid-glass-surface active" title="显示/隐藏线缆">
|
||
<span class="icon" aria-hidden="true">
|
||
<span class="material-symbols-rounded">cable</span>
|
||
</span>
|
||
<span class="tooltip">隐藏线缆</span>
|
||
</button>
|
||
</div>
|
||
</div>
|
||
<button id="reload-data" class="toolbar-btn floating-btn liquid-glass-surface" title="重新加载数据">
|
||
<span class="icon" aria-hidden="true">
|
||
<span class="material-symbols-rounded">refresh</span>
|
||
</span>
|
||
<span class="tooltip">重新加载数据</span>
|
||
</button>
|
||
<div id="zoom-control-group" class="floating-popover-group">
|
||
<button id="zoom-trigger" class="toolbar-btn floating-btn liquid-glass-surface" title="缩放控制">
|
||
<span class="icon" aria-hidden="true">
|
||
<span class="material-symbols-rounded">zoom_in</span>
|
||
</span>
|
||
<span class="tooltip">缩放控制</span>
|
||
</button>
|
||
<div id="zoom-toolbar" class="stack-toolbar">
|
||
<button id="zoom-in" class="zoom-btn liquid-glass-surface" title="放大">+<span class="tooltip">放大</span></button>
|
||
<span id="zoom-value" class="zoom-percent liquid-glass-surface" title="重置缩放到100%">100%<span class="tooltip">重置缩放到100%</span></span>
|
||
<button id="zoom-out" class="zoom-btn liquid-glass-surface" title="缩小">−<span class="tooltip">缩小</span></button>
|
||
</div>
|
||
</div>
|
||
<button id="reset-view" class="toolbar-btn floating-btn liquid-glass-surface" title="重置视角">
|
||
<span class="icon" aria-hidden="true">
|
||
<span class="material-symbols-rounded">my_location</span>
|
||
</span>
|
||
<span class="tooltip">重置视角</span>
|
||
</button>
|
||
<button id="layout-toggle" class="toolbar-btn floating-btn liquid-glass-surface" title="最大化布局">
|
||
<span class="icon layout-icon layout-expand" aria-hidden="true">
|
||
<span class="material-symbols-rounded">open_in_full</span>
|
||
</span>
|
||
<span class="icon layout-icon layout-collapse" aria-hidden="true">
|
||
<span class="material-symbols-rounded">close_fullscreen</span>
|
||
</span>
|
||
<span class="tooltip">最大化布局</span>
|
||
</button>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
|
||
<div id="coordinates-display">
|
||
<h3 style="color:#4db8ff; margin-bottom:8px; font-size:1.1rem;">坐标信息</h3>
|
||
<div class="coord-item">
|
||
<span class="coord-label">经度:</span>
|
||
<span id="longitude-value" class="coord-value">0.00°</span>
|
||
</div>
|
||
<div class="coord-item">
|
||
<span class="coord-label">纬度:</span>
|
||
<span id="latitude-value" class="coord-value">0.00°</span>
|
||
</div>
|
||
<div id="zoom-level">缩放: 1.0x</div>
|
||
<div class="mouse-coords" id="mouse-coords">鼠标位置: 无</div>
|
||
</div>
|
||
|
||
<div id="legend">
|
||
<h3 class="legend-title">线缆图例</h3>
|
||
<div class="legend-list">
|
||
<div class="legend-item">
|
||
<div class="legend-color" style="background-color: #ff4444;"></div>
|
||
<span>Americas II</span>
|
||
</div>
|
||
<div class="legend-item">
|
||
<div class="legend-color" style="background-color: #44ff44;"></div>
|
||
<span>AU Aleutian A</span>
|
||
</div>
|
||
<div class="legend-item">
|
||
<div class="legend-color" style="background-color: #4444ff;"></div>
|
||
<span>AU Aleutian B</span>
|
||
</div>
|
||
<div class="legend-item">
|
||
<div class="legend-color" style="background-color: #ffff44;"></div>
|
||
<span>其他电缆</span>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
|
||
<div id="earth-stats">
|
||
<h3 style="color:#4db8ff; margin-bottom:10px; font-size:1.1rem;">地球信息</h3>
|
||
<div class="stats-item">
|
||
<span class="stats-label">电缆系统:</span>
|
||
<span class="stats-value" id="cable-count">0个</span>
|
||
</div>
|
||
<div class="stats-item">
|
||
<span class="stats-label">状态:</span>
|
||
<span class="stats-value" id="cable-status-summary">-</span>
|
||
</div>
|
||
<div class="stats-item">
|
||
<span class="stats-label">登陆点:</span>
|
||
<span class="stats-value" id="landing-point-count">0个</span>
|
||
</div>
|
||
<div class="stats-item">
|
||
<span class="stats-label">地形:</span>
|
||
<span class="stats-value" id="terrain-status">开启</span>
|
||
</div>
|
||
<div class="stats-item">
|
||
<span class="stats-label">卫星:</span>
|
||
<span class="stats-value" id="satellite-count">0 颗</span>
|
||
</div>
|
||
<div class="stats-item">
|
||
<span class="stats-label">BGP异常:</span>
|
||
<span class="stats-value" id="bgp-anomaly-count">0 条</span>
|
||
</div>
|
||
<div class="stats-item">
|
||
<span class="stats-label">视角距离:</span>
|
||
<span class="stats-value" id="camera-distance">300 km</span>
|
||
</div>
|
||
<div class="stats-item">
|
||
<span class="stats-label">纹理质量:</span>
|
||
<span class="stats-value" id="texture-quality">8K 卫星图</span>
|
||
</div>
|
||
</div>
|
||
|
||
<div id="loading">
|
||
<div id="loading-spinner"></div>
|
||
<div id="loading-title">正在初始化全球态势数据...</div>
|
||
<div id="loading-subtitle" style="font-size:0.9rem; margin-top:10px; color:#aaa;">同步卫星、海底光缆、登陆点与BGP异常数据</div>
|
||
</div>
|
||
<div id="status-message" class="status-message" style="display: none;"></div>
|
||
<div id="tooltip" class="tooltip"></div>
|
||
</div>
|
||
|
||
<script type="module" src="js/main.js"></script>
|
||
</body>
|
||
</html>
|