css实现—时钟动画效果

1实现效果请添加图片描述

二、源码:


<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title>时钟</title>
		<style>
			*{
				margin: 0;
				padding: 0;
			}/* 清楚默认效果 */
			.clock{
				width: 350px;
				height: 350px;
				margin: 30px auto;
				border-radius:50%;
				border: 3px black solid;
				position: relative;
				background-image: url(../时钟背景.jpg);
				background-size: cover;
			}/* 设置时钟外表和相对定位 */
			.clock > div{
				position: absolute;
				top: 0;
				bottom: 0;
				left: 0;
				right: 0;
				margin: auto;
			}/* 设置时钟的直接子元素居中 */
			/* 小时 */
			.hour-warpper{
				width: 70%;
				height: 70%;
				animation: run 43200s linear infinite ;
			}
			.hour{
				height: 50%;
				width:7px;
				background-color: black;
				margin: 0 auto;/* 图片原因,导致中心偏下 */
			}
			/* 分钟 */
			.min-warpper{
				height: 80%;
				width: 80%;
			    animation: run 3600s infinite ;
			}
			.min{
				margin: 0 auto;
				height: 50%;
				width: 3px;
				background-color: blue;
			}
			/* 秒钟 */
			.sec-warpper{
				width: 90%;
				height: 90%;	
				animation: run 60s infinite steps(60);
			}
			.sec{
				margin: 0 auto;
				height: 50%;
				width: 2px;
				background-color: red;	
			}
			/* 动画 */
			@keyframes run{
				from{
					transform: rotateZ(0);
				}
				to{
					transform: rotateZ(1turn);
				}
			}
		</style>
	</head>
	<body>
		<div class="clock">
			<div class="hour-warpper">
				<div class="hour">
				</div>
			</div>
			
			<div class="min-warpper">
				<div class="min">
				</div>
			</div>
			<div class="sec-warpper">
				<div class="sec"></div>
			</div>
		</div>
	</body>
</html>

不喜勿噴。

  • 4
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
可以使用CSS的`transform`和`transition`属性来实现苹果表盘动画。 首先,需要将表盘的每个数字和指针都用`<div>`元素来表示,并设置好对应的样式。 然后,使用`transform: rotate()`将每个数字和指针旋转到对应的位置。同时,使用`transition`属性来设置动画的过渡效果。 最后,使用JavaScript来控制表盘指针的旋转,从而实现动态的表盘动画效果。 以下是一个基本的示例代码: HTML: ``` <div class="watch"> <div class="number number-1">1</div> <div class="number number-2">2</div> <div class="number number-3">3</div> <div class="number number-4">4</div> <div class="number number-5">5</div> <div class="number number-6">6</div> <div class="number number-7">7</div> <div class="number number-8">8</div> <div class="number number-9">9</div> <div class="number number-10">10</div> <div class="number number-11">11</div> <div class="number number-12">12</div> <div class="hour-hand"></div> <div class="minute-hand"></div> <div class="second-hand"></div> </div> ``` CSS: ``` .watch { position: relative; width: 200px; height: 200px; border: 10px solid #000; border-radius: 50%; margin: 50px auto; box-shadow: inset 0 0 10px rgba(0, 0, 0, .5); } .number { position: absolute; font-size: 20px; font-weight: bold; text-align: center; width: 20px; height: 20px; margin-left: -10px; margin-top: -10px; } .number-1 { top: 20px; left: 90px; } .number-2 { top: 40px; left: 140px; } .number-3 { top: 90px; left: 170px; } .number-4 { top: 140px; left: 140px; } .number-5 { top: 160px; left: 90px; } .number-6 { bottom: 20px; left: 90px; } .number-7 { bottom: 20px; left: 40px; } .number-8 { top: 160px; left: 10px; } .number-9 { top: 90px; left: 0; } .number-10 { top: 40px; left: 10px; } .number-11 { top: 20px; left: 40px; } .number-12 { top: 70px; left: 90px; } .hour-hand, .minute-hand, .second-hand { position: absolute; width: 2px; height: 60px; background: #000; left: 99px; top: 70px; transform-origin: bottom center; transition: all .5s ease-in-out; } .hour-hand { height: 50px; } .minute-hand { height: 70px; } .second-hand { height: 80px; background: red; } /* 旋转每个数字到对应的位置 */ .number { transform: rotate(30deg); } .number-1 { transform: rotate(30deg); } .number-2 { transform: rotate(60deg); } .number-3 { transform: rotate(90deg); } .number-4 { transform: rotate(120deg); } .number-5 { transform: rotate(150deg); } .number-6 { transform: rotate(180deg); } .number-7 { transform: rotate(210deg); } .number-8 { transform: rotate(240deg); } .number-9 { transform: rotate(270deg); } .number-10 { transform: rotate(300deg); } .number-11 { transform: rotate(330deg); } .number-12 { transform: rotate(0); } ``` JavaScript: ``` function setClock() { const now = new Date(); const seconds = now.getSeconds(); const minutes = now.getMinutes(); const hours = now.getHours(); const secondHand = document.querySelector('.second-hand'); const minuteHand = document.querySelector('.minute-hand'); const hourHand = document.querySelector('.hour-hand'); const secondDegrees = ((seconds / 60) * 360) + 90; const minuteDegrees = ((minutes / 60) * 360) + 90; const hourDegrees = ((hours / 12) * 360) + 90; secondHand.style.transform = `rotate(${secondDegrees}deg)`; minuteHand.style.transform = `rotate(${minuteDegrees}deg)`; hourHand.style.transform = `rotate(${hourDegrees}deg)`; } setInterval(setClock, 1000); ``` 这段代码实现了一个简单的时钟表盘动画,可以根据实际需求进行修改和优化。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

学徒在修行

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值