css3动画—实现上拉提示指针动画

今天要实现的内容如下图所示:

有了css3的动画属性,实现起来非常的简单。

html布局:

<div class="pointer">
   <p></p>
</div>

让.pointer的div放在你想要他显示方,p放的是指针箭头图的地片,而.pointer的div是盒子,因为裹这个箭头的盒要实现向上移动的效果,所以div的高度要比箭头高度高出10px。

css样式:

.pointer{
    position: absolute;
    height: 3.8rem;
    bottom: 3rem;
    width: 100%;
}
.pointer p{
    animation: anima-pointer 2s infinite;
    position: absolute;
    bottom: 0;
    left: 50%;
    margin-left: -1.4rem;
    height: 2.8rem;
    width: 2.8rem;
    background: url("../images/css-sprites.png") -63px 0;
}

/*animation*/
@keyframes anima-pointer
{
    0%   {opacity:0;bottom:0}
    100%  {opacity:
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 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
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值