mirror of
https://github.com/logsol/chuck.js.git
synced 2026-05-11 10:37:34 +00:00
145 lines
No EOL
4.2 KiB
JavaScript
Executable file
145 lines
No EOL
4.2 KiB
JavaScript
Executable file
define([
|
|
"Lib/Utilities/Protocol/Helper",
|
|
"Game/Client/GameController",
|
|
"Game/Client/User",
|
|
"Lib/Utilities/NotificationCenter",
|
|
"Game/Config/Settings",
|
|
"Game/Client/View/DomController"
|
|
],
|
|
|
|
function (ProtocolHelper, GameController, User, Nc, Settings, DomController) {
|
|
|
|
function Networker (socketLink) {
|
|
this.socketLink = socketLink;
|
|
this.gameController = null;
|
|
this.users = {};
|
|
|
|
this.socketLink.on('connect', this.onConnect.bind(this));
|
|
this.socketLink.on('disconnect', this.onDisconnect.bind(this));
|
|
|
|
var self = this;
|
|
this.socketLink.on('message', function (message) {
|
|
var m = JSON.parse(message)
|
|
if(Settings.NETWORK_LOG_INCOMING && !m.gameCommand) {
|
|
console.log('INCOMING', message);
|
|
}
|
|
ProtocolHelper.applyCommand(message, self);
|
|
});
|
|
|
|
Nc.on("sendGameCommand", this.sendGameCommand, this);
|
|
Nc.on("game/level/loaded", this.onLevelLoaded, this);
|
|
}
|
|
|
|
// Socket callbacks
|
|
|
|
Networker.prototype.onConnect = function () {
|
|
console.log('connected.')
|
|
var channel = JSON.parse(localStorage["channel"]);
|
|
var player = JSON.parse(localStorage["player"]);
|
|
if(channel.name) {
|
|
var options = {
|
|
channelName: channel.name,
|
|
nickname: player.nickname
|
|
}
|
|
this.sendCommand('join', options);
|
|
} else {
|
|
window.location.href = "/";
|
|
}
|
|
}
|
|
|
|
Networker.prototype.onDisconnect = function () {
|
|
if(this.gameController) this.gameController.destruct();
|
|
this.gameController = null;
|
|
console.log('disconnected. game destroyed. no auto-reconnect');
|
|
document.body.style.backgroundColor = '#aaaaaa';
|
|
}
|
|
|
|
Networker.prototype.onJoinSuccess = function (options) {
|
|
console.log("join success")
|
|
|
|
this.gameController = new GameController();
|
|
this.gameController.loadLevel(options.levelUid);
|
|
|
|
this.onUserJoined(options.user);
|
|
|
|
if (options.joinedUsers) {
|
|
for(var i = 0; i < options.joinedUsers.length; i++) {
|
|
this.onUserJoined(options.joinedUsers[i]);
|
|
}
|
|
}
|
|
|
|
this.initPing();
|
|
}
|
|
|
|
Networker.prototype.onJoinError = function(options) {
|
|
alert(options.message);
|
|
window.location.href = "/";
|
|
};
|
|
|
|
Networker.prototype.onLevelLoaded = function() {
|
|
for (var userId in this.users) {
|
|
this.gameController.createPlayer(this.users[userId]);
|
|
}
|
|
|
|
this.sendGameCommand("clientReady");
|
|
};
|
|
|
|
Networker.prototype.initPing = function() {
|
|
this.ping();
|
|
};
|
|
|
|
Networker.prototype.ping = function() {
|
|
this.sendCommand("ping", Date.now());
|
|
};
|
|
|
|
|
|
// Sending commands
|
|
|
|
// Remember: control commands are coordinator relevant commands
|
|
Networker.prototype.sendCommand = function (command, options) {
|
|
var message = ProtocolHelper.encodeCommand(command, options);
|
|
this.socketLink.send(message);
|
|
if(Settings.NETWORK_LOG_OUTGOING) {
|
|
console.log('OUTGOING', message);
|
|
}
|
|
}
|
|
|
|
Networker.prototype.sendGameCommand = function(command, options) {
|
|
var message = ProtocolHelper.encodeCommand(command, options);
|
|
this.sendCommand('gameCommand', message);
|
|
}
|
|
|
|
|
|
// Commands from server
|
|
|
|
Networker.prototype.onUserJoined = function (options) {
|
|
var user = new User(options.id, options);
|
|
console.log(options.nickname)
|
|
this.users[user.id] = user;
|
|
|
|
if (this.gameController
|
|
&& this.gameController.level
|
|
&& this.gameController.level.isLoaded) {
|
|
|
|
this.gameController.createPlayer(user);
|
|
};
|
|
}
|
|
|
|
Networker.prototype.onUserLeft = function (userId) {
|
|
this.gameController.onUserLeft(userId);
|
|
delete this.users[userId];
|
|
}
|
|
|
|
Networker.prototype.onGameCommand = function(message) {
|
|
ProtocolHelper.applyCommand(message, this.gameController);
|
|
}
|
|
|
|
Networker.prototype.onPong = function(timestamp) {
|
|
var ping = (Date.now() - parseInt(timestamp, 10));
|
|
DomController.setPing(ping);
|
|
setTimeout(this.ping.bind(this), 1000);
|
|
};
|
|
|
|
return Networker;
|
|
|
|
}); |