一行代码教你撩妹手到擒来❤html+css+js烟花告白3D相册(含音乐+可自定义文字)520表白/七夕情人节/求婚

我是如何获取学姐芳心~html+css+js实现满屏烟花3D相册(含音乐+自定义文字)

一年一度的520情人节/七夕情人节/女朋友生日/程序员表白/送礼物/3D相册,是不是要给女朋友或者正在追求的妹子一点小惊喜呢,今天这篇博客就分享下前端代码如何实现3D立体动态相册。赶紧学会了,来制作属于我们程序员的浪漫吧!



前言

520/七夕情人节表白[满屏烟花3D相册],程序员也可以很浪漫哦 ! 程序员向妹子表白专用代码!❤
HTML+css3+js 抖音很火的3d旋转相册-包含音乐,(送女友,表白,生日)动态生成效果,这样制作的~,现在,越来越多的人喜欢用视频记录生活,照片多的友友也会选择制作动态相册视频,不仅创意十足,同时还能展现自我风采, 撩妹神器哦!


更多告白演示

2.樱花雨3D相册演示地址
3.文字开场白+浪漫樱花飘落演示地址

1. 单相片演示(已兼容H5手机和PC电脑)

在这里插入图片描述

2. 多相片演示(已兼容H5手机和PC电脑)

在这里插入图片描述

代码文件目录

在这里插入图片描述

一、文字修改(代码实现)

示例:找到index.html文件中的script标签下 words字段,只需要修改文字就行~
在这里插入图片描述

二、3D相册(代码实现)

html (字幕部分)

    <!-- 打字 -->
    <div class="typing">
      <!-- 字幕 -->
      <h2 class="header-sub-title" id="word"></h2>
      <h2 class="header-sub-title blink">|</h2>
    </div>

html (3D相册)

    <!-- 相册 S -->
    <div class="box">
      <ul class="minbox">
        <li></li>
        <li></li>
        <li></li>
        <li></li>
        <li></li>
        <li></li>
      </ul>
      <ol class="maxbox">
        <li></li>
        <li></li>
        <li></li>
        <li></li>
        <li></li>
        <li></li>
      </ol>
    </div>
    <!-- 相册 E -->

html (文字打印)

    <!-- 打字 -->
    <div class="typing">
      <!-- 字幕 -->
      <h2 class="header-sub-title" id="word"></h2>
      <h2 class="header-sub-title blink">|</h2>
    </div>

html (播放器)

    <!-- 播放器 -->
    <div id="app">
      <div class="container_player">
        <div class="music-box">
          <!-- 音乐图片 -->
          <img src="img/01.png" />
          <div class="mask">
            <div class="mplayer" onclick="play()">
              <i class="fa">
                <span class="before"></span>
                <span class="after"> </span>
              </i>
              <svg
                class="loadingSvg"
                width="25"
                height="25"
                viewBox="0,0,50,50"
                style="
                  position: absolute;
                  top: 50%;
                  left: 50%;
                  transform: translate(-50%, -50%);
                "
              >
                <circle></circle>
              </svg>
            </div>
            <div class="m-circle m-progress">
              <svg width="163" height="163" viewBox="0,0,163,163">
                <circle
                  cx="81"
                  cy="81"
                  r="159"
                  stroke-width="8"
                  stroke="rgba(255, 206, 113, 0.2)"
                  fill="rgba(0,0,0,.2)"
                ></circle>
                <circle
                  class="a"
                  cx="81"
                  cy="81"
                  r="159"
                  stroke-width="6"
                  stroke="rgba(255, 206, 113, 1)"
                  fill="none"
                  stroke-dasharray="0 999"
                  transform="matrix(0,-1,1,0,0,163)"
                ></circle>
              </svg>
            </div>
            <div class="m_time">
              <span class="mplayer_curtime">00:00</span>
              <span class="m-join">/</span>
              <span class="mplayer_durtime">00:00</span>
            </div>
          </div>
        </div>
      </div>
    </div>
    <!-- 音乐 -->
    <audio id="myAudio" src="music/yinyue.mp3"></audio>

js(文字打印)

/* 只需要修改这里的文字就行 */
    <script>
      // 打印字
      const words = [
        "❤2021.5.20与你相爱 1314天~",
        "❉你的微笑,是我这辈子见过最美的景色。",
        "❉我想收藏这样的风景一辈子。",
        "❉我的人生放荡不羁,不曾为谁停留,",
        "❉但自从遇到你,我会用余生来守护你。",
        "❉我不想做你人生的插曲,",
        "❉我想成为你一生的主题曲。",
        "❤我爱你❤。",
      ];

      let i = 0;
      let timer;
      // 速度
      let deleteDelay = 3000;
      let typeSpeed = 100;
      let delSpeed = 50;
      /* 开始编写文字 */
      function typingEffect() {
        let word = words[i].split("");
        var loopTyping = function () {
          if (word.length > 0) {
            document.getElementById("word").innerHTML += word.shift();
          } else {
            delay(function () {
              deletingEffect(); // do stuff
            }, deleteDelay); // end delay
            // deletingEffect();
            return false;
          }
          timer = setTimeout(loopTyping, typeSpeed);
        };
        loopTyping();
      }
      /* 开始编写文字 */
      typingEffect();
    </script>

js (烟花效果实现)

 var audio = document.getElementById("myAudio");
var currentTime = $(".mplayer_curtime");
var durationTime = $(".mplayer_durtime");
var circle = $(".m-circle .a")[0];
var circumference = 2 * Math.PI * 160;
var timer_audio;

function play() {
  if (audio.paused) {
    audio.play();
    $(".music-box").addClass("mplaying");
    timer_audio = setInterval(() => {
      if (audio.ended) {
        $(".music-box").removeClass("mplaying");
        currentTime.text("00:00");
        circle.setAttribute("stroke-dasharray", "0 999");
      } else {
        currentTime.text(formatTime(audio.currentTime));
        durationTime.text(formatTime(audio.duration));
        var step = circumference / audio.duration;
        var timeDisplay = Math.floor(audio.currentTime);
        circle.setAttribute(
          "stroke-dasharray",
          "" + timeDisplay * step + " " + circumference
        );
      }
    }, 100);
  } else {
    audio.pause();
    $(".music-box").removeClass("mplaying");
  }
}

三、3D相册裁剪(教程)

教程如下:需要12张图片, 1-6 图片是大图 400px400px ,01-06 图片是小图 100px100px

将准备好的图片,自行替换 img 文件中的图片即可!
在这里插入图片描述

1.相片裁剪(教程)

1.1首先:下载美图秀秀/百度下载/或者软件安装
1.2或者使用在线链接裁剪—> 在线裁剪图片链接
在这里插入图片描述

2.美图秀秀(电脑版)裁剪图片

2.1选择图片裁剪
在这里插入图片描述

四、歌曲mp3更换教程(教程)

如需更换mp3背景音乐,可自行下载更换即可~ mp3免费下载地址
1.1搜索需要的歌曲

在这里插入图片描述

1.2下载在这里插入图片描述
1.3获取歌曲id
在这里插入图片描述
1.4关注公众号以后/复制链接到浏览器打开

在这里插入图片描述

1.5下载mp3 ~下载完毕以后自行替换mp3文件即可(如不想修改代码,必须保持名称一致)
在这里插入图片描述


五、做好的网页效果,如何通过发链接给别人看?

1.1 解决部署上线~> 部署上线工具(可永久免费使用)

1.不需要买服务器就能部署线上,全世界都能访问你的连接啦, 这里给大家推荐一个程序员必备神器~
插件集成了超级多好用的插件,免费下载安装,简单易懂, 简直神器 ~ 需要可在文章 ↓ 下方公Z号获取

2.就是把你的代码效果做好了以后, 部署到线上, 把链接发给别人, 就可以让对方通过你的连接点击进去, 就能看到你的网页效果啦, 电脑端和手机端都可以噢! (不然别人看你的网页都要发文件过去,体验感不太好哦~)

1.1部署流程

在这里插入图片描述

1.2 哇~ 部署成功

哇~ 部署成功! 将你写好的页面部署上线后, 全世界的人都可以通过链接访问到你的网页了(永久免费使用哦)~
在这里插入图片描述


六、前端 零基础 入门到高级 (视频+源码+开发软件+学习资料+面试题) 一整套 (教程)

适合入门到高级的童鞋们入手~
在这里插入图片描述


七、 源码获取

~ 关注我,点赞博文~ 每天带你涨知识!

1.看到这里了就 [点赞+好评+收藏] 三连~ 支持下吧,你的「点赞,好评,收藏」是我创作的动力。

2.关注我~ 每天带你学习 :各种前端插件、3D炫酷效果、图片展示、文字效果、以及整站模板 、大学生毕业模板 、期末大作业模板 、等! 「在这里有好多 前端 开发者,一起探讨 前端 Node 知识,互相学习」!

3.以上内容技术相关问题可以相互学习,可关注↓公Z号 获取更多源码 !

在这里插入图片描述


八、更多表白源码

❤100款表白源码演示地址

### 回答1: 超全的ad元件库和封装库以及3d模型是一种非常重要的资源,它可以帮助电子工程师在设计工作中更加高效、精准地完成任务。这类资源的功效是多方面的,比如:一方面,它们可以节省设计师的时间和精力,提高设计效率;另一方面,它们可以提供高质量的元件和封装以及3d模型,确保了电路设计的准确性和可靠性。 在电路设计中,元件库是一个非常关键的工具。通过元件库,工程师可以获取各种常用或非常规元件,包括芯片、电阻、电容、二极管、晶体管、集成电路等。这些元件的存在,让设计师无需手动绘制符号,可以直接拖拽、放置到布局中,无需担心错误。封装库则是对元件的标准化封装,确保元件的强度、与其他元件的连接等都符合要求。3D模型则是为元器件提供三维呈现,以方便设计预览并帮助工程师进行立体构思。在各种高级应用中,这种资源的存在是手到擒来的宝藏,能够更快完成研发任务,有助于创新和竞争。 综上所述,超全的ad元件库和封装库以及3d模型的作用不言而喻。随着科技的不断发展,这种资源将会越来越丰富和完善,成为越来越多工程师进行设计工作的重要基石。 ### 回答2: 超全的ad元件库、封装库以及3D模型是目前很多电子工程师所需要的基础工具之一。这些工具可以帮助工程师快速制作、优化并完善电路原理图和PCB布局。超全的ad元件库中包括了大量的电子元器件,如晶振、电容、电感、开关、转换器、集成电路等等。这些元器件的广泛应用使得超全的ad元件库可以满足众多电子产品的需要。 此外,封装库也是构建电路信号完整性、功耗优化等方面的重要工具。超全的封装库不仅提供了传统的SMD、Through Hole等封装,还可以适应各种新型器件和芯片的不同封装形态,让工程师更加灵活和自由地选择符合产品要求的器件。 3D模型是完善PCB布局、虚拟样机测试的重要工具。超全的3D模型通常包括了各种器件的封装和周边零部件,可以帮助工程师更加直观地感受一个产品的物理形态,同时也可以测试和验证电子产品的尺寸、外观、连通性等参数。 总之,超全的ad元件库、封装库和3D模型是电路设计中不可或缺的基本资源。工程师利用这些工具,可以更加轻松和高效地设计出各种电子产品,提升研发效率和产品质量。 ### 回答3: 随着广告行业的不断发展,广告制作的要求也越来越高。在这个大背景下,超全的ad元件库和封装库以及3d模型的出现,无疑是提升广告制作效率和品质不可或缺的利器。 首先,这种全面的资源库可以满足需求的品类、风格和素材种类,让制作人员可以快速找到适合的素材,轻松实现创意灵感的落地。对于制作公司而言,节省成本和提升商业竞争力的同时,也可以减轻设计人员的压力和工作量。 其次,利用这些广告元件库和封装库,设计人员可以将资源视觉化地分类和整理,帮助他们更快速地找到对应的素材。同时,素材质量的保证也是非常重要的一个因素,一个好的素材源可以降低制作的时间和成本,并且还可以让创意更容易地实现。 最后,对于3D模型而言,它可以提供更加逼真和生动的效果,可以将海报、广告、产品等场景更加真实地呈现。3D模型和渲染技术的运用,不仅可以在广告制作中大大提升视觉效果,也可以创造更加丰富的用户体验,让用户更好的理解和记忆宣传的品牌及产品。 综上所述,超全的ad元件库和封装库以及3d模型的运用可以提高制作效率和品质,降低成本,增强品牌影响力和商业竞争力,这些资源库也将成为广告制作的重要利器。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

@码出未来-web网页设计

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值