• 经营者要想“我心换你心”,就要未雨绸缪,让不诚信的诱惑少一点,如此才能在市场中生存下来。反过来说,承担不起亏损就关门歇业,是否也是一种不诚信呢? 2019-09-14
  • 上海市陆家嘴:打造社区多元治理“共同体” 2019-09-14
  • 2017最具体育活力城市排行榜 2019-09-14
  • 李克勤献唱央视“世界杯主题歌” 2018国语专辑筹备中李克勤 世界杯 2019-09-08
  • 回复@看着就想笑:难道公有制社会主义就不能生存发展吗?事实上公有制会生存发展的更好! 2019-09-03
  • 陵川县全力推进乡村振兴战略 2019-09-01
  • 周国平:男女之爱已经很强烈了,但亲子之爱更强烈 2019-09-01
  • 出租广州市荔湾区芳村大道东169号 2019-08-29
  • (原创)取消“份子钱”是出租车改革必须迈出的一步 2019-08-21
  • Facebook公关掌门离职 是应对隐私丑闻干将 2019-08-20
  • 你这纯粹是胡说八道!农民的宅基地,需要交钱才能使用吗?你敢推行这样的政策吗?你也只敢推行对工人的住宅地,要交钱才能使用!这样合理吗?那些交不起房钱的人,难道应该 2019-08-13
  • 西部网(陕西新闻网)硬科技频道 2019-08-13
  • 新华时评:成果不易,更需诚意与信任呵护 2019-08-09
  • 好好的书报亭放没放样,周围堆得一塌糊涂乱七八糟,真正的主人都搓麻将去了。再现代化造型在金钱至上的社会不可能再有相应的雅知气了。 2019-08-09
  • 2018海创会带你领略黑科技产品 2019-08-05
  • 平码贴吧:Html5 canvas实现粒子时钟的示例代码

    平码三中山论坛 www.mslzq.tw 我们先看看粒子时钟的效果,如下:

    下面我们将通过canvas和js实现,

    首先要创建一个html文件并添加一个canvas画布,如下:

    
        Document - 平码三中山论坛|平码高手论坛网址

    下面导入素材,digit.js,素材中通过二维数组拼成一个个数字,共有:0-9和冒号,十个字符,如下:

    可以看到为1的字符组成了

    下面开始创建画布:

    function Clock() {
            var canvas = document.getElementById("canvas");
            canvas.width = 600;
            canvas.height = 100;
            this.cxt = canvas.getContext('2d');
            this.cxt.fillStyle="#ddd";
            this.cxt.fillRect(0, 0, 500, 100);
        }

    上面的代码就可以在浏览器画一个小灰色画布了

    下面我们开始分析:

    1.了解数据矩阵?就是多维数组

    2.如何画圆?

    2.1要先知道半径?

    由上图得知,圆心的位置依次为:

    r+1
    r+1 + (r+1)*2*1
    r+1 + (r+1)*2*2
    。。。
    r+1 + (r+1)*2*i

    同时,也可以通过计算圆的高度,得到半径,如下:

    一个圆的高度是(r+1)*2,画布高度是由10个圆组成

    canvasHeight = (r+1)*2*10

    若将画布高度设为100,则r就出来了,圆心xy也出来了,开始画圆了
    先要在上面的Clock对象中加一条语句,计算r

    this.r = 100/20-1;

    下面我在Clock的原型上加上draw方法

    Clock.prototype.draw = function(num, index) {
            this.cxt.fillStyle="#000";
            for (let i=0; i

    draw接收2个参数,第一个是字符索引,第二个是字符偏移顺序,70就是一个偏移距离,可以自定。
    第一个for,拿到要渲染的字符数组,第二个for,取每一行进行渲染且只渲染为1的,画圆的参数主要是x,y,r

    下面就要得到时间,我们可以直接从new Date中用正则取时间,如下:

    Clock.prototype.getTime = function() {
            var reg = /(\d)(\d):(\d)(\d):(\d)(\d)/.exec(new Date());
            var data = [];
            data.push(reg[1], reg[2], 10, reg[3], reg[4], 10, reg[5], reg[6]);
            for (var i=0; i

    通过正则可以方便的取到时分秒,在push数组时注意格式对应,其中10表示digit.js中的第10位字符,即冒号
    注意 这样画会有问题,即画布不能刷新,可以加上这个

    canvas.height= 100

    下面可以运行代码了,如下:

    var clock = new Clock();
    setInterval(()=>{
            clock.getTime();
        })

    好了,这样就ok了

    以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持CAD之家。

    为您推荐

    发表评论

    联系我们

    联系我们

    在线咨询: QQ交谈

    地址:中国·贵州·贵阳 友情链接QQ:1034559333 本站QQ群:123733639
    关注微信
    微信扫一扫关注我们

    微信扫一扫关注我们

    关注微博
    返回顶部

    关于本站 || 版权声明 || 免责条款 || 隐私条款 || 平码三中山论坛 || ||

    Copyright??2018 平码三中山论坛 All Rights Reserved·黔ICP备15000265号-2

  • 经营者要想“我心换你心”,就要未雨绸缪,让不诚信的诱惑少一点,如此才能在市场中生存下来。反过来说,承担不起亏损就关门歇业,是否也是一种不诚信呢? 2019-09-14
  • 上海市陆家嘴:打造社区多元治理“共同体” 2019-09-14
  • 2017最具体育活力城市排行榜 2019-09-14
  • 李克勤献唱央视“世界杯主题歌” 2018国语专辑筹备中李克勤 世界杯 2019-09-08
  • 回复@看着就想笑:难道公有制社会主义就不能生存发展吗?事实上公有制会生存发展的更好! 2019-09-03
  • 陵川县全力推进乡村振兴战略 2019-09-01
  • 周国平:男女之爱已经很强烈了,但亲子之爱更强烈 2019-09-01
  • 出租广州市荔湾区芳村大道东169号 2019-08-29
  • (原创)取消“份子钱”是出租车改革必须迈出的一步 2019-08-21
  • Facebook公关掌门离职 是应对隐私丑闻干将 2019-08-20
  • 你这纯粹是胡说八道!农民的宅基地,需要交钱才能使用吗?你敢推行这样的政策吗?你也只敢推行对工人的住宅地,要交钱才能使用!这样合理吗?那些交不起房钱的人,难道应该 2019-08-13
  • 西部网(陕西新闻网)硬科技频道 2019-08-13
  • 新华时评:成果不易,更需诚意与信任呵护 2019-08-09
  • 好好的书报亭放没放样,周围堆得一塌糊涂乱七八糟,真正的主人都搓麻将去了。再现代化造型在金钱至上的社会不可能再有相应的雅知气了。 2019-08-09
  • 2018海创会带你领略黑科技产品 2019-08-05
  • 真钱打鱼 内蒙11选五最大遗漏值 三肖中特马 福彩快乐十分今天开奖 重庆时时宝宝计划 中国竞彩网手机版本 2019港台神算彩图2期 香港1668开奖报马结果 福州十三水玩法 安徽时时彩快三