2022新年祝福代码诠释(1)

举报
泽宇-Li 发表于 2022/07/16 10:28:47 2022/07/16
【摘要】 新年马上就要来临啦 春节到来还有28天下个月的1号~又到了大家准备发放红包和说新年贺词的时候 远在异地的亲戚又不能随时见面 没有什么对于程序员来说是用代码解决不了的 所以给大家准备一个代码的新年祝福和倒计时让我们一起来瞧瞧吧!先来预览下代码的成果:是不是很nice?让我们来瞧瞧接下里如何写这样儿的代码吧!首先我们得明白这样儿的代码要分别几个步骤才能完成  背景  字体  时间  高宽等等一:...

新年马上就要来临啦 春节到来还有28天下个月的1号~又到了大家准备发放红包和说新年贺词的时候 远在异地的亲戚又不能随时见面 没有什么对于程序员来说是用代码解决不了的 所以给大家准备一个代码的新年祝福和倒计时让我们一起来瞧瞧吧!

先来预览下代码的成果:

huaweiyun.gif

是不是很nice?让我们来瞧瞧接下里如何写这样儿的代码吧!

首先我们得明白这样儿的代码要分别几个步骤才能完成  背景  字体  时间  高宽等等

一:设置页面标题与head

我们在utf-8下加入<title>祝华为云小伙伴新年快乐</title>

为了给字体留出一个位置用span来修饰 需要在head中添加俩个内容一个是head1和head1span 让head1的id指向head1

部分代码展示:

h1{
  position: fixed;
  top: 30%;
  left: 0;
  width: 100%;
  text-align: center;
  transform:translateY(-50%);
  font-family: 'Love Ya Like A Sister', cursive;
  font-size: 60px;
  color: yellow;
  padding: 0 20px;
}
h1 span{
  position: fixed;
  left: 0;
  width: 100%;
  text-align: center;
margin-top:30px;
    font-size:40px;
}
</style>

</head>

二:画布的使用(canvas)

首先用var声明俩个变量 ww和wh function onResize() 定义一个size的作用函数 函数体如下

 ww = canvas.width = window.innerWidth;
  wh = canvas.height = window.innerHeight;

让画布的高度和宽度适应到window当前屏幕的高度和宽度

canvas.strokeStyle = "red";
canvas.shadowBlur = 35;
canvas.shadowColor = "hsla(0, 150%, 60%,1)";

设置canvas来实现当前的鼠标点击事件 目的是为了让点击后出现相应的动态效果和效果颜色

三:鼠标点击事件

定义一个onmove的函数 传递过来一个参数e  并让onmove为true确实在移动的前提下 才能进行下面的判断 如果传递过来的参数e如果===touchmove为false则实现if下面的操作

插播:在javascript中 ===和==意义不同  ===代表的是false  ==返回的是true 执行if下的push用法:可向数组的末尾添加一个或多个元素,并返回新的长度。用xy来标记当前的鼠标移动到的位置并为x和y传递参数

function onMove(e){
  mouseMoved = true;
  if(e.type === "touchmove"){
    hearts.push(new Heart(e.touches[0].clientX, e.touches[0].clientY));
    hearts.push(new Heart(e.touches[0].clientX, e.touches[0].clientY));
  }
  else{
    hearts.push(new Heart(e.clientX, e.clientY));
    hearts.push(new Heart(e.clientX, e.clientY));
  }
}

var Heart = function(x,y){
  this.x = x || Math.random()*ww;
  this.y = y || Math.random()*wh;
  this.size = Math.random()*2 + 1;
  this.shadowBlur = Math.random() * 10;
  this.speedX = (Math.random()+0.2-0.6) * 8;
  this.speedY = (Math.random()+0.2-0.6) * 8;
  this.speedSize = Math.random()*0.05 + 0.01;
  this.opacity = 1;
  this.vertices = [];
  for (var i = 0; i < precision; i++) {
    var step = (i / precision - 0.5) * (Math.PI * 2);
    var vector = {
      x : (15 * Math.pow(Math.sin(step), 3)),
      y : -(13 * Math.cos(step) - 5 * Math.cos(2 * step) - 2 * Math.cos(3 * step) - Math.cos(4 * step)) 
    }
    this.vertices.push(vector);
  }
}

四:设置倒计时

新年倒计时才是本页面的灵魂  如何设置倒计时呢?懂得都懂

用当前window的事件来设置一个开始的事件 倒计时时间=过年时间-当前时间

设置time为2022年2月1日为春节  添加计时器从当前时间开始 设置作用时间 将时间进行一个转换为当前的时间并设置未来的一个时间戳随后定义一个变量来获取倒计时时间是多少 未来时间-现在的时间

再将获取到的时间毫秒为单位/1000来计算  小时数用总小时数-过去的小时数为现在的小时数 在以60秒为一整份 取余计算得到的就是分钟数在用当前的时间%60就是秒数 最后我们插入想要的信息将上述设置的变量插入进去即可

window.onload=function starttime(){
        time(h1,'2022/2/1');     // 2021年春节时间
        ptimer = setTimeout(starttime,1000); // 添加计时器
}

function time(obj,futimg){
        var nowtime = new Date().getTime(); // 现在时间转换为时间戳
        var futruetime =  new Date(futimg).getTime(); // 未来时间转换为时间戳
        var msec = futruetime-nowtime; // 毫秒 未来时间-现在时间
        var time = (msec/1000);  // 毫秒/1000
        var day = parseInt(time/86400); // 天  24*60*60*1000 
        var hour = parseInt(time/3600)-24*day;    // 小时 60*60 总小时数-过去的小时数=现在的小时数 
        var minute = parseInt(time%3600/60); // 分 -(day*24) 以60秒为一整份 取余 剩下秒数 秒数/60 就是分钟数
        var second = parseInt(time%60);  // 以60秒为一整份 取余 剩下秒数
        obj.innerHTML="<br>距离长大一岁还有:<br>"+day+"天"+hour+"小时"+minute+"分"+second+"秒"+"<br><span>愿华为云社区小伙伴健康快乐<br>愿2022善待我们<br>May Huawei cloud community partners be healthy and happy <br>and may 2022 be kind to us</span>"
        return true;

(可选)我们也可以来设置背景音乐

</script>
  <audio id="bgmusic" src="https://y.qq.com/n/ryqq/player"></audio>
    <script type="text/javascript">
        document.addEventListener('DOMContentLoaded', function () {
            function audioAutoPlay() {
                var audio = document.getElementById('bgmusic');
                audio.play();
                document.addEventListener("WeixinJSBridgeReady", function () {
                    audio.play();
                    }, false);
                 }
                 audioAutoPlay();
                 });
</script>

src给一个背景的音乐链接 使用上方代码即可

代码到此就诠释的差不多了  我们来一起看看当前的代码效果吧

【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。