Тема: canvas & images
Показать сообщение отдельно
  #4 (permalink)  
Старый 10.10.2012, 22:53
Новичок на форуме
Отправить личное сообщение для tw1nk Посмотреть профиль Найти все сообщения от tw1nk
 
Регистрация: 09.10.2012
Сообщений: 4

Сообщение от melky Посмотреть сообщение
сделайте демонстрацию ... как можно лечить зубы по фотографии
извините)
но всмысле демонстрацию?)
вот на всякий случай полный код:
var ws;
var tanks;
var canvas;
var nextFrame;
var interval;
var id;
var image;
$(function () {
    inittest();
});


function inittest() {

    window.addEventListener("keydown", function (e) {
        var key = e.keyCode;
        if (key == 32) {
            ws.send("fire")
        }
        if (key > 36 && key < 41) {
            switch (key) {
                case 37:
                    setDirection("left");
                    break;
                case 38:
                    setDirection("up");
                    break;
                case 39:
                    setDirection("right");
                    break;
                case 40:
                    setDirection("down");
                    break;
            }
        }
    }, false);

    ws = new WebSocket("ws://localhost:8080/drawServlet");
    ws.onopen = function (data) {
    };
    ws.onmessage = function (data) {
        onmessage(data);
    };
    canvas = document.getElementById("mcanvas").getContext("2d");//почему не работает $("#mcanvas")???
    tanks = [];
    rockets = [];
    image = new Image();
    image.src = "/images/sprite1.png";
    initFrame();
}
function onmessage(data) {
    var packet = JSON.parse(data.data);
    if (packet.type == "join") {
        tanks[packet.id] = new Tank(packet.id, packet.x, packet.y);
        id = packet.id;
    }
    else if (packet.type == "update") {
        updatetest(packet);
    }
    else if (packet.type == "leave") {
        tanks[packet.id] = null;
        delete tanks[packet.id];
    }
}
function draw() {
    canvas.clearRect(0, 0, 600, 600);
    for (var g in tanks) {
        if (tanks[g] != null) {
            switch (tanks[g].direction) {

                case 1:
                    canvas.drawImage(image, 120, 0, 40, 40, tanks[g].cor[0], tanks[g].cor[1], 40, 40);
                    break;
                case 2:
                    canvas.drawImage(image, 0, 0, 40, 40, tanks[g].cor[0], tanks[g].cor[1], 40, 40);
                    break;
                case 3:
                    canvas.drawImage(image, 40, 0, 40, 40, tanks[g].cor[0], tanks[g].cor[1], 40, 40);
                    break;
                case 4:
                    canvas.drawImage(image, 80, 0, 40, 40, tanks[g].cor[0], tanks[g].cor[1], 40, 40);
                    break;
            }
        }
    }
    if (nextFrame != null) {
        nextFrame()
    }
}
function updatetest(lol) {
    for (var i in lol.data) {
        if (tanks[lol.data[i].id] != undefined) {
            tanks[lol.data[i].id].cor[0] = lol.data[i].x;
            tanks[lol.data[i].id].cor[1] = lol.data[i].y;
            tanks[lol.data[i].id].direction = lol.data[i].direction;
        }
        else {
            tanks[lol.data[i].id] = new Tank(lol.data[i].id, lol.data[i].x, lol.data[i].y)
        }
    }
}


function initFrame() {
    if (window.webkitRequestAnimationFrame) {
        nextFrame = function () {
            webkitRequestAnimationFrame(draw);
        };
    } else if (window.mozRequestAnimationFrame) {
        nextFrame = function () {
            mozRequestAnimationFrame(draw);
        };
    } else {
        interval = setInterval(draw(), 1000 / 30);
    }
    if (nextFrame != null) {
        nextFrame();
    }
}
function setDirection(dir) {

    ws.send(dir);
}

function Tank(id, x, y) {
    this.cor = [x, y];
    this.id = id;
    this.direction = 2;
}


вот изображение:

Ответить с цитированием