有趣的css - 乱转的指北针

大家好,我是 Just,这里是「设计师工作日常」,今天分享的是使用 css 模拟实现搜索图标过渡到输入框的小动效的一个效果。

《有趣的css》系列最新实例通过公众号「设计师工作日常」发布。


目录

  • 整体效果
  • 核心代码
    • html 代码
    • css 部分代码
  • 完整代码如下
    • html 页面
    • css 样式
    • 页面渲染效果

整体效果

知识点:
① css 绘制三角形
② animation 动画属性
③ transform 属性值 rotate 旋转

思路:
使用 css 绘制出指北针,通过 animation 设置动画,分别设置不同关键帧时的 transform 属性值(rotate 值)。


核心代码部分,简要说明了写法思路;完整代码在最后,可直接复制到本地运行。

核心代码

html 代码

<div class="loading40"><span class="one-sj40"></span><span class="two-sj40"></span><span class="round40"></span>
</div>

通过 3 个 span 标签绘制出指北针。

css 部分代码

.loading40{width: 126px;height: 126px;background-color: #000000;border-radius: 50%;position: relative;overflow: hidden;border: 6px solid #FFCA1C;transform: rotate(35deg);animation: zhuan40-eff 6s ease-in-out infinite;box-shadow: inset 0px 0px 2px #ffffff;
}
.one-sj40{border-bottom: 40px solid #FFCA1C;border-left: 16px solid transparent;border-right: 16px solid transparent;position: absolute;top: 22px;left: 47px;
}
.two-sj40{border-top: 40px solid #FFF42B;border-left: 16px solid transparent;border-right: 16px solid transparent;position: absolute;bottom: 22px;left: 47px;
}
.round40{width: 12px;height: 12px;border-radius: 50%;background-color: #000000;position: absolute;top: 57px;left: 57px;z-index: 10;
}
@keyframes zhuan40-eff{0% {transform: rotate(35deg);}30%{transform: rotate(0deg);}45%{transform: rotate(-60deg);}60% {transform: rotate(60deg);}65% {transform: rotate(-30deg);}80%{transform: rotate(100deg);}95%{transform: rotate(-10deg);}100%{transform: rotate(35deg);}
}

1、绘制指南针:
分别绘制一个圆形,以及两个三角形,通过 position 定位组成指北针,再绘制一个黑色圆形背景,一个指北针的圆形图标就绘制完成。

2、然后再给图标整体加上 animation 动画属性,并定义不同关键帧下 transform 属性值,让指北针旋转不同的角度。

完整代码如下

html 页面

<!DOCTYPE html>
<html lang="zh"><head><meta charset="utf-8"><link rel="stylesheet" href="style.css"><title>乱转的指北针</title></head><body><div class="app"><div class="loading40"><span class="one-sj40"></span><span class="two-sj40"></span><span class="round40"></span></div></div></body>
</html>

css 样式

/** style.css **/
.app{width: 100%;height: 100vh;background-color: #ffffff;position: relative;display: flex;justify-content: center;align-items: center;
}
.loading40{width: 126px;height: 126px;background-color: #000000;border-radius: 50%;position: relative;border: 6px solid #FFCA1C;transform: rotate(35deg);animation: zhuan40-eff 6s ease-in-out infinite;box-shadow: inset 0px 0px 2px #ffffff;
}
.one-sj40{border-bottom: 40px solid #FFCA1C;border-left: 16px solid transparent;border-right: 16px solid transparent;position: absolute;top: 22px;left: 47px;
}
.two-sj40{border-top: 40px solid #FFF42B;border-left: 16px solid transparent;border-right: 16px solid transparent;position: absolute;bottom: 22px;left: 47px;
}
.round40{width: 12px;height: 12px;border-radius: 50%;background-color: #000000;position: absolute;top: 57px;left: 57px;z-index: 10;
}
@keyframes zhuan40-eff{0% {transform: rotate(35deg);}30%{transform: rotate(0deg);}45%{transform: rotate(-60deg);}60% {transform: rotate(60deg);}65% {transform: rotate(-30deg);}80%{transform: rotate(100deg);}95%{transform: rotate(-10deg);}100%{transform: rotate(35deg);}
}

页面渲染效果

以上就是所有代码,以及简单的思路,希望对你有一些帮助或者启发。


[1] 原文阅读


CSS 是一种很酷很有趣的计算机语言,在这里跟大家分享一些 CSS 实例 Demo,为学习者获取灵感和思路提供一点帮助,希望你们喜欢。

我是 Just,这里是「设计师工作日常」,求点赞求关注!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/568614.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

MySQL进阶-----索引的结构与分类

目录 前言 一、认识索引 二、索引结构 1.概述 2. 二叉树 3 .B-Tree 4.BTree 5.Hash 三、索引的分类 1 .索引分类 2 .聚集索引&二级索引 前言 索引&#xff08;index&#xff09;是帮助MySQL高效获取数据的数据结构(有序)。在数据之外&#xff0c;数据库系统还维…

【第十二届“泰迪杯”数据挖掘挑战赛】【2024泰迪杯】B题基于多模态特征融合的图像文本检索—解题全流程(持续更新)

2024 年(第 12 届)“泰迪杯”数据挖掘挑战赛B题 解题全流程&#xff08;持续更新&#xff09; -----基于多模态特征融合的图像文本检索 一、写在前面&#xff1a; ​ 本题的全部资料打包为“全家桶”&#xff0c; “全家桶”包含&#xff1a;模型数据、全套代码、训练好的模…

【zlm】问题记录:chrome更新引起的拉不出webrtc; 证书校验引起的放几秒中断

目录 chrome更新引起的拉不出webrtc 证书校验引起的放几秒中断 chrome更新引起的拉不出webrtc 【zlm】最新的chrome版本中的报错&#xff1a; 我有个问题event.js:8 [RTCPusherPlayer] DOMException: Failed to execute setRemoteDescription on RTCPeerConnection: Failed …

web全栈架构师第16期教程

教程介绍 互联网时代已进入后半场&#xff0c;行业环境发生了显著变化。互联网人&#xff0c;尤其是技术人员&#xff0c;如何在加速更迭的技术浪潮中持续充电&#xff0c;提升自身价值&#xff0c;是当下必须面对的挑战。课程涉及了现下前端实际开发时所需要的各块内容&#…

【力扣刷题日记】1082.销售分析I

前言 练习sql语句&#xff0c;所有题目来自于力扣&#xff08;https://leetcode.cn/problemset/database/&#xff09;的免费数据库练习题。 今日题目&#xff1a; 1082.销售分析I 表&#xff1a;Person 列名类型product_idintproduct_namevarcharunit_priceint product_i…

MySQL-记

目录 数据库的三范式 MySQL数据库引擎 InnoDB与MyISAM的区别 数据库的事务 索引 SQL优化手段 drop、delete与truncate 视图 内联接、左外联接、右外联接 并发事务带来的问题 大表优化 1. 限定数据的范围 2. 读/写分离 3. 垂直分区 4. 水平分区 在 MySQL 中一条查…

09 网络ARP请求,响应,ICMP协议

arp协议_arp请求_arp回应 ICMP包构造ping搜狐服务器参考 #include <stdio.h> #include <sys/types.h> /* See NOTES */ #include <sys/socket.h> #include <linux/if_packet.h> #include <linux/if_ether.h> #include <string.h> #includ…

我天,太好看了吧!还是响应式的手机也能用,一款超棒的宣传网站,都能当公司主页了。快来学习学习吧!

《你给我做个公司宣传页&#xff0c;明天下班交&#xff0c;没问题吧&#xff1f;》《你去把唐僧师徒除掉》 大家不知道有没有接到过这些离谱的任务&#xff1f;老板&#xff0c;你咋不让我上天呢&#xff1f; 这个时候&#xff0c;就应该祭出程序员的大杀器&#xff01;我们来…

数据结构-树-006

1二叉树 1.1目标二叉树 前序遍历&#xff1a;ABDHIEJCFKG 中序遍历&#xff1a;HDIBEJAFKCG 后序遍历&#xff1a;HIDJEBKFGCA 层序遍历&#xff1a;ABCDEFGHIJK运行结果&#xff1a; 运行结果符合目标二叉树的深度优先&#xff08;前序遍历&#xff0c;中序遍历&#xff0c;…

APP软件开发是选择iOS还是Android两者的优势是什么

在选择开发iOS还是Android应用程序时&#xff0c;开发者需要考虑多方面因素&#xff0c;包括目标用户群体、市场份额、开发成本和技术要求等。下面将从不同角度对iOS和Android应用程序开发进行比较&#xff0c;并提供关于选择的建议。 一.用户群体与市场份额&#xff1a; 1.iOS…

Pandoc下载和安装笔记

目录 一、下载 二、安装 1、安装软件 2、测试是否安装成功 Pandoc 的作者是 John MacFarlane&#xff0c;John MacFarlane是美国加州大学伯克利分校的哲学系的一位教授。编写Pandoc 用来生成讲义、课件和网站等。程序开源免费&#xff0c;目前以 GPL 协议托管在 Github 网站…

电脑控制面板在哪?5招教你快速打开!

“我在执行一个任务时要进入电脑的控制面板中查看&#xff0c;但是我不知道电脑的控制面板在哪&#xff0c;谁能帮帮我呀&#xff1f;” 电脑控制面板是一个系统文件夹&#xff0c;它提供了各种对计算机系统进行设置和管理的工具。控制面板允许用户查看并操作基本的系统设置&am…