HTML与CSS实现风车旋转图形的代码技术详解

在前端开发中,HTML和CSS是构建网页的基础技术。通过巧妙运用HTML的结构搭建和CSS的样式控制,我们能够实现各种精美的视觉效果。本文将对一段实现旋转图形效果的HTML和CSS代码进行详细解读,剖析其中的技术要点。

一、运行效果

HTML与CSS实现风车旋转图形

二、整体代码结构分析

上述代码由HTML和CSS两部分组成。HTML部分构建页面的基本结构,CSS部分则负责定义样式和动画效果。

1. HTML结构

<body><div class="main"><div class="white_circle"></div><div class="fla fla_one"><div class="squ squ_one"></div><div class="tri tri_one"></div></div><div class="fla fla_two"><div class="squ squ_two"></div><div class="tri tri_two"></div></div><div class="fla fla_three"><div class="squ squ_three"></div><div class="tri tri_three"></div></div><div class="fla fla_four"><div class="squ squ_four"></div><div class="tri tri_four"></div></div></div>
</body>

在HTML的<body>标签内,最外层是一个类名为main<div>元素,它作为整个图形的容器。内部包含了一个白色圆形(white_circle类)和四个不同的图形组合(fla类及其子元素)。每个图形组合又由一个矩形(squ类)和一个三角形(tri类)组成,通过不同的类名区分各自的样式和旋转角度。

2. CSS样式

CSS部分被包含在HTML的<head>标签内的<style>标签中,用于设置各个元素的样式和动画效果。

* {margin: 0;padding: 0;
}

*通配符选择器将所有元素的marginpadding设置为0,这是为了消除浏览器默认的内外边距,保证页面布局的一致性。

三、关键样式解析

1. 容器样式

.main {width: 804px;height: 804px;animation: roll 3000ms linear infinite;
}

类名为main的元素定义了容器的宽高均为804px,并应用了名为roll的动画。动画持续时间为3000ms(即3秒),以linear线性的速度播放,并且infinite无限循环。

2. 动画定义

@keyframes roll {0% {transform: rotate(0deg);}100% {transform: rotate(-360deg);}
}

@keyframes规则定义了名为roll的动画。在动画的起始阶段(0%),元素的旋转角度为0度;在结束阶段(100%),元素旋转-360度,负号表示逆时针旋转,从而实现图形的持续旋转效果。

3. 白色圆形样式

.white_circle {z-index: 99;position: absolute;width: 50px;height: 50px;border-radius: 50px;background-color: white;margin: 377px 0 0 377px;
}

white_circle类定义了一个白色圆形。z-index: 99将其置于较高的层叠顺序,使其显示在其他图形之上。position: absolute使其脱离文档流进行绝对定位,通过margin属性精确设置其在容器中的位置。border-radius: 50px将方形元素转换为圆形,background-color: white设置其背景颜色为白色。

4. 图形组合样式

.fla {position: absolute;width: 402px;height: 180px;
}

fla类定义了图形组合的基本样式,设置为绝对定位,并指定了宽高。

.fla_one {transform: rotate(270deg);margin:108px 0px 0px 121px;
}
.fla_two {transform: rotate(180deg);margin-top: 389px;
}
.fla_three {transform: rotate(90deg);margin: 511px 0 0 280px;
}
.fla_four {transform: rotate(360deg);margin: 230px 0 0 402px;
}

这些类通过transform: rotate()属性分别设置了不同的旋转角度,并且通过margin属性调整其在容器中的位置,使得四个图形组合围绕中心均匀分布。

5. 三角形样式

.tri {width: 0;height: 0;border-width: 142px;border-style: solid;border-top-left-radius: 109px 122px;position: absolute;transform: rotate(45deg);top: 28px;left: 56px;
}

tri类通过设置border属性创建了一个三角形。widthheight设置为0,通过不同方向的边框颜色和宽度来形成三角形形状。border-top-left-radius属性为三角形的左上角添加圆角效果。position: absolute配合topleft属性确定其在父元素中的位置,transform: rotate(45deg)对三角形进行旋转。

.tri_one {border-color: #F1C40F transparent transparent #F1C40F;
}
.tri_two {border-color: #EA4C3C transparent transparent #EA4C3C;
}
.tri_three {border-color: #2ECC71 transparent transparent #2ECC71;
}
.tri_four {border-color: #1ABC9C transparent transparent #1ABC9C;
}

这些类分别设置了不同三角形的边框颜色,通过调整颜色值实现图形的区分。

6. 矩形样式

.squ {position: absolute;width: 271px;height: 170px;border-top-right-radius: 98px 68px;
}

squ类定义了矩形的基本样式,通过border-top-right-radius属性为矩形的右上角添加圆角效果。

.squ_one {background-color: #F39C12;
}
.squ_two {background-color: #C0392B;
}
.squ_three {background-color: #27AE60;
}
.squ_four {background-color: #16A085;
}

这些类分别设置了不同矩形的背景颜色,进一步丰富图形的视觉效果。

四、完整代码


<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><meta http-equiv="X-UA-Compatible" content="ie=edge"><title>Document</title><style>*{margin: 0;padding: 0;}.main{width: 804px;height: 804px;animation: roll 3000ms linear infinite;}@keyframes roll{0%{transform: rotate(0deg);}100%{transform: rotate(-360deg);}}.white_circle{z-index: 99;position: absolute;width: 50px;height: 50px;border-radius: 50px;background-color: white;margin: 377px 0 0 377px;}.fla{position: absolute;width: 402px;height: 180px;}.fla_one{transform: rotate(270deg);margin:108px 0px 0px 121px;}.fla_two{transform: rotate(180deg);margin-top: 389px;}.fla_three{transform: rotate(90deg);margin: 511px 0 0 280px;}.fla_four{transform: rotate(360deg);margin: 230px 0 0 402px;}.tri{width: 0;height: 0;border-width: 142px;border-style: solid;border-top-left-radius: 109px 122px;position: absolute;transform: rotate(45deg);top: 28px;left: 56px;}.tri_one {border-color: #F1C40F transparent transparent #F1C40F;}.tri_two {border-color: #EA4C3C transparent transparent #EA4C3C;}.tri_three {border-color: #2ECC71 transparent transparent #2ECC71;}.tri_four {border-color: #1ABC9C transparent transparent #1ABC9C;}.squ{position: absolute;width: 271px;height: 170px;border-top-right-radius: 98px 68px;}.squ_one{background-color: #F39C12;}.squ_two{background-color: #C0392B;}.squ_three{background-color: #27AE60;}.squ_four{background-color: #16A085;}</style>
</head>
<body><div class="main"><div class="white_circle"></div><div class="fla fla_one"><div class="squ squ_one"></div><div class="tri tri_one"></div></div><div class="fla fla_two"><div class="squ squ_two"></div><div class="tri tri_two"></div></div><div class="fla fla_three"><div class="squ squ_three"></div><div class="tri tri_three"></div></div><div class="fla fla_four"><div class="squ squ_four"></div><div class="tri tri_four"></div></div></div>
</body>
</html>

五、总结与拓展

通过对上述代码的详细解读,我们了解了如何利用HTML的结构搭建和CSS的样式与动画控制,实现一个旋转的图形效果。从整体布局到各个元素的样式细节,每一个属性的设置都对最终效果起到关键作用。

在实际开发中,我们可以基于此代码进行更多的拓展和创新。例如,修改动画的速度、方向和循环次数,调整图形的颜色和形状,甚至结合JavaScript实现更复杂的交互效果。掌握这些基础的前端技术,将有助于我们打造出更加精彩的网页界面。

希望本文的讲解能够帮助你更好地理解和运用HTML与CSS,如果你在实践过程中有任何疑问或新的想法,欢迎在评论区交流讨论。

以上从多方面解析了代码。你若对代码的优化、功能拓展感兴趣,或想了解更多相关技术,欢迎随时和我说。

上述讲解涵盖了代码的各个关键部分。如果你想了解代码的优化方向,或者有其他特定的技术疑问,欢迎随时和我交流。

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

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

相关文章

linux下,ollama会把模型文件保存在哪里?

文章目录 运行ollama,有两种形式,估计得分开讨论首先是使用自动启动的ollama:先跑个“小一点的大模型”但是现在模型文件存在哪儿呢?运行ollama,有两种形式,估计得分开讨论 我们用两种方式,来运行ollama。 首先是使用自动启动的ollama: ps -aux | grep ollama系统自…

鼎讯信通 智能通信干扰设备:多频段多模态信号压制解决方案

在万物互联时代&#xff0c;通信安全已成为现代社会的核心基础设施防护重点。面对日益复杂的电磁环境挑战&#xff0c;新一代智能通信干扰设备通过技术创新实现了信号压制能力的革命性突破。本文将深入解析该设备的八大核心功能与技术特性&#xff0c;展现其在商业通信保障、工…

【2025软考高级架构师】——案例分析总结(13)

摘要 本文对2025年软考高级架构师的考纲及案例分析进行了总结。内容涵盖系统规划、架构设计、系统建模、安全架构、可靠性分析、大数据架构等多方面知识点&#xff0c;还涉及软件质量特性、系统流程图与数据流图、嵌入式系统架构、分布式系统设计等考查内容&#xff0c;详细列…

js单调栈解题模板

模板 function solve(arr) {const stack [];const result new Array(arr.length).fill(默认值);for (let i 0; i < arr.length; i) {while (stack.length && 比较条件(arr[i], arr[栈顶])) {const top stack.pop();result[top] 计算结果(i, top); }stack.push…

[蓝桥杯真题题目及解析]2025年C++b组

移动距离&#xff08;填空&#xff09;** 小明初始在二维平面的原点&#xff0c;他想前往坐标 (233,666)。在移动过程中&#xff0c;他只能采用以下两种移动方式&#xff0c;并且这两种移动方式可以交替、不限次数地使用&#xff1a; 水平向右移动&#xff0c;即沿着 x 轴正方…

【ICMP协议深度解析】从网络诊断到安全实践

目录 前言技术背景与价值当前技术痛点解决方案概述目标读者说明 一、技术原理剖析核心概念图解核心作用讲解关键报文类型说明协议版本对比 二、实战演示环境配置要求核心实验实现实验1&#xff1a;标准ping流程实验2&#xff1a;traceroute路径发现实验3&#xff1a;自定义ICMP…

安卓基础(悬浮窗分级菜单和弹窗)

initializeViews() 初始化 把全部的按钮都弄出来 // 主菜单按钮ImageButton mainButton floatingMenuView.findViewById(R.id.main_button);// 二级菜单按钮subButtons new ImageButton[3];subButtons[0] floatingMenuView.findViewById(R.id.sub_button_1);subButtons[1]…

冯·诺依曼体系:现代计算机的底层逻辑与百年传承

在智能手机流畅运行复杂游戏、超级计算机模拟气候变化的今天&#xff0c;很少有人会想到&#xff0c;驱动这些神奇机器运转的核心架构&#xff0c;依然遵循着70多年前提出的设计理念。这就是由匈牙利裔美国科学家约翰冯诺依曼&#xff08;John von Neumann&#xff09;奠定的冯…

【云备份】服务端工具类实现

1.文件实用工具类设计 不管是客户端还是服务端&#xff0c;文件的传输备份都涉及到文件的读写&#xff0c;包括数据管理信息的持久化也是如此&#xff0c;因此首先设 计封装文件操作类&#xff0c;这个类封装完毕之后&#xff0c;则在任意模块中对文件进行操作时都将变的简单化…

CGI 协议是否会具体到通讯报文?

CGI&#xff08;Common Gateway Interface&#xff09;不涉及具体的网络通讯报文格式&#xff0c;它定义的是 Web服务器与外部程序之间的数据交互方式&#xff0c;而不是像HTTP或FastCGI那样的二进制协议。下面分几个方面详细说明&#xff1a; 1. CGI 的交互方式&#xff08;非…

【Mytais系列】Type模块:类型转换

MyBatis 的 类型系统&#xff08;Type System&#xff09; 是框架处理 Java 类型与数据库类型之间映射的核心模块&#xff0c;它通过 类型处理器&#xff08;TypeHandler&#xff09;、类型别名&#xff08;TypeAlias&#xff09; 和 类型转换器 等机制&#xff0c;实现了数据库…

新华三H3CNE网络工程师认证—动态NAT

静态NAT严格地一对一进行地址映射&#xff0c;这就导致即便内网主机长时间离线或者不发送数据时&#xff0c;与之对应的共有地址也处于使用状态。为了避免地址浪费&#xff0c;动态NAT提出了地址池的概念&#xff1a;所有可用的共用地址组成地址池。 当内部主机访问外部网络时临…

华为OD机试真题 Java 实现【水库蓄水问题】

前言 博主刷的华为机考题&#xff0c;代码仅供参考&#xff0c;因为没有后台数据&#xff0c;可能有没考虑到的情况 如果感觉对你有帮助&#xff0c;请点点关注点点赞吧&#xff0c;谢谢你&#xff01; 题目描述 思路 1. 其实就是找一个最大的水坑&#xff0c;两个…

【Linux】Petalinux驱动开发基础

基于Petalinux做Linux驱动开发。 部分图片和经验来源于网络,若有侵权麻烦联系我删除,主要是做笔记的时候忘记写来源了,做完笔记很久才写博客。 专栏目录:记录自己的嵌入式学习之路-CSDN博客 目录 1 一个完整的Linux系统(针对Zynq) 1.1 PS部分 1.2 PL部分(若…

JAVA刷题记录: 递归,搜索与回溯

专题一 递归 面试题 08.06. 汉诺塔问题 - 力扣&#xff08;LeetCode&#xff09; class Solution {public void hanota(List<Integer> A, List<Integer> B, List<Integer> C) {dfs(A, B, C, A.size());}public void dfs(List<Integer> a, List<In…

YOLOv11改进:利用RT-DETR主干网络PPHGNetV2助力轻量化目标检测

这里写自定义目录标题 YOLOv11改进&#xff1a;利用RT-DETR主干网络PPHGNetV2助力轻量化目标检测1. 介绍2. 引言3. 技术背景3.1 YOLOv11概述3.2 RT-DETR与PPHGNetV23.3 相关工作 4. 应用使用场景5. 详细代码实现5.1 环境准备5.2 PPHGNetV2主干网络实现5.3 YOLOv11与PPHGNetV2集…

WPF之Button控件详解

文章目录 1. 引言2. Button控件基础Button类定义 3. Button控件的核心属性3.1 Content属性3.2 IsDefault属性3.3 IsCancel属性3.4 其他常用属性 4. 按钮样式与模板自定义4.1 简单样式设置4.2 使用Style对象4.3 触发器使用4.4 使用ControlTemplate完全自定义4.5 按钮视觉状态 5.…

【Java】2025 年 Java 学习路线:从入门到精通

文章目录 一、Java基础阶段(4-8周)1. 开发环境搭建2. 核心语法基础3. 面向对象编程(OOP)4. 核心类库二、Java进阶阶段(6-10周)1. JVM深度理解2. 并发编程3. 新特性掌握4. 设计模式三、开发框架与中间件(8-12周)1. Spring生态2. 持久层框架3. 常用中间件四、项目实战阶段…

虚幻引擎入门笔记

【虚幻5】UE5新手入门尝试 虚幻引擎的基础设置 1.验证-当文件误删的时候&#xff0c;对其进行验证&#xff0c;可以恢复。 2.虚幻引擎极其强大&#xff0c;可以实现多种复合技能&#xff0c;所在创建项目页面可以看见不只是创建游戏的项目 3.更改虚幻引擎默认的缓存地址。有些…

【PostgreSQL数据分析实战:从数据清洗到可视化全流程】1.1 数据库核心概念与PostgreSQL技术优势

&#x1f449; 点击关注不迷路 &#x1f449; 点击关注不迷路 &#x1f449; 点击关注不迷路 文章大纲 深度解析PostgreSQL核心架构与技术优势&#xff1a;从数据库原理到实战场景1.1 数据库核心概念与PostgreSQL技术优势1.1.1 关系型数据库核心架构解析1.1.1.1 数据库系统的底…