参考Vim版本的BadApple改写而成。由于加载数据比较大,可能网速不给力的童鞋效果不太好,多刷新几次就好了,^_^。
运行环境:支持HTML5 Canvas的浏览器。
​1. 代码:
$(function() {
    var BadApple = {
        is_running: false,
        data_index: 0,
        data_count: 67,
        is_loading: {},
        progress: $('#progress'),
        init: function() {
            var me = this,
                stage = $('#stage'),
                i;
 
            me.data_matrix = [];
            for (i = 0; i < me.frame_row; ++i) {
                me.data_matrix[i] = Array(me.frame_col).join(' ').split('');
            }
 
            me.canvas = stage.get(0);
            me.ctx = me.canvas.getContext('2d');
            me.canvas.width = me.frame_col * 7;
            me.canvas.height = me.frame_row * 16;
 
            me.ctx.fillStyle = 'rgba(0, 0, 0, .05)';
            me.ctx.fillRect(0, 0, me.canvas.width, me.canvas.height);
            me.ctx.fillStyle = '#7E7E7E';
            me.ctx.font = '12px monospace';
        },
        load_data: function (index, count, fn) {
            var me = this;
            if (!me.is_loading[index]) {
                // mark is loading
                me.is_loading[index] = true;
                $.get('data/BadApple/data_' + index + '.txt', function (data) {
                    // finish loading
                    me.is_loading[index] = null;
                    me.data_index = index;
                    data = data.split('\n');
                    // update progress
                    me.progress.html((index / me.data_count * 100).toFixed(2) + '%');
 
                    if (me.data) {
                        me.data = me.data.concat(data);
                    }
                    // first time
                    else {
                        me.data = data;
                        var rc = data[0].split(' ');
                        me.frame_row = parseInt(rc[0]);
                        me.frame_col = parseInt(rc[1]);
                        $('#div_loading').remove();
                        me.init();
                    }
 
                    if (count > 1 && index < me.data_count) {
                        me.load_data(index + 1, count - 1, fn);
                    }
                    else {
                        fn && fn();
                    }
                });
            }
        },
        draw_frame: function(data) {
            var me = this, i;
            for (i = 0; i < data.length; ++i) {
                me.data_matrix[data[i][0] - 1][data[i][1] - 1] = data[i][2];
            }http://www.huiyi8.com/jianbihua/​
            me.ctx.clearRect(0, 0, me.canvas.width, me.canvas.height);
            for (i = 0; i < me.frame_row; ++i) {
                me.ctx.fillText(me.data_matrix[i].join(''), 4, i * 14 + 16);
            }简笔画大全
        },
        play: function() {
            var me = this,
                i = 0,
                j,
                l,
                r;
            me.is_running = true;
            me.interval || (me.interval = setInterval(function () {
                if (me.is_running && i < me.data.length) {
                    l = me.data[++i];
                    r = [];
                    if (l && !/^\s*$/.test(l)) {
                        l = l.split('|');
                        for (j = 0; j < l.length; ++j) {
                            r[j] = l[j].split('_');
                        }
                    }
                    me.draw_frame(r);
                    // load data
                    if (i + 16 > me.data_index * 16 && 
                            me.data_index < me.data_count) {
                        me.load_data(me.data_index + 1, 2);
                    }
                }
            }, 70));
        },
        start: function() {
            var me = this;
            if (me.data) {
                me.play();
            }
            else {
                me.load_data(0, 1, function() {
                    me.play();
                });
            }
        },
        stop: function() {
            this.is_running = false;
        },
        terminal: function () {
            this.stop();
            clearInterval(this.interval);
        }
    };
 
    $('#stage').click(function() {
        BadApple.is_running ? 
            BadApple.stop() : 
            BadApple.start();
    }).click();
});

闲得蛋疼,JavaScript版本BadApple的更多相关文章

  1. 小王子浅读Effective javascript(一)了解javascript版本

    哈哈,各位园友新年快乐!愚安好久没在园子里写东西了,这次决定针对javascript做一个系列,叫做<小王子浅读Effective javascript>,主要是按照David Herma ...

  2. [闲的蛋疼系列]从零开始用TypeScript写React的UI组件(0)-先写一个Button??

    0.咸鱼要说的 一入前端深似海,咸鱼入海更加咸. 最近闲的蛋疼,手上年前的事也完成了7788了,借助[PG1]的话来说,我们要keep real. 咸鱼肯定不real 了,因为我们都活在梦里,所以咱们 ...

  3. 介绍一种在ABAP内核态进行内表高效拷贝的方法,和对应的Java和JavaScript版本的伪实现

    内表操作是ABAP开发人员几乎在每个ABAP程序里都会遇到的. 看一个例子:有两个行结构不一样的内表,每个内表的行结构有三列,除了name这一列名字一致外,其他两列的名称都不同,下图用红色和蓝色标注出 ...

  4. 经典算法:快排的Javascript版本

    function swap(arr,l,r){ var temp=arr[l]; arr[l]=arr[r]; arr[r]=temp; } function partition(arr,camp,l ...

  5. JavaScript 版本的 RSA加密库文件

    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/ ...

  6. 伟大的通信使者——JSON(JavaScript版本)

    JSON(JavaScript Object Notation, JS 对象标记) 是一种轻量级的数据交换格式.它基于 ECMAScript 规范的一个子集,采用完全独立于编程语言的文本格式来存储和表 ...

  7. Struts2-Ajax整合之纯JavaScript版本

    1.Ajax的作用:能够在不重新加载页面的情况下,用异步的方式与后台服务器进行数据交互 2.Struts2-Json的jar包(包含阿里巴巴自己的jar包) commons-beanutils-1.7 ...

  8. 生日礼物网页Javascript版本与锚点版本

    <style> #dv1{ width:60px; height:36px; margin:0 auto; background-color:orange; display:none; } ...

  9. BF算法和KMP算法(javascript版本)

    var str="abcbababcbababcbababcabcbaba";//主串 var ts="bcabcbaba";//子串 function BF( ...

随机推荐

  1. python自定义模块导入方法,文件夹,包的区别

    python模块导入,网上介绍的资料很多,方法也众说纷纭.根据自己的实践,感觉这个方法最简单直接,而且可以与主流的python ide生成的工程是一样的. 规则只有三条 1.      严格区分包和文 ...

  2. 洛谷P2058 海港

    题目描述 小K是一个海港的海关工作人员,每天都有许多船只到达海港,船上通常有很多来自不同国家的乘客. 小K对这些到达海港的船只非常感兴趣,他按照时间记录下了到达海港的每一艘船只情况:对于第i艘到达的船 ...

  3. 【bzoj1042】[HAOI2008]硬币购物-递推与动规-容斥原理

    硬币购物 硬币购物一共有4种硬币.面值分别为c1,c2,c3,c4.某人去商店买东西,去了tot次.每次带di枚ci硬币,买si的价值的东西.请问每次有多少种付款方法. Input 第一行 c1,c2 ...

  4. 深入理解计算机操作系统——第11章:全球IP英特网

    全球IP英特网 (1)每台英特网主机都运行实现TCPIP协议的软件. (2)英特网的客户端和服务器混合使用套接字接口函数和Unix IO函数来进行通信. (3)套接字函数典型的是作为陷入内核的系统调用 ...

  5. Python()-类命名空间和对象/实例命名空间

    类命名空间和对象/实例命名空间: 创建类, 就会创建一个类的名称空间, 空间:存储类的属性 属性: 静态属性:直接定义在类下面 & 和类名关联 的变量 对象属性:在类内和self关联 & ...

  6. django学习之- Form

    参考:http://www.cnblogs.com/wupeiqi/articles/6144178.htmlFORM中的字段只对post上来的数据进行form验证,主要涉及:字段 和 插件字段:对用 ...

  7. 洛谷 P3811 【模板】乘法逆元

    P3811 [模板]乘法逆元 题目背景 这是一道模板题 题目描述 给定n,p求1~n中所有整数在模p意义下的乘法逆元. 输入输出格式 输入格式: 一行n,p 输出格式: n行,第i行表示i在模p意义下 ...

  8. httpclient请求去掉返回结果string中的多余转义字符

    public String doGet() { String uriAPI = "http://XXXXX?str=I+am+get+String"; String result= ...

  9. jsoup 提取 html 中的所有链接、图片和媒体

    原文:http://www.open-open.com/code/view/1420729333515 package org.jsoup.examples; import org.jsoup.Jso ...

  10. Spring MVC 异步处理请求,提高程序性能

    原文:http://blog.csdn.net/he90227/article/details/52262163 什么是异步模式 如何在Spring MVC中使用异步提高性能? 一个普通 Servle ...