1024 开源“擂台”赛来了,听说奖品可以拿到手软

达尔文 发布于 10/21 18:03
阅读 7K+
收藏 12

 

又到了一年一度的 1024 程序员节,

这节,当然是要过的,这班,当然也还是要上的。

但是上区区一个班怎么能阻止我们对节日的向往呢!

在这个金秋十月硕果飘香的日子里,

小编为 1024 准备了一点小小的礼物,不成敬意~

 

花生棒pro

花生棒标准版

技术书籍

开源中国限量版T恤

开源马克杯

 

心动了吗?

怎么才能抱走他们呢?

嘿嘿,来开源中国参加【开源武林“擂台”赛】吧!

用实力一决高下~

 

擂台一:内力比拼

 

活动介绍:这是代码执行效果PK环节。参赛的各位选手在底部留言区留下一段可在此页面的 console 里运行的代码(注:要求 Chrome 浏览器),运行后的效果需要与“1024 程序员节”有关,可以是精彩的节日特效,也可以是暖心的节日祝福等,任你发挥!

留言要求主题名称+执行代码+效果预览截图(这样效果更加直观哦~)

示例

活动时间:10月22日-10月23日

评选规则

1、初选:23日 18:00 之后由工作人员选出优秀的20位进入决赛

2、决赛:24日在【擂台三:颜值大赏】公布进入决赛的名单,并由观众投票选出最优秀的前10名送出奖品

奖品设置

一等奖 1 名:花生棒 pro*1

二等奖 2 名:花生棒标准版*1

三等奖 3 名:技术图书*1+限量版t恤*1+开源马克杯*1

鼓励奖 4 名:技术图书*1

 

擂台二:意念切磋

敬请期待......

 

擂台三:颜值大赏

敬请期待......

 

我们是谁?

程序猿!

我们的节日是哪一天?

1024!

我们要怎么庆祝?

新需求不接!旧 Bug 不改!

不对不对,我们要参加开源中国“擂台”赛!为自己打 Call!

快来吧,底部留言等你来放大招哟~

加载中
3
夏夜微凉
夏夜微凉

$('.p-question-detail').css('transform','rotateX(180deg)');     

$('.p-question-detail').css('-webkit-transform','rotateX(180deg)');     

$('.p-question-detail').css('-moz-transform','rotateX(180deg)');

三行代码权当娱乐

ITxiaoniu
ITxiaoniu
这是什么毒
dafengchui
dafengchui
有毒诶
monr
monr
社会社会,吓得我赶紧把电脑倒过来
岁月的云
岁月的云
有毒
挪鸡鸭
挪鸡鸭
有毒
下一页
3
Lison-Liou
Lison-Liou

主题名称:1024节送你多金多祝福(翻出老码改一改,其实我就这水平了)

执行代码:

/**
 * author @Lison-Liou
 *
 * @url https://lison.cc/552.html
 * @type {string}
 *
 *
 * //红色选择六个数 1-33里选
 * //蓝色选择一个数 1-16里选
 *
 */


var css = "html{font-size:12px;font-family:\"sans serif\",tahoma,verdana,helvetica}body{text-align:center;padding-top:20%}#pool{padding:10px;border:dashed 1px orangered;width:40%;min-height:200px;margin-left:auto;margin-right:auto;max-height:200px;overflow:auto;overflow-y:yes}#pool span{font-size:24px;line-height:36px}#pool .red{color:indianred}#pool .blue{color:dodgerblue}.red{color:indianred}.blue{color:dodgerblue}.green{color:forestgreen}.purple{color:mediumpurple}.pink{color:deeppink}.dark{color:black}.yellow{color:yellowgreen}";
var html = "<div><h1 class=\"title\" id=\"title\">1024节日祝福 送你海多双色球 多金多到数不完</h1></div><br/><div id=\"pool\"></div><br/><button id=\"lotty\">LOTTY ME~!</button><button id=\"scroll\">SCROLL@</button><button id=\"clear\">CLEAR^</button>";

var ticket = {};

function init() {
    var head = document.head;
    var body = document.body;

    head.innerHTML = "<style type=\"text/css\">" + css + "</style>";
    body.innerHTML = html;

    var btn = document.getElementById('lotty');

//摇奖按钮事件
    btn.addEventListener('click', function () {

        reset_ticket();
        for (var i = 0; i < 6; i++) {
            ticket['red'].push(Math.floor(Math.random() * 33 + 1));
        }

        ticket['blue'] = Math.floor(Math.random() * 16 + 1);

        append_pull(ticket);
    });

//自动滚动生成
    var scroll = document.getElementById("scroll");
    var interval;
    scroll.addEventListener('click', function () {
        if (scroll.innerHTML == 'SCROLL@') {
            scroll.innerHTML = "PAUSE-";
            //开始滚动
            interval = setInterval(function () {
                btn.click();
            }, 1000);
        }
        else {
            scroll.innerHTML = "SCROLL@";
            clearInterval(interval);
        }
    });

    var clear = document.getElementById('clear');
    clear.addEventListener('click', function () {
        var pool = document.getElementById('pool');
        pool.innerHTML = '';
    });

    blink();
}


//title变换颜色class组
var colors = ['red', 'blue', 'green', 'purple', 'pink', 'dark', 'yellow'];

//闪烁标题
var blink = function () {
    var title = document.getElementById('title');
    var titles = title.innerHTML.split('');

    setInterval(function () {
        var html = '';
        for (var i = 0; i < titles.length; i++) {
            html += '<span class=' + colors[Math.floor(Math.random() * 7)] + '>' + titles[i] + '</span>';
        }
        title.innerHTML = html;
    }, 1000);
};

//生成结果滚动展示
function append_pull(ticket) {
    var pool = document.getElementById('pool');
    pool.innerHTML = pool.innerHTML + "<span class=\'red\'>" + ticket['red'].join("    ") + "</span><span class=\'blue\'>   (" + ticket['blue'] + ")</span><br />";

    setInterval(scroll_end(pool), 100);
    reset_ticket();
}

//重置ticket
function reset_ticket() {
    ticket = {};
    ticket['red'] = [];
    ticket['blue'] = null;
}

//滚动到对象底部
function scroll_end(e) {
    e.scrollTop = e.scrollHeight;
}

init();

效果预览截图

为什么我是第一个,哦我知道了,我是前锋炮灰

达尔文
达尔文
厉害了
2
宇润
宇润

主题:祝 1024 程序员节暴富!

执行代码:

var info = document.createElement("div");
info.style = 'top:0;position: absolute;width: 100%;font-family: monospace;text-align: center;z-index: 99999999999999999;background: linear-gradient(to right,rgba(78,170,76,.5),rgba(0,202,133,.5)),#4eaa4c;height: 100%;'
info.innerHTML = '<div style="top:0;position: absolute;z-index:999999;width:100%;text-align:center;background:rgba(0,0,0,0.2);color:#fff;line-height: 1rem;"><h1>祝 1024 程序员节暴富!</h1><p>背景是开源中国色</p></div>';
document.body.appendChild(info);
var canvas = document.createElement("canvas");
canvas.style='position: absolute;left: 0;top:0'
canvas.width = window.innerWidth;
canvas.height = window.innerHeight;
info.appendChild(canvas);
var context = canvas.getContext("2d"),
id = 1,
cwidth = 271,
cwidthhalf = cwidth / 2,
cheight = 140,
cheighthalf = cheight / 2,
particles = [],
Particle = function(a, b, c, d, e) {
    0 === d && (d = 2);
    var f = a % 1 * cwidth,
    g = Math.floor(a / 1) * cheight;
    this.update = function() {
        b += d;
        c += e;
        if (b < -cwidthhalf || b > canvas.width + cwidthhalf) {
            var a = particles.indexOf(this);
            particles.splice(a, 1);
            return ! 1
        }
        c > canvas.height - cheighthalf && (c = canvas.height - cheighthalf, e = 0.85 * -e);
        e += 0.98;
        context.drawImage(image, f, g, cwidth, cheight, Math.floor(b - cwidthhalf), Math.floor(c - cheighthalf), cwidth, cheight);
        return ! 0
    }
},
image = document.createElement("img");
image.src = "";
var throwCard = function(a, b) {
    0 < id ? id--:id = 0;
    var c = new Particle(id, a, b, 2 * Math.floor(6 * Math.random() - 3), 16 * -Math.random());
    particles.push(c)
};
document.addEventListener("mousedown",
function(a) {
    a.preventDefault();
    document.addEventListener("mousemove", onMouseMove, !1)
},
!1);
document.addEventListener("mouseup",
function(a) {
    a.preventDefault();
    throwCard(a.clientX, a.clientY);
    document.removeEventListener("mousemove", onMouseMove, !1)
},
!1);
function onMouseMove(a) {
    a.preventDefault();
    throwCard(a.clientX, a.clientY)
}
document.addEventListener("touchstart",
function(a) {
    a.preventDefault();
    for (var b = 0; b < a.changedTouches.length; b++) throwCard(a.changedTouches[0].pageX, a.changedTouches[0].pageY)
},
!1);
document.addEventListener("touchmove",
function(a) {
    a.preventDefault();
    for (var b = 0; b < a.touches.length; b++) throwCard(a.touches[b].pageX, a.touches[b].pageY)
},
!1);
function random(a, b) {
    var c = b - a,
    d = Math.random();
    return a + Math.round(d * c)
}
setInterval(function() {
    50 > particles.length && throwCard(random(0, canvas.clientWidth), random(200, canvas.clientHeight));
    for (var a = 0,
    b = particles.length; a < b;) particles[a].update() ? a++:b--
},
1E3 / 60);

效果预览截图:

(单张图无法表现出震撼,请自行运行代码!)

Chiroc
Chiroc
Wooh
达尔文
达尔文
亮瞎了:)
2
开源红薯烹调技术专家
开源红薯烹调技术专家

主题:薯傲天的祝福

来自薯傲天大大的 超位魔法 "1024的祝福 "  只能祝福上面的兄弟们了

来晚了!!代码也上不来了,只能截图了  哈哈~~ (用到了开源SVGA项目的动画框架和素材支持)

1
fly2xiang
fly2xiang

主题:祝你1024节日快乐

执行代码:

var $canvas = $('<canvas id="canvas"></canvas>');
$canvas.appendTo($('body'));
$('body').css({
    overflow: 'hidden'
});
$canvas.attr({
    width: window.innerWidth,
    height: window.innerHeight
});
$canvas.css({
    position: 'fixed',
    top: 0,
    left: 0,
    right: 0,
    bottom: 0,
    'z-index': 10000,
    'background': 'rgba(0, 0, 0, 0.8)'
});

window.requestAnimFrame = (function () {
    return window.requestAnimationFrame ||
        window.webkitRequestAnimationFrame ||
        window.mozRequestAnimationFrame ||
        function (callback) {
            window.setTimeout(callback, 1000 / 60);
        };
})();

var canvas = document.getElementById('canvas'),
    ctx = canvas.getContext('2d'),
    cw = window.innerWidth,
    ch = window.innerHeight,
    fireworks = [],
    particles = [],
    hue = 120,
    limiterTotal = 5,
    limiterTick = 0,
    timerTotal = 80,
    timerTick = 0,
    mousedown = false,
    mx,
    my;

canvas.width = cw;
canvas.height = ch;

function random(min, max) {
    return Math.random() * (max - min) + min;
}

function calculateDistance(p1x, p1y, p2x, p2y) {
    var xDistance = p1x - p2x,
        yDistance = p1y - p2y;
    return Math.sqrt(Math.pow(xDistance, 2) + Math.pow(yDistance, 2));
}

function Firework(sx, sy, tx, ty) {
    this.x = sx;
    this.y = sy;
    this.sx = sx;
    this.sy = sy;
    
    this.tx = tx;
    this.ty = ty;
    
    this.distanceToTarget = calculateDistance(sx, sy, tx, ty);
    this.distanceTraveled = 0;
    
    this.coordinates = [];
    this.coordinateCount = 3;
    
    while (this.coordinateCount--) {
        this.coordinates.push([this.x, this.y]);
    }
    this.angle = Math.atan2(ty - sy, tx - sx);
    this.speed = 2;
    this.acceleration = 1.05;
    this.brightness = random(50, 70);
    
    this.targetRadius = 1;
}


Firework.prototype.update = function (index) {
    
    this.coordinates.pop();
    
    this.coordinates.unshift([this.x, this.y]);

    
    if (this.targetRadius < 8) {
        this.targetRadius += 0.3;
    } else {
        this.targetRadius = 1;
    }

    
    this.speed *= this.acceleration;

    
    var vx = Math.cos(this.angle) * this.speed,
        vy = Math.sin(this.angle) * this.speed;
    
    this.distanceTraveled = calculateDistance(this.sx, this.sy, this.x + vx, this.y + vy);

    
    if (this.distanceTraveled >= this.distanceToTarget) {
        createParticles(this.tx, this.ty);
        
        fireworks.splice(index, 1);
    } else {
        
        this.x += vx;
        this.y += vy;
    }
};


Firework.prototype.draw = function () {
    ctx.beginPath();
    
    ctx.moveTo(this.coordinates[this.coordinates.length - 1][0], this.coordinates[this.coordinates.length - 1][
        1
        ]);
    ctx.lineTo(this.x, this.y);
    ctx.strokeStyle = 'hsl(' + hue + ', 100%, ' + this.brightness + '%)';
    ctx.stroke();

    ctx.beginPath();
    
    ctx.arc(this.tx, this.ty, this.targetRadius, 0, Math.PI * 2);
    ctx.stroke();
};


function Particle(x, y) {
    this.x = x;
    this.y = y;
    
    this.coordinates = [];
    this.coordinateCount = 5;
    while (this.coordinateCount--) {
        this.coordinates.push([this.x, this.y]);
    }
    
    this.angle = random(0, Math.PI * 2);
    this.speed = random(1, 10);
    
    this.friction = 0.95;
    
    this.gravity = 1;
    
    this.hue = random(hue - 20, hue + 20);
    this.brightness = random(50, 80);
    this.alpha = 1;
    
    this.decay = random(0.015, 0.03);
}


Particle.prototype.update = function (index) {
    
    this.coordinates.pop();
    
    this.coordinates.unshift([this.x, this.y]);
    
    this.speed *= this.friction;
    
    this.x += Math.cos(this.angle) * this.speed;
    this.y += Math.sin(this.angle) * this.speed + this.gravity;
    
    this.alpha -= this.decay;

    
    if (this.alpha <= this.decay) {
        particles.splice(index, 1);
    }
};




Particle.prototype.draw = function () {

    ctx.beginPath();

    ctx.moveTo(this.coordinates[this.coordinates.length - 1][0], this.coordinates[this.coordinates.length - 1][
        1
        ]);
    ctx.lineTo(this.x, this.y);
    ctx.strokeStyle = 'hsla(' + this.hue + ', 100%, ' + this.brightness + '%, ' + this.alpha + ')';
    ctx.stroke();

};


function createParticles(x, y) {
    
    var particleCount = 30;
    while (particleCount--) {
        particles.push(new Particle(x, y));
    }
}


function loop() {
    
    requestAnimFrame(loop);

    
    hue += 0.5;

    
    
    
    ctx.globalCompositeOperation = 'destination-out';
    
    ctx.fillStyle = 'rgba(0, 0, 0, 0.5)';
    ctx.fillRect(0, 0, cw, ch);
    
    
    ctx.globalCompositeOperation = 'lighter';

    var text = "HAPPY 1024 DAY !";
    ctx.font = "50px sans-serif";
    var textData = ctx.measureText(text);
    ctx.fillStyle = "rgba(" + parseInt(random(0, 255)) + "," + parseInt(random(0, 255)) + "," + parseInt(random(0,
        255)) + ",0.3)";
    ctx.fillText(text, cw / 2 - textData.width / 2, ch / 2);

    
    var i = fireworks.length;
    while (i--) {
        fireworks[i].draw();
        fireworks[i].update(i);
    }

    
    var i = particles.length;
    while (i--) {
        particles[i].draw();
        particles[i].update(i);
    }

    
    if (timerTick >= timerTotal) {
        if (!mousedown) {
            

            for (var h = 0; h < 50; h++) {
                fireworks.push(new Firework(cw / 2, ch / 2, random(0, cw), random(0, ch)));
            }

            timerTick = 0;
        }
    } else {
        timerTick++;
    }

    
    if (limiterTick >= limiterTotal) {
        if (mousedown) {
            
            fireworks.push(new Firework(cw / 2, ch / 2, mx, my));
            limiterTick = 0;
        }
    } else {
        limiterTick++;
    }
}



canvas.addEventListener('mousemove', function (e) {
    mx = e.pageX - canvas.offsetLeft;
    my = e.pageY - canvas.offsetTop;
});


canvas.addEventListener('mousedown', function (e) {
    e.preventDefault();
    mousedown = true;
});

canvas.addEventListener('mouseup', function (e) {
    e.preventDefault();
    mousedown = false;
});

loop();

执行效果预览截图:

HAPPY 1024 DAY !

av
av
不错
达尔文
达尔文
Cool!!!!
1
寒川
寒川

主题名称:黑客帝国1024 oschina

执行代码:

var canvas = document.createElement("canvas");
canvas.style='position: absolute;left: 0;top:0;z-index:999;';
canvas.width = window.innerWidth;
canvas.height = window.innerHeight;
document.body.appendChild(canvas);
var ctx = canvas.getContext('2d');
var texts = '1024 oschina'.split('');
var fontSize = 16;
var columns = canvas.width/fontSize;
var drops = [];
for(var x = 0; x < columns; x++){
    drops[x] = 1;
}

function draw(){
    ctx.fillStyle = 'rgba(0, 0, 0, 0.05)';
    ctx.fillRect(0, 0, canvas.width, canvas.height);
    ctx.fillStyle = '#0F0';
    ctx.font = fontSize + 'px arial';
    for(var i = 0; i < drops.length; i++){
        var text = texts[Math.floor(Math.random()*texts.length)];
        ctx.fillText(text, i*fontSize, drops[i]*fontSize);

        if(drops[i]*fontSize > canvas.height || Math.random() > 0.95){
            drops[i] = 0;
        }

        drops[i]++;
    }
}

setInterval(draw, 33);

效果预览截图:

aron1992
aron1992
这个好
1
小水熊
小水熊
for(var i=0;i<=1024;i++)alert('哈哈:'+i);

卡死了,截图没能发上来,抱歉。

dafengchui
dafengchui
快回去睡觉,尬
达尔文
达尔文
有毒
1
正在加载2
正在加载2

菜鸟小试牛刀~简单地祝大家1024节日快乐 

let letsBegin = function () {
    console.log('letsBegin')

    let clientWidth = document.documentElement.clientWidth
    let clientHeight = document.documentElement.clientHeight

    let $body = $(document.body)
    $body.html(
'<canvas id="canvas"></canvas>' +
'<div id="cover" style="position: fixed;z-index: 1000;background-color: rgba(0, 0, 0, 0);width: 100%;height: 100%;top: 0;left: 0;display: flex;align-items: center;color: white;">' +
    '<div id="coverInner" style="width: 100%;text-align: center;">祝大家1024程序员节快乐!!!</div>' +
'</div>'
    )
    $body.css("background-color", "black");
    $body.css("margin", "0");
    $body.css("overflow", "hidden");

    let $cover = $('#cover')
    let $coverInner = $('#coverInner')



    //
    const PHI = (1 + Math.sqrt(5)) / 2, // 1.618033988749895
        maxGeneration = (navigator.userAgent.toLowerCase().indexOf('firefox') > -1) ? 5 : 6,
        frameDuration = 1000 / 60,
        duration = 3000,
        rotationSpeed = 0.3,
        totalIterations = Math.floor(duration / frameDuration),
        maxBaseSize = 100,
        baseSizeSpeed = 0.02;

    var canvas = document.getElementById("canvas"),
        ctx = canvas.getContext("2d"),
        canvasWidth = document.documentElement.clientWidth,
        canvasHeight = document.documentElement.clientHeight,
        shapes = [],
        sizeVariation,
        iteration = 0,
        animationDirection = 1,
        sizeVariationRange = .15,
        baseRotation = 0,
        baseSize = 50,
        c1 = 43,
        c1S = 1,
        c2 = 205,
        c2S = 1,
        c3 = 255,
        c3S = 1;

    canvas.setAttribute("width", canvasWidth);
    canvas.setAttribute("height", canvasHeight);

    function Shape(gen, x, y, size, rotation) {
        this.generation = gen;
        this.size = size;
        this.rotation = -rotation;
        this.start = {
            x: x,
            y: y
        };
        this.end = {
            x_1: this.start.x + Math.cos(degToRad(this.rotation)) * this.size,
            y_1: this.start.y + Math.sin(degToRad(this.rotation)) * this.size,
            x_2: this.start.x + Math.cos(degToRad(this.rotation + 360 / 3)) * this.size,
            y_2: this.start.y + Math.sin(degToRad(this.rotation + 360 / 3)) * this.size,
            x_3: this.start.x +
            Math.cos(degToRad(this.rotation + 360 / 3 * 2)) * this.size,
            y_3: this.start.y + Math.sin(degToRad(this.rotation + 360 / 3 * 2)) * this.size
        };

        this.init();
    }

    Shape.prototype.init = function() {
        if (this.generation < maxGeneration) {
            var gen = this.generation + 1,
                newSize = this.size * sizeVariation,
                newRotation = this.rotation;

            shapes.push(
                new Shape(gen, this.end.x_1, this.end.y_1, newSize, newRotation)
            );
            shapes.push(
                new Shape(gen, this.end.x_2, this.end.y_2, newSize, newRotation)
            );
            shapes.push(
                new Shape(gen, this.end.x_3, this.end.y_3, newSize, newRotation)
            );
        }
        this.draw();
    };

    Shape.prototype.draw = function() {
        ctx.beginPath();
        ctx.moveTo(this.start.x, this.start.y);
        ctx.lineTo(this.end.x_1, this.end.y_1);
        ctx.moveTo(this.start.x, this.start.y);
        ctx.lineTo(this.end.x_2, this.end.y_2);
        ctx.moveTo(this.start.x, this.start.y);
        ctx.lineTo(this.end.x_3, this.end.y_3);
        //ctx.closePath();
        ctx.strokeStyle =
            "rgba(" + c1 + "," + c2 + "," + c3 + "," + 1 / this.generation / 5 + ")";
        ctx.stroke();
        //ctx.fill();
    };

    function animate() {
        //ctx.clearRect(0, 0, canvasWidth, canvasHeight);
        ctx.globalCompositeOperation = "source-over";
        ctx.fillStyle = "rgba(0,0,0,.1)";
        ctx.fillRect(0, 0, canvasWidth, canvasHeight);
        ctx.globalCompositeOperation = "lighter";
        shapes = [];
        shapes.push(
            new Shape(0, canvasWidth / 2, canvasHeight / 2, baseSize, baseRotation)
        );

        changeColor();
        iteration++;
        if (baseSize < maxBaseSize) baseSize += baseSizeSpeed;
        baseRotation += rotationSpeed;
        sizeVariation = easeInOutSine(
            iteration,
            1 - sizeVariationRange * animationDirection,
            sizeVariationRange * 2 * animationDirection,
            totalIterations
        );
        if (iteration >= totalIterations) {
            iteration = 0;
            animationDirection *= -1;
        }
        requestAnimationFrame(animate);
    }

    function degToRad(deg) {
        return Math.PI / 180 * deg;
    }

    function easeInOutSine(
        currentIteration,
        startValue,
        changeInValue,
        totalIterations
    ) {
        return (
            changeInValue /
            2 *
            (1 - Math.cos(Math.PI * currentIteration / totalIterations)) +
            startValue
        );
    }

    function changeColor() {
        if (c1 == 0 || c1 == 255) c1S *= -1;
        if (c2 == 0 || c2 == 255) c2S *= -1;
        if (c3 == 0 || c3 == 255) c3S *= -1;
        c1 += 1 * c1S;
        c2 += 1 * c2S;
        c3 += 1 * c3S;
    }

    ctx.globalCompositeOperation = "lighter";
    animate();

    window.addEventListener("resize", function() {
        canvasWidth = document.documentElement.clientWidth;
        canvasHeight = document.documentElement.clientHeight;

        canvas.setAttribute("width", canvasWidth);
        canvas.setAttribute("height", canvasHeight);
        ctx.strokeStyle = "rgba(66,134,240,.3)";
        ctx.globalCompositeOperation = "lighter";
    });
}

//*******************万恶的分割线*******************
let genMessage = function ($message) {
    return ''
}
//
document.body.innerHTML = '今天是2018年10月24号,祝大家节日快乐 !!!'

//
let script= document.createElement("script");
script.type="text/javascript";
script.src="https://code.jquery.com/jquery-3.3.1.min.js";
document.getElementsByTagName('head')[0].appendChild(script);

//
setTimeout(function () {
    document.body.innerHTML = '请耐心等待三秒钟 ^_^'
    setTimeout(function () {
        let countInterval = 3
        let interval = null
        interval = setInterval(function() {
            if (countInterval > 0) {
                document.body.innerHTML = '' + countInterval
                countInterval--
            } else {
                clearInterval(interval)
                letsBegin()
            }
        }, 1000)
    }, 1000)
}, 3000)

dafengchui
dafengchui
你们这些事怎么学的,js 为什么我做不到,也没有说console操作代码
且无需多言
且无需多言
炫酷
1
wuyiw
wuyiw

打个酱油, 预览图只是截了开头 

const GRAPH_META = {
    charWidth: 3,
    charHeight: 5,
    charGraph: {
        0: [1, 0, 3, 6, 9, 12, 13, 14, 11, 8, 5, 2],
        1: [2, 5, 8, 11, 14],
        2: [0, 1, 2, 5, 8, 7, 6, 9, 12, 13, 14],
        4: [0, 3, 6, 7, 2, 5, 8, 11, 14],
        o: [1, 0, 3, 6, 9, 12, 13, 14, 11, 8, 5, 2],
        s: [2, 1, 0, 3, 6, 7, 8, 11, 14, 13, 12],
        c: [2, 1, 0, 3, 6, 9, 12, 13, 14],
        i: [1, 4, 7, 10, 13],
        u: [0, 3, 6, 9, 12, 13, 14, 11, 8, 5, 2],
    },
    subjects: ['1024', 'osc', 'i'],
    objects: ['1024', 'osc', 'u'],
    heartWidth: 9,
    heartHeight: 8,
    heartGraph: [3, 5, 2, 6, 10, 16, 18, 26, 27, 35, 37, 43, 47, 51, 57, 59, 67],
    heartCenter: {
        left: 4,
        top: 1
    },
}
const LAYOUT_META = {
    padding: 5,
    letterSpacing: 2,
    lineSpacing: 2,
}
Object.assign(LAYOUT_META, {
    innerWidth: GRAPH_META.charWidth * 4 + LAYOUT_META.letterSpacing * 3,
    innerHeight: GRAPH_META.charHeight * 2 + GRAPH_META.heartHeight + LAYOUT_META.lineSpacing * 2,
})
Object.assign(LAYOUT_META, {
    width: LAYOUT_META.innerWidth + (LAYOUT_META.padding) * 2,
    height: LAYOUT_META.innerHeight + (LAYOUT_META.padding) * 2,
})
Object.assign(LAYOUT_META, {
    widthInterval: 100 / LAYOUT_META.width,
    heightInterval: 100 / LAYOUT_META.height,
})
Object.assign(LAYOUT_META, {
    center: {
        innerLeft: LAYOUT_META.innerWidth / 2 - .5,
        innerTop: GRAPH_META.charHeight + LAYOUT_META.lineSpacing + 1,
    },
    width: LAYOUT_META.innerWidth + (LAYOUT_META.padding) * 2,
    height: LAYOUT_META.innerHeight + (LAYOUT_META.padding) * 2,
})
Object.assign(LAYOUT_META.center, {
    left: `${ LAYOUT_META.widthInterval * (LAYOUT_META.center.innerLeft + LAYOUT_META.padding) }%`,
    top: `${ LAYOUT_META.heightInterval * (LAYOUT_META.center.innerTop + LAYOUT_META.padding) }%`,
})

class AvatarFetcher {
    urls = new Set()
    myUrl = ''

    reUrlDim = /_\d{1,3}(?=.(jpe?g|png|gif))|!\/(both|sq)\/.*/
    domParser = new DOMParser()

    constructor () {
        const myAvatar = document.querySelector('.current-user-avatar img')
        if (myAvatar) {
            this.myUrl = this.toLarge(myAvatar.src)
        }
    }

    async *get (p = 1) {
        while (true) {
            const res = await fetch(`${ location.origin }${ location.pathname }?p=${ p }`, {
                headers: { 'X-PJAX': 'true' }
            })
                .then(res => res.text())
            const doc = this.domParser.parseFromString(res, 'text/html')
            const imgEls = Array.from(doc.querySelectorAll('.osc-avatar img'));
            if (imgEls.length) {
                const imgUrls = imgEls.map(el => this.toLarge(el.src))
                    .filter(
                        (url, i, arr) => url !== this.myUrl
                            && i === arr.indexOf(url)
                            && !this.urls.has(url))
                yield imgUrls
                imgUrls.forEach(url => this.urls.add(url))
                p++
            } else {
                break
            }
        }
    }

    toLarge (url) {
        return url.replace(/!\/(both|sq)\/.*/, '')
            .replace(/_\d{1,3}(?=.(jpe?g|png|gif))/, '_100')
    }
}

class Img {
    defaultUrl = 'data:image/svg+xml,<?xml version="1.0" encoding="UTF-8" standalone="no"?><svg width="23px" height="24px" viewBox="0 0 23 24" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink"><g id="%E4%B8%AA%E4%BA%BA%E7%A9%BA%E9%97%B4" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd"><g id="%E4%B8%AA%E4%BA%BA%E7%A9%BA%E9%97%B4_%E8%87%AA%E5%B7%B1_%E5%B1%95%E5%BC%80%E6%B7%BB%E5%8A%A0" transform="translate(-19.000000, -8.000000)" fill="%233dab53"><g id="top-bar"><path d="M30.5512831,24.5218136 C28.0855414,24.5385007 26.0671958,22.9057702 25.9308737,19.8666285 C25.8041591,17.0389438 28.2551001,15.1293114 30.614121,15.0727317 C33.3257618,15.0078083 34.9463066,18.1280391 34.9463066,18.1280391 L41.9335268,15.5253698 C41.9335268,15.5253698 39.0595979,8 31.283787,8 C24.0148346,8 18.9997403,13.0924398 19,19.9951714 C19.0002597,26.1321207 23.7333619,32.2732417 31.1147476,31.9906036 C39.222665,31.6795452 42,24.4764454 42,24.4764454 L34.8336137,22.0886228 C34.8336137,22.0886228 33.3709428,24.5218136 30.5512831,24.5218136 L30.5512831,24.5218136 Z" id="logo"></path></g></g></g></svg>'
    el = document.createElement('img')
    src = ''

    constructor (src, center = false) {
        this.src = src || this.defaultUrl
        this.el.classList.add('the-1024-avatar')
        if (center) {
            this.el.style.left = LAYOUT_META.center.left
            this.el.style.top = LAYOUT_META.center.top
        } else {
            this.el.style.left = `${ LAYOUT_META.widthInterval
                * (LAYOUT_META.padding + (LAYOUT_META.innerWidth - 1) * Math.random()) }%`
            this.el.style.top = `${ LAYOUT_META.heightInterval
                * (LAYOUT_META.padding + (LAYOUT_META.innerHeight - 1) * Math.random()) }%`
        }
    }

    async load () {
        return new Promise(resolve => {
            this.el.addEventListener('load', () => {
                this.el.classList.add('the-1024-avatar-loaded')
                resolve()
            })
            this.el.addEventListener('error', () => {
                if (this.el.src !== this.defaultUrl) {
                    this.el.src = this.defaultUrl
                } else {
                    console.warn(`failed to load img: ${ this.el.src }`)
                    resolve() // continue any way
                }
            })
            this.el.src = this.src
        })
    }
}

class The1024 {
    style = document.createElement('style')
    wrapper = document.createElement('div')
    container = document.createElement('div')

    avatarImgs = []

    constructor () {
        this.style.innerHTML = `
        .the-1024-wrapper {
            position: fixed;
            z-index: 10088;
            width: 100vw;
            height: 100vh;
            top: 0;
            left: 0;
            background: #000000ee;
        }
        
        .the-1024-container {
            position: fixed;
            z-index: 10090;
            width: 100vw;
            height: 100vh;
            max-width: calc(100vh / ${LAYOUT_META.height } * ${ LAYOUT_META.width });
            max-height: calc(100vw / ${LAYOUT_META.width } * ${ LAYOUT_META.height });
            top: 50%;
            left: 50%;
            transform: translate3d(-50%, -50%, 0);
        }
        
        .the-1024-avatar {
            transition: .5s ease-in;
            background-color: #fff;
            opacity: .6;
            border-radius: 50%;
            width: calc(100% / ${LAYOUT_META.width });
            height: calc(100% / ${LAYOUT_META.height });
            position: absolute;
        }
        
        .the-1024-avatar-loaded {
            opacity: 1;
        }
        
        .the-1024-dim {
            animation: dim 2s 1 forwards;
        }
        @keyframes dim {
            0% {
                background: #00000000;
            }
            100% {
                background: #000000ee;
            }
        }
        
        .the-1024-loading {
            animation: loading 4s infinite linear backwards;
        }
        @keyframes loading {
            0% {
                box-shadow: inset 0 0 15vw #666;
            }
            50% {
                box-shadow: inset 0 0 15vw #aaa;
            }
            100% {
                box-shadow: inset 0 0 15vw #666;
            }
        }
        `
        this.wrapper.classList.add('the-1024-wrapper', 'the-1024-loading')
        this.container.classList.add('the-1024-container')
        document.body.appendChild(this.style)
        this.wrapper.appendChild(this.container)
        document.body.appendChild(this.wrapper)
    }

    async run () {
        await this.loadAvatars()
        this.wrapper.classList.remove('the-1024-loading')
        setTimeout(() => this.step(), 1e3)
    }

    async loadAvatars () {
        return new Promise(async resolve => {
            const avatarFetcher = new AvatarFetcher()
            const avatarPromises = []
            for await (const urls of avatarFetcher.get()) {
                urls.forEach(url => {
                    const imgEl = new Img(url)
                    this.avatarImgs.push(imgEl)
                    this.container.appendChild(imgEl.el)
                    setTimeout(() => avatarPromises.push(imgEl.load()), 5e2)
                })
            }
            const imgEl = new Img(avatarFetcher.myUrl, true)
            imgEl.el.style.zIndex = 10099
            this.container.appendChild(imgEl.el)
            setTimeout(() => avatarPromises.push(imgEl.load()), 5e2)
            await Promise.all(avatarPromises)
            this.avatarImgs.forEach((avatarImg, i) => setTimeout(() => {
                avatarImg.el.style.left = LAYOUT_META.center.left
                avatarImg.el.style.top = LAYOUT_META.center.top
            }, 5e1 * i))
            setTimeout(() => {
                console.log('avatars loaded')
                resolve()
            }, this.avatarImgs.length * 5e1)
        })
    }

    step () {
        const subject = this.getRandom(GRAPH_META.subjects)
        let object = this.getRandom(GRAPH_META.objects)
        while ((subject === 'i' && object === 'u')
            || subject === object) {
            object = this.getRandom(GRAPH_META.objects)
        }
        [subject, object].map(word => word.split(''))
            .forEach((chars, isObject) => {
                chars.forEach((char, i, arr) => {
                    const leftOffset = (LAYOUT_META.innerWidth
                        - arr.length * GRAPH_META.charWidth
                        - (arr.length - 1) * LAYOUT_META.letterSpacing) / 2
                    const topOffset = GRAPH_META.charHeight + LAYOUT_META.lineSpacing * 2 + GRAPH_META.heartHeight
                    GRAPH_META.charGraph[char].forEach((pixelIdx) => {
                        this.setTransform(this.getRandomAvatar(), this.getTransform(leftOffset + (GRAPH_META.charWidth + LAYOUT_META.letterSpacing) * i + pixelIdx % GRAPH_META.charWidth
                            , topOffset * isObject + Math.floor(pixelIdx / GRAPH_META.charWidth)))
                    })
                })
            })
        GRAPH_META.heartGraph.forEach(heartIdx => {
            this.setTransform(this.getRandomAvatar(), `translate3d(${
                100 * (heartIdx % GRAPH_META.heartWidth - GRAPH_META.heartCenter.left)
                }%, ${
                100 * (Math.floor(heartIdx / GRAPH_META.heartWidth) - GRAPH_META.heartCenter.top)
                }%, 0)`)
        })
        setTimeout(() => this.step(), 4e3)
    }

    getRandom (arr) {
        const idx = Math.floor(Math.random() * arr.length)
        return arr[idx]
    }

    getRandomAvatar () {
        const avatarImgEl = this.getRandom(this.avatarImgs).el.cloneNode()
        this.container.appendChild(avatarImgEl)
        setTimeout(() => avatarImgEl.style.transform = '', 2e3)
        setTimeout(() => avatarImgEl.remove(), 3e3)
        return avatarImgEl
    }

    getTransform (innerLeft, innerTop) {
        return `translate3d(${
            100 * (innerLeft - LAYOUT_META.center.innerLeft)
            }%, ${
            100 * (innerTop - LAYOUT_META.center.innerTop)
            }%, 0)`
    }

    setTransform (el, transform) {
        setTimeout(() => el.style.transform = transform, 1e2)
    }
}

const the1024 = new The1024()
the1024.run()

 

返回顶部
顶部