HTML5 Canvas彩色小球碰撞运动特效

脚本简介HTML5Canvas彩色小球碰撞运动特效是一款基于canvas加面向对象制作的运动小球动画特效。效果展示 http://hovertree.com/texiao/html5/

大家好,又见面了,我是全栈君,今天给大家准备了Idea注册码。

脚本简介

HTML5 Canvas彩色小球碰撞运动特效是一款基于canvas加面向对象制作的运动小球动画特效。
 
 
效果图如下:


HTML5 Canvas彩色小球碰撞运动特效

代码如下:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>HTML5 Canvas彩色小球碰撞运动特效 - 何问起</title>
    <base target="_blank" />

    <style>
        #hovertreeball {
            border: 1px dashed #999;
            box-shadow: 0px 4px 40px #233;
            background: black;
        }
        .hovertreeinfo{text-align:center;}
        a{color:blue;}
    </style>
</head>
<body>
    <div class="hovertreeinfo" >
        提示:可以点击按钮改变背景颜色<br />
        <canvas id="hovertreeball" width="800" height="600"></canvas>
    </div>
<script type="text/javascript">
    var canvas = document.getElementById("ho"+"vertreeball");
    var context = canvas.getContext("2d");
    var maxWidth = canvas.width;
    var maxHeight = canvas.height;
    var colors = ["#33B5E5", "#0099CC", "#AA66CC", "#9933CC", "#99CC00", "#669900", "#FFBB33", "#FF8800", "#FF4444", "#CC0000"]

    //随机数
    function random(min, max) {
        return Math.floor(Math.random() * (max - min) + min)
    }

    //构造函数
    function Ball() {
        this.a = true;
        this.b = true;
        this.r = random(10, 30);
        this.ballColor = { color: colors[Math.floor(Math.random() * colors.length)] }
        this.vx = random(30, maxWidth - 30);
        this.vy = random(30, maxHeight - 30);
        this.ispeed = random(1, 10);
        this.ispeed2 = random(1, 10);
    }

    // 面向对象
    Ball.prototype.moveBall = function () {
        context.beginPath();
        if (this.a) {
            this.vx += this.ispeed;
            if (this.vx >= maxWidth - this.r) {
                this.a = false;
            }

        } else {
            this.vx -= this.ispeed;
            if (this.vx <= this.r) {
                this.a = true;
            }
        }

        if (this.b) {
            this.vy += this.ispeed2;
            if (this.vy >= maxHeight - this.r) {
                this.b = false;
            }

        } else {
            this.vy -= this.ispeed2;
            if (this.vy <= this.r) {
                this.b = true;
            }
        }

        context.fillStyle = this.ballColor.color;
        context.arc(this.vx, this.vy, this.r, 0, Math.PI * 2, false);
        context.fill();
    }

    var Aball = [];
    for (var i = 0; i < 100; i++) {
        Aball[i] = new Ball();
    }

    setInterval(function () {
        context.clearRect(0, 0, canvas.width, canvas.height)
        for (var i = 0; i < 100; i++) {
            Aball[i].moveBall();
        }

    }, 30)
    function hovertreecolor() {
        if (canvas.style.backgroundColor != "white") {
            canvas.style.backgroundColor = "white";
        }
        else {
            canvas.style.backgroundColor = "black";
        }
    }
</script>

<div style="text-align:center;margin:10px 0; font:normal 14px/24px 'MicroSoft YaHei';">
    <button id="hovertreechange">改变背景颜色</button>
<p>适用浏览器:FireFox、Chrome、Safari、Opera、傲游、搜狗、世界之窗等. 不支持IE8及以下浏览器。</p>
<p>来源:<a href="http://hovertree.com/" target="_blank">何问起</a> <a href="http://hovertree.com/menu/texiao/">网页特效</a>
<a href="http://hovertree.com/h/bjaf/mll8cpr3.htm">代码说明</a></p>
</div>
    <script>
        document.getElementById("hover" + "treechange").addEventListener("click", hovertreecolor)
    </script>
</body>
</html>

转自:http://hovertree.com/h/bjaf/mll8cpr3.htm

更多特效:http://www.cnblogs.com/roucheng/p/texiao.html

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

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/120304.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • 深度学习——SPPNet原理[通俗易懂]

    深度学习——SPPNet原理[通俗易懂]从R-CNN到FastR-CNN,有必要了解下SPPNet,其全称为SpatialPyramidPoolingConvolutionalNetworks(空间金字塔池化卷积网络)。它将CNN的输入从固定尺寸改进为任意尺寸,例如在CNN结构中,输入图像的尺寸往往固定的(如224×224像素),输出可看做固定维数的向量。SPPNet在普通的CNN结构中加入了ROI池化层(ROIPo…

  • redflag linux6.0 sp2桌面版,红旗Linux桌面版(Red Flag Linux)

    redflag linux6.0 sp2桌面版,红旗Linux桌面版(Red Flag Linux)第一次听说红旗Linux的“Favour”吗?现在的新名词太多,你作为第二个听说的人,一点也不落伍从09年起,针对Linux开源技术的发展特点,红旗Linux对个人版产品线做了重要调整,其中“Favour”版将尽可能把最新、最炫的DD呈现给关注开源技术的“红Fan家人”们,也希望获得更多爱好者对红旗Linux产品的关注、反馈和支持。红旗inWise操作系统V8.0是对系统软件包组件的升级和稳定性易…

  • server宕机监控、检測、报警程序(139绑定手机短信报警)monitor_down.sh

    server宕机监控、检測、报警程序(139绑定手机短信报警)monitor_down.sh

  • powermodule_getsocketopt

    powermodule_getsocketopt严格模式ES6的模块自动采用严格模式,不管你有没有在模块头部加上"usestrict";。严格模式的限制如下变量必须声明后再使用函数的参数不能有同名属性,否则报错不能

  • 一些sql二

    1、说明:复制表(只复制结构,源表名:a 新表名:b) (Access可用)法一:select * into b from a&#

    2021年12月25日
  • 手机客户端设置同济邮箱的方法「建议收藏」

    手机客户端设置同济邮箱的方法「建议收藏」手机客户端设置同济邮箱的方法(以苹果为例):依次点击:“设置”-“邮件”-“账户”-“添加账户”。选择邮箱,因为是学校邮箱所以不属于主流服务器,点击“其他”-“添加邮件账户”。输入邮件地址与密码,注意,这里的密码不是自己的邮件密码,需要填写由网页端邮箱生成的IMAP密码,该密码只会在生成时显示!填写完成后点击“下一步”。收件服务器和发件服务器中的主机名填写:imap.tongji.edu.cn,用户名填自己的邮箱地址即可,密码不用填。提示无SSL保护,没关系继续登录。设置完成,可以在手机端正

发表回复

您的电子邮箱地址不会被公开。

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