svg+css+js实现车站汽车发车时间表卡片代码
代码语言:html
所属分类:布局界面
代码描述:svg+css+js实现车站汽车发车时间表卡片代码,可显示所有时间表,默认显示当前时间的下一班次发车时间。
代码标签: svg css js 车站 汽车 发车 时间表 卡片 代码
下面为部分代码预览,完整代码请点击下载或在bfwstudio webide中打开
<!DOCTYPE html>
<html lang="en" >
<head>
<meta charset="UTF-8">
<script type="text/javascript" src="//repo.bfw.wiki/bfwrepo/js/tailwindcss.3.4.16.js"></script>
<link href="https://fonts.googleapis.com/css2?family=Fira+Code:wght@400;500;600&display=swap" rel="stylesheet">
<style>
body {
font-family: "Fira Code", monospace;
background-color: #111827; /* Darker Slate Gray */
color: #d1d5db; /* Light Gray */
display: flex;
justify-content: center;
align-items: center;
min-height: 100vh;
padding: 1rem;
overflow: hidden;
}
.dashboard-widget {
border: 1px solid #4b5563;
width: 100%;
max-width: 500px;
transition: background-color 0.5s ease, border-color 0.5s ease;
position: relative;
overflow: hidden;
}
#background-canvas {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
z-index: 0; /* Behind the content */
}
.content-wrapper {
position: relative;
z-index: 1;
background-color: rgba(17, 24, 39, 0.6); /* Made overlay more transparent */
backdrop-filter: blur(6px); /* Reduced blur effect */
}
.schedule-section {
transition: opacity 0.4s ease-in-out;
cursor: pointer;
-webkit-tap-highlight-color: transparent;
}
.primary {
opacity: 1;
}
.secondary {
opacity: 0.4;
}
.secondary:hover {
opacity: 0.7;
}
.next-time-glow {
text-shadow: 0 0 10px rgba(34, 197, 94, 0.5);
}
.header-glow {
text-shadow: 0 0 10px rgba(59, 130, 246, 0.4);
}
.view-container {
transition: max-height 0.5s ease-in-out, opacity 0.3s ease-in-out;
overflow: hidden;
}
/* Dev Tools */
.dev-tools {
transition: transform 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
transform: translateX(110%);
}
.range-slider {
-webkit-appearance: none;
width: 100%;
height: 10px;
border-radius: 5px;
background: #374151;
outline: none;
padding: 0;
margin: 0;
}
.range-slider::-webkit-slider-thumb {
-webkit-appearance: none;
appearance: none;
width: 20px;
height: 20px;
border-radius: 50%;
background: #3b82f6;
cursor: pointer;
transition: background 0.15s ease-in-out;
}
.range-slider::-webkit-slider-thumb:hover {
background: #60a5fa;
}
.range-slider::-moz-range-thumb {
width: 20px;
height: 20px;
border: 0;
border-radius: 50%;
background: #3b82f6;
cursor: pointer;
transition: background 0.15s ease-in-out;
}
.range-slider::-moz-range-thumb:hover {
background: #60a5fa;
}
/* Date Picker */
.date-picker-modal {
transition: opacity 0.2s ease-in-out;
}
.calendar-day:not(.disabled):hover {
background-color: #3b82f6;
color: white;
}
.calendar-day.selected {
background-color: #2563eb;
color: white;
}
.calendar-day.disabled {
color: #4b5563;
cursor: not-allowed;
}
/* Schedule Column Hover */
.schedule-column:hover {
background-color: rgba(75, 85, 99, 0.2);
}
/* Hierarchy Styles */
.primary .next-time {
font-size: 2.25rem;
line-height: 2.5rem;
}
.primary .arrival-time {
font-size: 1rem;
line-height: 1.5rem;
opacity: 0.8;
}
.primary .countdown {
display: block;
font-size: 1.125rem;
line-height: 1.75rem;
}
.secondary .next-time {
font-size: 1.5rem;
line-height: 2rem;
color: #9ca3af;
}
.secondary .arrival-time {
font-size: 0.875rem;
line-height: 1.25rem;
opacity: 0.6;
}
.secondary .countdown {
display: none;
}
/* Kraken Easter Egg Theme */
.kraken-theme #background-canvas {
display: none; /* Hide water canvas during kraken */
}
.kraken-theme .content-wrapper {
background-color: rgba(13, 37, 56, 0.9) !important;
}
.kraken-theme {
border-color: #17a2b8 !important;
}
.kraken-theme * {
color: #17a2b8 !important;
text-shadow: 0 0 5px #17a2b8;
}
.kraken-theme a,
.kraken-theme .primary,
.kraken-theme .calendar-day.selected,
.kraken-theme .range-slider::-webkit-slider-thumb {
border-color: #17a2b8 !important;
background-color: #0d2538 !important;
}
.kraken-theme svg {
fill: #17a2b8 !important;
}
#kraken-tentacles {
position: absolute;
bottom: -150px; /* Start hidden */
left: 0;
width: 100%;
height: 150px;
pointer-events: none;
transition: transform 1.5s cubic-bezier(0.68, -0.55, 0.27, 1.55);
z-index: 2;
}
#kraken-tentacles.active {
transform: translateY(-150px);
}
</style>
</head>
<body translate="no">
<div class="flex flex-col items-center">
<div class="dashboard-widget rounded-xl shadow-2xl">
<canvas id="background-canvas"></canvas>
<div class="content-wrapper">
<header class="relative p-4 border-b border-gray-700/50">
<div id="progress-container" class="absolute top-0 left-0 w-full h-1 bg-gray-700 hidden">
<div id="progress-bar" class="h-full bg-blue-500 transition-all duration-1000 ease-linear"></div>
</div>
<div class="flex items-center justify-between">
<h1 class="text-lg font-semibold header-glow text-blue-300 cursor-pointer">WS Ferry</h1>
<div class="flex items-center space-x-2">
<button id="todayBtn" class="text-gray-400 hover:text-white transition-colors hidden" title="Reset to Today">
<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" fill="currentColor" viewBox="0 0 16 16">
<path fill-ru.........完整代码请登录后点击上方下载按钮下载查看
















网友评论0