css案例:小黄人案例

news2025/1/23 10:40:32

css案例:小黄人案例

  1. 先看效果图
    眼睛和嘴巴有做动画的,但是我懒得上传gif了。
    在这里插入图片描述3. 源码 html
<!DOCTYPE html>
<html lang="en">
<head>
	<meta charset="utf-8">
	<style>
		.contain {
			width: 400px;
			height: 600px;
			border: 1px solid #000;
			margin: 0 auto;

			position: relative;
			z-index: -2;
			background-color: pink;
		}
		/* 身体 */
		.body {
			width: 250px;
			height: 400px;
			background-color: #FBF404;
			border: 5px solid #000;
			border-radius: 120px;
			box-shadow: 6px 0px 6px rgba(0, 0, 0, 0.3);
			position: absolute;
			top: 50%;
			left: 50%;
			transform: translate(-50%, -50%);
			overflow: hidden;
		}
		/* 头发 */
		.hair_l,
		.hair_r {
			width: 130px;
			height: 100px;
			/* background-color: #000; */
			border-top: 10px solid #000;
			border-radius:50%;
			position: absolute;
			transform: rotate(48deg);
			z-index: -1;

		}
		.hair_l {
			top: 89px;
			left: 98px;
		}
		.hair_r {
			top: 80px;
			left: 99px;
		}
		/* 眼睛 */
		.eyes {
			width: 100%;
			height: 100px;
			/* border: 1px solid #000; */
			position: absolute;
			top: 75px;
			overflow: hidden;
		}
		/* 眼戴直接用父亲伪元素做 */
		.eyes::before {
			content: "";
			width: 60px;
			height: 20px;
			background-color: #000;
			position: absolute;
			top: 31px;
			left: -15px;
			transform: rotate(25deg);
		}

		.eyes::after {
			content: "";
			width: 60px;
			height: 20px;
			background-color: #000;
			position: absolute;
			top: 31px;
			right: -15px;
			transform: rotate(-25deg);
		}

		/* 大眼眶 */
		.eyes .eyes_l,
		.eyes .eyes_r {
			width: 90px;
			height: 90px;
			border-radius: 50%;
			border: 5px solid #000;
			position: absolute;
			background-color: #fff;
			z-index: 999;
		}
		.eyes .eyes_l {
			left: 25px;
		}
		.eyes .eyes_r {
			right: 25px;
		}
		/* 黑眼珠 */
		.eyes .eyes_l .black_l,
		.eyes .eyes_r .black_r {
			width: 50px;
			height: 50px;
			background-color: #000;
			border-radius: 50%;
			position: absolute;
			top: 20px;
			left: 20px;
			/* 如果用transform定位,再加动画时这个定位就失效了 */
			/* transform: translate(-50%, -50%); */
			/* animation: eye 3s ease infinite; */

		}
		
		/* 白眼珠 */
		.eyes .eyes_l .black_l .white_l,
		.eyes .eyes_r .black_r .white_r {
			width: 20px;
			height: 20px;
			background: #fff;
			border-radius: 50%;
			position: absolute;
			top: 15px;
			
            
		}
		.eyes .eyes_l .black_l .white_l {
			left: 23px;
		}
		.eyes .eyes_r .black_r .white_r {
            left: 6px;
		}
		/* 嘴巴 */
		.mouth {
			width: 80px;
			height: 40px;
			background-color: #fff;
			position: absolute;
			border: 5px solid #000;
			top: 190px;
			left: 80px;
			border-radius: 0 0 45px 45px;
		}
		.mouth::before {
			content: "";
			width: 5px;
			height: 40px;
			background-color: #000;
			position: absolute;
			left: 20px;
		}
		.mouth::after {
			content: "";
			width: 5px;
			height: 40px;
			background-color: #000;
			position: absolute;
			left: 52px;
		}
		
		/* 手臂 */
		.hand_l,
		.hand_r {
			width: 100px;
			height: 100px;
			border: 5px solid #000;
			background-color: #FBF404;
			border-radius: 24px;
			position: absolute;
			top: 300px;		
			z-index: -1;
			

		}
		.hand_l {
			transform: rotate(45deg);
			left:50px;

		}
		.hand_r {
			transform: rotate(-45deg);
			right: 50px;
		}
		.hand_l::after,
		.hand_r::after {
			content: "";
			width: 20px;
			height: 20px;
			background-color: #000;
			border-radius: 7px;
			position: absolute;
			top: 64px;
			/* z-index: 9999; */


		}
		.hand_l::after {
           left: 18px;
		}
		.hand_r::after {
			right: 18px;

		}

		/* 衣服 */
		.clothes {
			width: 260px;
			height: 140px;
			/* border: 1px solid #000; */
			position: absolute;
			bottom: 0;
			left: -5px;
		}
		/* 衣服肩带 */
		.clothes .clothes_jl {
			content: "";
			width: 110px;
			height: 15px;
			border: 5px dashed #000;
			background-color: blue;
			position: absolute;
			top:-15px;
			left: -22px;
			z-index: 2;
			transform: rotate(24deg);

		}
		.clothes .clothes_jr {
			content: "";
			width: 110px;
			height: 15px;
			border: 5px dashed #000;
			background-color: blue;
			position: absolute;
			top:-15px;
			right: -22px;
			z-index: 2;
			transform: rotate(-24deg);

		}
		/* 肩带圆点 */
		.clothes .clothes_jl::after {
			content: "";
			width: 10px;
			height: 10px;
			background-color: #000;
			border-radius: 50%; 
			position: absolute;
			top: 2px;
			right: 3px;
		}
		.clothes .clothes_jr::after {
			content: "";
			width: 10px;
			height: 10px;
			background-color: #000;
			border-radius: 50%; 
			position: absolute;
			top: 2px;
			left: 3px;

		}
		.clothes .clothes_t {
			width: 100px;
			height: 40px;
			background-color: blue;
			border: 5px dashed #000;
			border-bottom: 0;
			position: absolute;
			left: 50%;
			transform: translate(-50%, 0);
			z-index: 1;

		}
		.clothes .clothes_b {
			width: 100%;
			height: 100px;
			background-color: blue;
			border: 5px dashed #000;
			position: absolute;
			bottom: -10px;

		}
		/* 口袋 */
		.clothes .clothes_k {
			width: 80px;
			height: 50px;
			background-color: blue;
			border-radius: 0 0 25px 25px;
			border: 3px dashed #000;
			position: absolute;
			top: 60px;
			left: 88px;
		}
		/* 口袋里面的圆形 */
		.clothes .clothes_k .clothes_k_y {
			content: "";
			width: 30px;
			height: 30px;
			border-radius: 50%;
			/* background-color: ; */
			background-color: #000;
			border: 2px dashed #000;
			position: absolute;
			top: 50%;
			left: 50%;
			transform: translate(-50%, -50%);

		}
		 /* .clothes_k .clothes_k_y {
			background-color: yellow;
		} */
		/* 正方形 */
		.clothes .clothes_k .clothes_k_y::after {
			content: "";
			width: 20px;
			height: 20px;
			background-color: blue;
			border: 2px solid #000;
			position: absolute;
			top: 3px;
			left: 3px;
			transform: rotate(45deg);


		}
		/* 小圆点 */
		.clothes .clothes_k .clothes_k_y::before {
			content: "";
			width: 10px;
			height: 10px;
			border-radius: 50%;
			background-color: #000;
			position: absolute;
			top: 10px;
			left: 10px;
			z-index: 999;
		}
		/* 脚部 */
		.foot .foot_l,
		.foot .foot_r {
			width: 30px;
			height: 80px;
			background-color: #000;

			position: absolute;
			bottom: 80px;
			z-index: -1;		
		}

		.foot .foot_l {
			left: 165px;

		}
		.foot .foot_r {
			left: 220px;

		}
		.foot .foot_l::after,
		.foot .foot_r::after {
			content: "";
			width: 60px;
			height: 30px;
			background-color: #000;
			box-shadow: 2px 2px 2px rgba(0, 0, 0, 0.3);
			position: absolute;
			bottom: -30px;
					
		}
		.foot .foot_l::after {
			left: -30px;
			border-radius: 15px 0 0 15px;
		}
		.foot .foot_r::after {
			right: -30px;
			border-radius: 0px 15px 15px 0px;
		}
		/* 动画 */
		/* 黑眼珠动画 */
		.eyes .black_l,
		.eyes .black_r {
          animation: black_eye 3s infinite;
		}
		@keyframes black_eye {
			0% {
				transform: translate(0, 0);
			}
			25% {
				transform: translate(18px, 0);
			}
			50% {
				transform: translate(0px, 0);
			}
			75% {
				transform: translate(-18px, 0);
			}
			100% {
				transform: translate(0px, 0);
			}

		}
		/* 白眼珠动画 */
		.eyes .black_l .white_l,
		.eyes .black_r .white_r {
			animation: white_eye 3s infinite;
		}
		@keyframes white_eye {
			0% {
				transform: translate(0, 0);
			}
			25% {
				transform: translate(0px, 5px);
			}
			50% {
				transform: translate(0px, 0);
			}
			75% {
				transform: translate(0px, -5px);
			}
			100% {
				transform: translate(0px, 0);
			}

		}
		/* 手臂动画 */
		.hand_l{
			animation: hand_l_mov 3s linear infinite;
		}
		@keyframes hand_l_mov {
			0% {
				transform: rotate(45deg);
			}
			25% {
				transform: rotate(52deg);
				
			}
			50% {
				transform: rotate(45deg);
				
			}
			75% {
				transform: rotate(52deg);
				
			}
			100% {
				transform: rotate(45deg);
				
			}

		}

		.hand_r{
			animation: hand_r_mov 3s linear infinite;
		}
		@keyframes hand_r_mov {
			0% {
				transform: rotate(-45deg);
			}
			25% {
				transform: rotate(-52deg);
				
			}
			50% {
				transform: rotate(-45deg);
				
			}
			75% {
				transform: rotate(-52deg);
				
			}
			100% {
				transform: rotate(-45deg);
				
			}

		}
		/* 头发动画 */
		.hair_l,.hair_r {
			animation: hair_mov 3s linear infinite;
		}
		@keyframes hair_mov {
			0% {
				transform: rotate(48deg);
			}
			25% {
				transform: rotate(55deg);
				
			}
			50% {
				transform: rotate(48deg);
				
			}
			75% {
				transform: rotate(55deg);
				
			}
			100% {
				transform: rotate(48deg);
				
			}

		}
		/* 嘴巴动画 */
		.mouth {
			animation: mouth_mov 1s linear infinite;
		}

       		@keyframes mouth_mov {
			0% {
				transform: translate(0, 0);
			}
			25% {
				transform: translate(0px, 5px);
			}
			50% {
				transform: translate(0px, 0);
			}
			75% {
				transform: translate(0px, -5px);
			}
			100% {
				transform: translate(0px, 0);
			}

		}



	</style>
</head>
<body>
<!-- 小黄人容器 -->
	<div class="contain">
	   <!-- 身体 -->
		<div class="body">	
		<!-- 眼睛 -->
          <div class="eyes">
          <div class="eyes_l">
          	<div class="black_l">
          		<div class="white_l">	</div>
          	</div>
          </div>
          <div class="eyes_r">
          	<div class="black_r">
          		<div class="white_r">	</div>
          	</div>
          </div>

          </div>
          <!-- 嘴巴 -->
          <div class="mouth">	</div>
          <!-- 衣服 -->
          <div class="clothes">
          <!-- 上部 -->
          	<div class="clothes_t"></div>
          	<!-- 下部 -->
          	<div class="clothes_b"></div>
          	<!-- 口袋 -->
          	<div class="clothes_k">
          		<div class="clothes_k_y">
          			
          		</div>
          	</div>
          	<!-- 肩带 -->
          	<div class="clothes_jl"></div>
          	<div class="clothes_jr"></div>

          </div>
		</div>
		<!-- 头发 -->
		<div class="hair">
			<div class="hair_l"></div>
			<div class="hair_r"></div>

		</div>
		<!-- 手臂 -->
		<div class="hand">
			<div class="hand_l"></div>
			<div class="hand_r"></div>
		</div>
		<!-- 脚部 -->
		<div class="foot">
			<div class="foot_l">
				
			</div>
			<div class="foot_r">
				
			</div>
		</div>
	</div>
</body>
</html>

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

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

相关文章

贪心-合并果子(经典Huffman树)

题意 在一个果园里&#xff0c;达达已经将所有的果子打了下来&#xff0c;而且按果子的不同种类分成了不同的堆。 达达决定把所有的果子合成一堆。 每一次合并&#xff0c;达达可以把两堆果子合并到一起&#xff0c;消耗的体力等于两堆果子的重量之和。 可以看出&#xff0c;所…

Linux驱动开发:uboot启动流程详解

前言&#xff1a;uboot作为Linux驱动开发的 “三巨头” 之一&#xff0c;绝对是一座绕不开的大山。当然&#xff0c;即使不去细致了解uboot启动流程依旧不影响开发者对uboot的简单移植。但秉持着知其然知其所以然的学习态度&#xff0c;作者将给读者朋友细致化的过一遍uboot启动…

如何用ChatGPT举办活动,人类与AI的一次深度对谈

刚刚&#xff0c;Mixlab今年首次线下联合举办的活动开启了&#xff0c;活动不仅分享了AIGC对体验设计的新要求、内容产业的发展研判、用于模拟仿真的生成式智能体&#xff0c;还演示了AI如何深度整合到一场活动之中。 1/ 数字人出场介绍Mixlab 是如何实现的呢&#xff1f;无限…

[Net]SSE消息推送简介

文章目录 SSE网络协议客户端服务端事件 SSE示例客户端服务端 SSE&#xff08;Server-Sent Events&#xff09;是一种服务端到客户端&#xff08;浏览器&#xff09;的单向消息推送方式。 SSE网络协议 SSE是基于HTTP协议的&#xff0c;客户端向服务端发起一个请求&#xff0c;建…

Android 9.0 系统设置显示主菜单添加屏幕旋转菜单实现旋转屏幕功能

1.前言 在android9.0的系统rom定制化开发中,在对系统设置进行定制开发中,有产品需求要求增加旋转屏幕功能的菜单,就是在点击旋转屏幕菜单后弹窗显示旋转0度,旋转 90度,旋转180度,旋转270度针对不同分辨率的无重力感应的大屏设备的屏幕旋转功能的实现,接下来就来分析实现…

以太网PLC无线WIFI跨网段通讯和Modbus仪表数据采集

产品介绍 产品型号&#xff1a;NET50-NAT-W4 使用范围&#xff1a;用于以太网PLC的跨网段无线通讯和仪表的数据采集 产品介绍 工业通讯桥接器&#xff08;NET50-NAT-W4&#xff09;用于以太网PLC的通讯扩展&#xff0c;以太网跨网段通讯和Modbus仪表的数据采集&#xff0c;上…

2023年制造业产品经理考NPDP有什么用?

产品经理国际资格认证NPDP是新产品开发方面的认证&#xff0c;集理论、方法与实践为一体的全方位的知识体系&#xff0c;为公司组织层级进行规划、决策、执行提供良好的方法体系支撑。 【认证机构】 产品开发与管理协会&#xff08;PDMA&#xff09;成立于1979年&#xff0c;是…

谈一谈django应用实践

python 的 web 框架非常多,比较出名的有 django, flask, tornado。django 作为一个老牌框架,无论是文档还是代码质量都非常高,另外他自带的 admin 后台和一些有用的 app,如果你的需求是做 cms 之类的 web 应用的话,基本上不用开发多少代码就能出一个成品。不过很多新手可能…

2023-04-23 学习记录--C/C++-函数

合抱之木&#xff0c;生于毫末&#xff1b;九层之台&#xff0c;起于累土&#xff1b;千里之行&#xff0c;始于足下。&#x1f4aa;&#x1f3fb; 【一】、调用有参函数 ⭐️ 有参函数&#xff1a;调用函数时&#xff0c;需要传对应参数。 一、实现步骤 &#x1f338; 实现步骤…

Adobe国际认证证书,深化设计师个人优势!

Adobe国际认证又称为Adobe认证(英文:Adobe Certified Professional)是Adobe公司CEO签发的权威国际认证体系,旨在为用户提供Adobe软件的专业认证。 该体系基于Adobe核心技术及岗位实际应用操作能力的测评体系得到国际ISTE协会的认可&#xff0c;并在全球 148 个国家推广&#xf…

mybatis分页插件的详细理解和使用

mybatis分页插件的基本理解和使用 为什么要使用mybatis分页插件&#xff1f; 分页是一种将所有数据分段展示给用户的技术。用户每次看到的不是全部数据&#xff0c;而是其中一部分&#xff0c;如果在其中没有找到自己想要的内容&#xff0c;用户可以通过制定页码或者是翻页的…

头歌c语言实训项目-综合案例课外练习:学生成绩管理系统

(创作不易&#xff0c;感谢有你&#xff0c;你的支持&#xff0c;就是我前行的最大动力&#xff0c;如果看完对你有帮助&#xff0c;请留下您的足迹&#xff09; 目录 第1关&#xff1a;学生成绩管理系统 题目&#xff1a; 代码思路&#xff1a; 代码表示&#xff1a; 如…

【Git】git使用

vitevue3部署静态文件到github 1. 新建仓库 新建仓库 仓库名称: 必须是 [你的git用户名]或[仓库名称] .github.io&#xff0c;例如你的用户名是YunZhonJun&#xff0c;统一为小写&#xff0c;如↓ 例1 用户名.github.io yunzhonjun.github.io 例2 仓库名称.github.io colors…

【动力节点】Springsecurity14-18章JWT+Spring Security+redis+mysql 实现认证

15 SpringSecurity 集成thymeleaf 此项目是在springsecurity-12-database-authorization-method 的基础上进行 复制springsecurity-12-database-authorization-method 并重命名为springsecurity-13-thymeleaf 15.1 添加thymeleaf依赖 | org.springframework.boot spring-…

根据vue2数组响应式实现原理找到了一个待优化点

最近学习了相关知识 写出了 vue2数据响应式原理(5) 通过重写函数实现数组响应式监听但也在这里 我发现 数组响应式 一个是通过for遍历监听已有属性 还有就是重写会改变数组的几个内置函数来监听 但 如果 元素之前没有 且 我们不适用这些内置函数去修改呢&#xff1f; 我们创建…

报表生成器 FastReport .Net 用户指南(一):基本原理

FastReport .Net是一款全功能的Windows Forms、ASP.NET和MVC报表分析解决方案&#xff0c;使用FastReport .NET可以创建独立于应用程序的.NET报表。 随着FastReport .Net 2023版的正式发布&#xff0c;厂商也发布了最新版的用户手册&#xff0c;从今天起我们将持续更新2023版的…

苹果手机怎么看生产日期?参考方法在这!

案例&#xff1a;怎么查苹果手机买了几年&#xff1f; 【求助&#xff01;我从别人那里买了一部苹果手机&#xff08;非官方&#xff09;&#xff0c;怎么看这个手机用了几年&#xff1f;】 苹果手机作为一款高端手机&#xff0c;备受用户的喜爱。然而&#xff0c;许多用户不知…

utools - 电脑必装软件

目录 一、超级面板二、计算稿纸三、IP地址查询和正则表达式测试四、浏览器书签五、OCR识别六、Markdown编辑器、Emoji表情输入工具七、总结 简介&#xff1a; 今天我要向大家介绍一款非常实用的电脑软件——utools。 官网&#xff1a;utloos &#x1f433;作为一款集成了多种实…

初识c++语法(一)

我们在C语言的基础之上进行c语言的学习。对于我们的c语言来说&#xff0c;c兼容C语言&#xff0c;所以我们以前编写的C语言的程序在c平台上也是可以运行的。唯一不同的就是我们的c对于我们C语言的部分语法做出了优化以及引入了面向对象的概念。所以在刚开始学习c的时候我们可以…

免费馅饼(牛客刷dp)

免费馅饼 比赛主页 我的提交 时间限制&#xff1a;C/C 1秒&#xff0c;其他语言2秒 空间限制&#xff1a;C/C 262144K&#xff0c;其他语言524288K 64bit IO Format: %lld 题目描述 SERKOI最新推出了一种叫做“免费馅饼”的游戏:游戏在一个舞台上进行。舞台的宽度为W格&#…