LLM-test/test/clock/minimax-2.1-web.html

202 lines
6.6 KiB
HTML

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Responsive Analog Clock</title>
<style>
* {
margin: 0;
padding: 0;
box-sizing: border-box;
}
body {
height: 100vh;
display: flex;
justify-content: center;
align-items: center;
background-color: #f0f2f5;
font-family: 'Arial', sans-serif;
}
.clock-container {
position: relative;
width: min(90vmin, 400px);
height: min(90vmin, 400px);
}
.clock {
position: relative;
width: 100%;
height: 100%;
background-color: #ffffff;
border-radius: 50%;
box-shadow: 0 10px 25px rgba(0, 0, 0, 0.1);
border: 2px solid #e0e0e0;
}
.clock-face {
position: relative;
width: 100%;
height: 100%;
border-radius: 50%;
}
.number {
position: absolute;
width: 30px;
height: 30px;
text-align: center;
line-height: 30px;
font-size: 1.2rem;
font-weight: bold;
color: #333;
left: 50%;
top: 50%;
transform-origin: center;
}
.number1 { transform: translate(-50%, -50%) rotate(30deg) translateY(-35%) rotate(-30deg); }
.number2 { transform: translate(-50%, -50%) rotate(60deg) translateY(-35%) rotate(-60deg); }
.number3 { transform: translate(-50%, -50%) rotate(90deg) translateY(-35%) rotate(-90deg); }
.number4 { transform: translate(-50%, -50%) rotate(120deg) translateY(-35%) rotate(-120deg); }
.number5 { transform: translate(-50%, -50%) rotate(150deg) translateY(-35%) rotate(-150deg); }
.number6 { transform: translate(-50%, -50%) rotate(180deg) translateY(-35%) rotate(-180deg); }
.number7 { transform: translate(-50%, -50%) rotate(210deg) translateY(-35%) rotate(-210deg); }
.number8 { transform: translate(-50%, -50%) rotate(240deg) translateY(-35%) rotate(-240deg); }
.number9 { transform: translate(-50%, -50%) rotate(270deg) translateY(-35%) rotate(-270deg); }
.number10 { transform: translate(-50%, -50%) rotate(300deg) translateY(-35%) rotate(-300deg); }
.number11 { transform: translate(-50%, -50%) rotate(330deg) translateY(-35%) rotate(-330deg); }
.number12 { transform: translate(-50%, -50%) rotate(360deg) translateY(-35%) rotate(-360deg); }
.hand {
position: absolute;
bottom: 50%;
left: 50%;
transform-origin: bottom center;
transform: translateX(-50%) rotate(0deg);
transition: transform 0.1s cubic-bezier(0.4, 0, 0.2, 1);
}
.hour-hand {
width: 6px;
height: 25%;
background-color: #333;
border-radius: 3px;
z-index: 3;
}
.minute-hand {
width: 4px;
height: 35%;
background-color: #333;
border-radius: 2px;
z-index: 2;
}
.second-hand {
width: 2px;
height: 40%;
background-color: #e74c3c;
border-radius: 1px;
z-index: 1;
transition: transform 0.05s cubic-bezier(0.4, 0, 0.2, 1);
}
.center-dot {
position: absolute;
top: 50%;
left: 50%;
width: 16px;
height: 16px;
background-color: #333;
border-radius: 50%;
transform: translate(-50%, -50%);
z-index: 4;
}
.center-dot::before {
content: '';
position: absolute;
top: 50%;
left: 50%;
width: 8px;
height: 8px;
background-color: #ffffff;
border-radius: 50%;
transform: translate(-50%, -50%);
}
@media (max-width: 480px) {
.number {
font-size: 1rem;
width: 25px;
height: 25px;
line-height: 25px;
}
.hour-hand {
width: 5px;
}
.minute-hand {
width: 3px;
}
.second-hand {
width: 1.5px;
}
}
</style>
</head>
<body>
<div class="clock-container">
<div class="clock">
<div class="clock-face">
<div class="number number1">1</div>
<div class="number number2">2</div>
<div class="number number3">3</div>
<div class="number number4">4</div>
<div class="number number5">5</div>
<div class="number number6">6</div>
<div class="number number7">7</div>
<div class="number number8">8</div>
<div class="number number9">9</div>
<div class="number number10">10</div>
<div class="number number11">11</div>
<div class="number number12">12</div>
<div class="hand hour-hand"></div>
<div class="hand minute-hand"></div>
<div class="hand second-hand"></div>
<div class="center-dot"></div>
</div>
</div>
</div>
<script>
function updateClock() {
const now = new Date();
const hours = now.getHours() % 12;
const minutes = now.getMinutes();
const seconds = now.getSeconds();
const milliseconds = now.getMilliseconds();
// Calculate angles
const hourAngle = (hours * 30) + (minutes * 0.5) + (seconds * 0.008333);
const minuteAngle = (minutes * 6) + (seconds * 0.1) + (milliseconds * 0.000166667);
const secondAngle = (seconds * 6) + (milliseconds * 0.006);
// Apply rotations
document.querySelector('.hour-hand').style.transform = `translateX(-50%) rotate(${hourAngle}deg)`;
document.querySelector('.minute-hand').style.transform = `translateX(-50%) rotate(${minuteAngle}deg)`;
document.querySelector('.second-hand').style.transform = `translateX(-50%) rotate(${secondAngle}deg)`;
}
// Update clock immediately and then every millisecond for smooth movement
updateClock();
setInterval(updateClock, 1);
</script>
</body>
</html>