制作一个小黄鸭转圈跳舞的页面。

制作一个小黄鸭转圈跳舞的页面。

我们来制作一个小黄鸭转圈跳舞的页面。

分析一下

1、分析一下这个页面,要完成这些效果,一共需要3步:

  • 把鸭子都放到一个盒子当中
  • 在盒子里,把每个鸭子的位置摆好
  • 让盒子旋转

2、让鸭子在盒子中的位置摆好,需要怎么做:

  • 先让鸭子站在圆心的位置(需要先了解父相子绝定位方式)
  • 每个鸭子旋转一个角度,让每个鸭子均匀面向不同的角度
  • 向前移动一个半径的距离(3d)

开始写代码

要用到的知识包括几个HTML标签和一部分的css知识。

先把图片放到页面里边。

先来在页面中添加一个img标签,将小黄鸭跳舞的gif图放到标签中

<img src="img/001.gif" alt="">

这个时候,可以看到,页面中已经有一个小黄鸭了。

把图片放到一个盒子里边

<div class="box">
    <img src="img/001.gif" alt="">
</div>

这个时候盒子看不到,我们通过选择器,来给盒子添加一个边框,好看到它

<style>
    .box{
        border: 1px solid red;
    }
</style>

盒子很大,比鸭子大很多。

我们把盒子的大小设置成跟鸭子图片的大小一样

.box{
    border: 1px solid red;
    width: 140px;
    height: 172px;
}

接下来呢,让小黄鸭显示在页面的中间。

.box{
    border: 1px solid red;
    width: 140px;
    height: 172px;
    /*margin-right: auto ;*/
    /*margin-left: auto ;*/
    margin: 0 auto;
}

这个时候,盒子跟盒子里的鸭子都居中了。

我们再添加其他的鸭子。

<div class="box">
    <img src="img/001.gif">
    <img src="img/002.gif">
    <img src="img/003.gif">
    <img src="img/004.gif">
    <img src="img/005.gif">
    <img src="img/006.gif">
    <img src="img/007.gif">
    <img src="img/008.gif">
    <img src="img/009.gif">
</div>

发现鸭子是竖着排成一列的

我们先要把所有的鸭子放到围绕旋转的圆心处,所以,所有的鸭子应该是在同一个位置。怎么把鸭子都放在圆心处呢。我们需要先学习一个定位方式:父相子绝定位。

重要内容补充-定位方式的讲解

相对定位,绝对定位。

重要内容补充-3D图形布局讲解

需要进行3D布局的元素,父元素加上一个样式:

transform-style: preserve-3d;

只加上这个,没有效果,需要跟transform配合使用

transform-style: preserve-3d;
/*设置旋转绕X轴*/ 
transform: rotateX(-10deg);   

开始写代码

把所有鸭子放到同一个位置

利用父相子绝定位,把父盒子设置成相对定位,子盒子设置成绝对定位

.box{
    border: 1px solid red;
    width: 140px;
    height: 172px;
    /*margin-right: auto ;*/
    /*margin-left: auto ;*/
    margin: 0 auto;
    position: relative;
}

img{
    position: absolute;
}

让鸭子面向不同的方向,在360度内均匀分布

设置父盒子的3D效果,给每个图片添加一个类名,给每个图片,设置不同的旋转角度。

<div class="box">
    <img src="img/001.gif" class="img1">
    <img src="img/002.gif" class="img2">
    <img src="img/003.gif" class="img3">
    <img src="img/004.gif" class="img4">
    <img src="img/005.gif" class="img5">
    <img src="img/006.gif" class="img6">
    <img src="img/007.gif" class="img7">
    <img src="img/008.gif" class="img8">
    <img src="img/009.gif" class="img9">
</div>
<style>
    .box {
        border: 1px solid red;
        width: 140px;
        height: 172px;
        /*margin-right: auto ;*/
        /*margin-left: auto ;*/
        margin: 0 auto;
        position: relative;

        transform-style: preserve-3d;
    }

    img {
        position: absolute;
    }

    .img1 {
        transform: rotateY(0deg);
    }

    .img2 {
        transform: rotateY(40deg);
    }

    .img3 {
        transform: rotateY(80deg);
    }

    .img4 {
        transform: rotateY(120deg);
    }

    .img5 {
        transform: rotateY(160deg);
    }

    .img6 {
        transform: rotateY(200deg);
    }

    .img7 {
        transform: rotateY(240deg);
    }

    .img8 {
        transform: rotateY(280deg);
    }

    .img9 {
        transform: rotateY(320deg);
    }
</style>

这个时候,鸭子都在圆点,面向了不同的角度,在让它们向前跨一步,就分散成了一个圆

<style>
    .box {
        border: 1px solid red;
        width: 140px;
        height: 172px;
        /*margin-right: auto ;*/
        /*margin-left: auto ;*/
        margin: 0 auto;
        position: relative;

        transform-style: preserve-3d;
    }

    img {
        position: absolute;
    }

    .img1 {
        transform: rotateY(0deg) translateZ(300px);
    }

    .img2 {
        transform: rotateY(40deg) translateZ(300px);
    }

    .img3 {
        transform: rotateY(80deg) translateZ(300px);
    }

    .img4 {
        transform: rotateY(120deg) translateZ(300px);
    }

    .img5 {
        transform: rotateY(160deg) translateZ(300px);
    }

    .img6 {
        transform: rotateY(200deg) translateZ(300px);
    }

    .img7 {
        transform: rotateY(240deg) translateZ(300px);
    }

    .img8 {
        transform: rotateY(280deg) translateZ(300px);
    }

    .img9 {
        transform: rotateY(320deg) translateZ(300px);
    }
</style>

但其实没有看到围城圆的效果,我们把父盒子在x轴旋转一个角度,就可以体现出来。同时,加一个

margin-top: 150px;

.box {
    border: 1px solid red;
    width: 140px;
    height: 172px;
    /*margin-right: auto ;*/
    /*margin-left: auto ;*/
    margin: 0 auto;
    position: relative;

    transform-style: preserve-3d;
    transform: rotateX(-20deg);
    margin-top: 150px;
}

可以看到,已经形成一个圆了。

添加动画

/*定义一个动画*/
@keyframes xuanzhuan {
    0% {
        transform: rotateX(-20deg) rotateY(0deg)
    }
    100% {
        transform: rotateX(-20deg) rotateY(360deg)
    }
}

.box {
    border: 1px solid red;
    width: 140px;
    height: 172px;
    /*margin-right: auto ;*/
    /*margin-left: auto ;*/
    margin: 0 auto;
    position: relative;

    transform-style: preserve-3d;
    transform: rotateX(-20deg);

    margin-top: 150px;

    /*绑定动画*/
    animation: xuanzhuan 10s;
    /*动画无限循环播放*/
    animation-iteration-count: infinite;
    /*速度线性播放*/
    animation-timing-function: linear;
}

添加背景音乐

<audio src="media/小黄鸭音频.mp3" autoplay="autoplay" loop="loop"></audio>

chrome浏览器不能自动播放问题解决

浏览器输入

chrome://flags/#autoplay-policy

将 Autoplay policy 改为

No user gesture is required

完整代码

<!doctype html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> <style> @keyframes xuanzhuan { 0% { transform: rotateX(-20deg) rotateY(0deg) } 100% { transform: rotateX(-20deg) rotateY(360deg) } } body { background-color: #313131; } .box { width: 154px; height: 186px; margin: 150px auto; position: relative; transform-style: preserve-3d; transform: rotateX(-20deg); animation: xuanzhuan 15s; animation-iteration-count: infinite; animation-timing-function: linear; } .box > div { position: absolute; } </style> </head> <body> <audio src="media/小黄鸭音频.mp3" loop="loop" autoplay="autoplay"></audio> <div class="box"> <div style="transform: rotateY(0deg) translateZ(300px)"> <img src="img/001.gif" alt=""> </div> <div style="transform: rotateY(40deg) translateZ(300px) "> <img src="img/002.gif" alt=""> </div> <div style="transform: rotateY(80deg) translateZ(300px) "> <img src="img/003.gif" alt=""> </div> <div style="transform: rotateY(120deg) translateZ(300px) "> <img src="img/004.gif" alt=""> </div> <div style="transform: rotateY(160deg) translateZ(300px) "> <img src="img/005.gif" alt=""> </div> <div style="transform: rotateY(200deg) translateZ(300px) "> <img src="img/006.gif" alt=""> </div> <div style="transform: rotateY(240deg) translateZ(300px) "> <img src="img/007.gif" alt=""> </div> <div style="transform: rotateY(280deg) translateZ(300px) "> <img src="img/008.gif" alt=""> </div> <div style="transform: rotateY(320deg) translateZ(300px) "> <img src="img/009.gif" alt=""> </div> </div> </body> </html>

转载于:https://www.cnblogs.com/hansha/p/10125070.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/101257.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • JVM调优总结 -Xms -Xmx -Xmn -Xss

    JVM参数在tomcat中如何进行配置在tomcat的bin目录下面有很多可以执行的脚步,执行的脚步分为windows环境和Linux环境! 如果在windows环境配置jvm参数,catalina.bat如下:set JAVA_OPTS=&amp;quot;$JAVA_OPTS -server -Xmx3550m -Xms3550m -Xmn2g -XX:PermSize=256m -XX:MaxPer…

    2022年2月27日
    41
  • 快速阶乘算法python_【最全】阶乘算法!(python和C语言)

    快速阶乘算法python_【最全】阶乘算法!(python和C语言)阶乘的计算叁岁学编程:用最简单的大白话理解编程,欢迎大家关注,留言,提问,希望和大家一起提升!文章目录阶乘的计算阶乘定义:解析方法一:for循环计算方法二:定义for循环的函数计算方法三:定义递归函数计算小知识:C语言代码方法一:for函数方法二:递归函数总结:阶乘定义:阶乘指从1乘以2乘以3乘以4一直乘到所要求的数。例如所要求的数是4,则阶乘式是1×2×3×4,得到的积是24。24就是4的阶乘。…

    2022年7月24日
    9
  • labview车牌识别教学视频(车牌识别)

    OCR从本质上可看作是目标分类和识别的一种实际应用,因此它也包括训练和分类过程。

    2022年4月13日
    62
  • 正确姿势临时和永久开启关闭Android的SELinux

    正确姿势临时和永久开启关闭Android的SELinux      正确姿势临时和永久关闭Android的SELinux前言  自从Android4.4强制开启SELinux以后,在开发中我们经常会遇到avcdenied的问题,为了方便开发调试我们会将SELinux关闭,那么本章将带领读者怎么临时和永久关闭Android的SELinux。正确姿势临时和永久关闭Android的SELinux1.1临时关闭Andro…

    2022年6月27日
    35
  • 指令的四个周期_cpu指令周期流程图

    指令的四个周期_cpu指令周期流程图指令流程图的概念菱形:译码,测试,表示判断,如零指令字是0或者1.与前面的CPU周期紧密相连,不单独占用CPU周期。每个方框箭头下面的是公共操作符符号,表示一条指令结束。mov指令将R1寄存器的数据存储到R2寄存器中,lad指令时间主存中的数据存储到寄存器中。sto是将R2中的数据根据R3中的主存地址存储到主存中。lad和sto是寄存器-主存指令需要三个CPU周期,其他都是寄存器-…

    2022年10月13日
    3
  • Mac下homebrew安装

    Mac下homebrew安装需要替换国内镜像 usr bin ruby e curl fsSLhttps cdn jsdelivr net gh ineo6 homebrew install install 该脚本用了中科大镜像加速访问 仅修改仓库地址部分 不会产生安全隐患 关于中科大所提供的 Homebrew 镜像服务 https lug ustc edu cn wiki mirrors help brew git 以下是中科大的 Homebrew 安装帮助 Homebrew

    2025年8月5日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号