/* global $ */ var client = require("./player-client.js"); var consts = require("./game-consts.js"); var io = require('socket.io-client'); var GRID_SIZE = consts.GRID_SIZE; var CELL_WIDTH = consts.CELL_WIDTH; client.allowAnimation = true; client.renderer = require("./game-renderer.js"); /** * Provides requestAnimationFrame in a cross browser way. (edited so that this is also compatible with node.) * @author paulirish / http://paulirish.com/ */ // window.requestAnimationFrame = function( /* function FrameRequestCallback */ callback, /* DOMElement Element */ element ) { // window.setTimeout( callback, 1000 / 60 ); // }; if ( !this.requestAnimationFrame ) { this.requestAnimationFrame = ( function() { return this.webkitRequestAnimationFrame || this.mozRequestAnimationFrame || this.oRequestAnimationFrame || this.msRequestAnimationFrame || function( /* function FrameRequestCallback */ callback, /* DOMElement Element */ element ) { setTimeout( callback, 1000 / 60 ); }; })(); } function run() { client.connectGame('//' + window.location.hostname + ':8081', $('#name').val(), function(success, msg) { if (success) { $("#begin").addClass("hidden"); $("#begin").animate({ opacity: 0 }, 1000); } else { var error = $("#error"); error.text(msg); } }); } $(function() { var error = $("#error"); if (!window.WebSocket) { error.text("Your browser does not support WebSockets!"); return; } error.text("Loading..."); //TODO: show loading screen. var success = false; var socket = io('http://' + window.location.hostname + ':8081', { 'forceNew': true, upgrade: false, transports: ['websocket'] }); socket.on('connect_error', function() { if (!success) error.text("Cannot connect with server. This probably is due to misconfigured proxy server. (Try using a different browser)"); }); socket.emit("checkConn", function() { success = true; socket.disconnect(); }); setTimeout(function() { if (!success) error.text("Cannot connect with server. This probably is due to misconfigured proxy server. (Try using a different browser)"); else { error.text(""); $("input").keypress(function(evt) { if (evt.which === 13) requestAnimationFrame(run); }); $("button").click(function(evt) { requestAnimationFrame(run); }); } }, 2000); }); //Event listeners $(document).keydown(function(e) { var newHeading = -1; switch (e.which) { case 37: newHeading = 3; break; //LEFT case 38: newHeading = 0; break; //UP case 39: newHeading = 1; break; //RIGHT case 40: newHeading = 2; break; //DOWN default: return; //exit handler for other keys. } client.changeHeading(newHeading); e.preventDefault(); });