1
0
mirror of https://github.com/exane/not-gwent-online synced 2024-11-23 19:36:53 +00:00

more stuff

This commit is contained in:
exane 2015-06-14 16:01:25 +02:00
parent abc92be140
commit f09a66f547
11 changed files with 330 additions and 85 deletions

View File

@ -23,7 +23,7 @@ module.exports = {
var cards = this.getDeck().find("name", name); var cards = this.getDeck().find("name", name);
cards.forEach(function(_card) { cards.forEach(function(_card) {
self.getDeck().removeFromDeck(_card.getId()); self.getDeck().removeFromDeck(_card.getID());
this._placeCard(_card); this._placeCard(_card);
}) })
} }

View File

@ -23,6 +23,7 @@
"handlebars": "^3.0.3", "handlebars": "^3.0.3",
"jquery": "^2.1.4", "jquery": "^2.1.4",
"promise": "^7.0.1", "promise": "^7.0.1",
"pubsub-js": "^1.5.2",
"shortid": "^2.2.2", "shortid": "^2.2.2",
"vinyl-source-stream": "^1.1.0" "vinyl-source-stream": "^1.1.0"
}, },

View File

@ -123,7 +123,7 @@
<div class="row"> <div class="row">
<div class="col-xs-12 field field-hand"> <div class="col-xs-12 field field-hand">
{{#each cards}} {{#each cards}}
<div class="card" data-key="{{_key}}"> <div class="card" data-key="{{_key}}" data-id="{{_id}}">
<img src='../assets/cards/{{_data.img}}.png'> <img src='../assets/cards/{{_data.img}}.png'>
</div> </div>
{{/each}} {{/each}}

View File

@ -93,65 +93,87 @@ var App = Backbone.Router.extend({
} }
}); });
/*var Partial = Backbone.View.extend({
initialize: function(options){
this.template = Handlebars.compile($(options.templateID).html());
this.infoData = this.infoData || {};
this.app = options.app;
var self = this;
this.listenTo(this.infoData, "change", this.render);
this.app.on("update:info", function(d) {
self.infoData = d;
self.render();
});
this.render();
},
render: function(){
var self = this;
var d = this.infoData;
this.$el.html(this.template({
name: d.name,
score: d.score,
hand: d.hand,
lives: d.lives
}));
return this;
}
});*/
var SideView = Backbone.View.extend({ var SideView = Backbone.View.extend({
el: ".container", el: ".container",
template: Handlebars.compile('<div class="card" data-key="{{_key}}"><img src="../assets/cards/{{_data.img}}.png"></div>'),
templateCards: Handlebars.compile('{{#each this}}' +
'<div class="card" data-key="{{_key}}">' +
'<img src="../assets/cards/{{_data.img}}.png">' +
'</div>' +
'{{/each}}'),
initialize: function(options){ initialize: function(options){
var self = this; var self = this;
this.side = options.side; this.side = options.side;
this.app = options.app; this.app = options.app;
this.battleView = options.battleView; this.battleView = options.battleView;
this.infoData = this.infoData || {}; this.infoData = this.infoData || {};
this.leader = this.leader || {};
this.field = this.field || {};
this.$info = this.$el.find(".game-info" + this.side);
this.$fields = this.$el.find(".battleside" + this.side);
/*this.$info = new Partial({
templateID: "#info-template",
el: ".game-info"+this.side,
app: this.app
});*/
/*this.app.on("update:info", function(d){
self.infoData = d.infoData;
console.log(d);
self.render();
});*/
}, },
render: function(){ render: function(){
this.renderInfo();
this.renderCloseField();
this.renderRangeField();
this.renderSiegeField();
return this;
},
renderInfo: function(){
var d = this.infoData; var d = this.infoData;
var l = this.leader;
this.$info = this.$el.find(".game-info" + this.side); this.$info = this.$el.find(".game-info" + this.side);
this.$info.find(".info-name").html(d.name); this.$info.find(".info-name").html(d.name);
this.$info.find(".score").html(d.score); this.$info.find(".score").html(d.score);
this.$info.find(".hand-card").html(d.hand); this.$info.find(".hand-card").html(d.hand);
this.$info.find(".gwent-lives").html(this.lives(d.lives)); this.$info.find(".gwent-lives").html(this.lives(d.lives));
return this; this.$info.find(".field-leader").html(this.template(l))
if(this.app.user.get("waiting") && this.side === ".player"){
this.$info.addClass("removeBackground");
}
if(!this.app.user.get("waiting") && this.side === ".foe"){
this.$info.addClass("removeBackground");
}
},
renderCloseField: function(){
if(!this.field.close) return;
this.$fields = this.$el.find(".battleside" + this.side);
var $field = this.$fields.find(".field-close").parent();
var cards = this.field.close._cards;
var score = this.field.close._score;
var html = this.templateCards(cards);
$field.find(".field-close").html(html)
$field.find(".large-field-counter").html(score)
},
renderRangeField: function(){
if(!this.field.ranged) return;
this.$fields = this.$el.find(".battleside" + this.side);
var $field = this.$fields.find(".field-range").parent();
var cards = this.field.ranged._cards;
var score = this.field.ranged._score;
var html = this.templateCards(cards);
$field.find(".field-range").html(html)
$field.find(".large-field-counter").html(score)
},
renderSiegeField: function(){
if(!this.field.siege) return;
this.$fields = this.$el.find(".battleside" + this.side);
var $field = this.$fields.find(".field-siege").parent();
var cards = this.field.siege._cards;
var score = this.field.siege._score;
var html = this.templateCards(cards);
$field.find(".field-siege").html(html)
$field.find(".large-field-counter").html(score)
}, },
lives: function(lives){ lives: function(lives){
var out = ""; var out = "";
@ -178,6 +200,7 @@ var BattleView = Backbone.View.extend({
$(this.el).prependTo('body'); $(this.el).prependTo('body');
this.listenTo(user, "change:showPreview", this.render); this.listenTo(user, "change:showPreview", this.render);
this.listenTo(user, "change:waiting", this.render);
this.$hand = this.$el.find(".field-hand"); this.$hand = this.$el.find(".field-hand");
this.$preview = this.$el.find(".card-preview"); this.$preview = this.$el.find(".card-preview");
@ -193,6 +216,7 @@ var BattleView = Backbone.View.extend({
app.receive("update:info", function(data){ app.receive("update:info", function(data){
var _side = data._roomSide; var _side = data._roomSide;
var infoData = data.info; var infoData = data.info;
var leader = data.leader;
var side = yourSide; var side = yourSide;
@ -201,8 +225,25 @@ var BattleView = Backbone.View.extend({
} }
console.log(side); console.log(side);
side.infoData = infoData; side.infoData = infoData;
side.leader = leader;
side.render();
});
app.receive("update:fields", function(data){
var close, ranged, siege;
var _side = data._roomSide;
var side = yourSide;
if(user.get("roomSide") != _side){
side = otherSide;
}
side.field.close = data.close;
side.field.ranged = data.ranged;
side.field.siege = data.siege;
side.render(); side.render();
//app.trigger("update:info", {side: side, infoData: infoData});
}) })
var interval = setInterval(function(){ var interval = setInterval(function(){
@ -221,7 +262,17 @@ var BattleView = Backbone.View.extend({
}, },
events: { events: {
"mouseover .card": "onMouseover", "mouseover .card": "onMouseover",
"mouseleave .card": "onMouseleave" "mouseleave .card": "onMouseleave",
"click .field-hand": "onClick"
},
onClick: function(e){
if(!!this.user.get("waiting")) return;
var $card = $(e.target).closest(".card");
var id = $card.data("id");
console.log("clicked id ", id);
this.app.send("play:cardFromHand", {
id: id
});
}, },
onMouseover: function(e){ onMouseover: function(e){
var target = $(e.target).closest(".card"); var target = $(e.target).closest(".card");
@ -277,6 +328,12 @@ var User = Backbone.Model.extend({
console.log("room id", self.get("room")); console.log("room id", self.get("room"));
}) })
app.receive("set:waiting", function(data){
var waiting = data.waiting;
console.log("is waiting: ", waiting);
self.set("waiting", waiting);
})
app.on("createRoom", this.createRoom, this); app.on("createRoom", this.createRoom, this);
app.on("joinRoom", this.joinRoom, this); app.on("joinRoom", this.joinRoom, this);

View File

@ -53,6 +53,11 @@ $game-height: 800px;
height: $game-height/2 - 100px; height: $game-height/2 - 100px;
width: 100%; width: 100%;
border: 1px solid black; border: 1px solid black;
background: rgba(252, 219, 125, 0.51);
}
.removeBackground {
background: 0;
} }
.mid-line { .mid-line {

View File

@ -1,4 +1,5 @@
var Battleside = require("./Battleside"); var Battleside = require("./Battleside");
var PubSub = require("pubsub-js");
var io = global.io; var io = global.io;
@ -31,25 +32,50 @@ var Battle = (function(){
r.init = function(){ r.init = function(){
this.p1 = Battleside(this._user1.getName(), 0, this); this.p1 = Battleside(this._user1.getName(), 0, this, this._user1);
this.p2 = Battleside(this._user2.getName(), 1, this); this.p2 = Battleside(this._user2.getName(), 1, this, this._user2);
this.p1.foe = this.p2; this.p1.foe = this.p2;
this.p2.foe = this.p1; this.p2.foe = this.p1;
this.p1.send("update:info", {info: this.p1.getInfo()});
this.p2.send("update:info", {info: this.p2.getInfo()});
this.start(); this.start();
} }
r.start = function() { r.start = function(){
this.p1.setLeadercard();
this.p2.setLeadercard();
this.p1.draw(10); this.p1.draw(10);
this.p2.draw(10); this.p2.draw(10);
//this.p2.wait(); PubSub.subscribe("nextTurn", this.switchTurn.bind(this));
this.switchTurn();
} }
r.send = function(event, data) { r.switchTurn = function(){
/*this.playerManager.renderInfos();
if(this.playerManager.bothPassed() && !this._roundCheck) {
//start new round
this._roundCheck = true;
this.checkRound();
return;
}
if(this.playerManager.bothPassed()) {
return;
}
var entity = this.playerManager.getNextPlayer();
this.playerManager.renderInfos();*/
var side = this.turn++ % 2 ? this.p1 : this.p2;
PubSub.publish("onEachTurn");
PubSub.publish("turn/" + side.getID());
console.log("current Turn: ", side.getName());
}
r.send = function(event, data){
io.to(this._id).emit(event, data); io.to(this._id).emit(event, data);
} }

View File

@ -1,24 +1,36 @@
var io = global.io; var io = global.io;
var DeckData = require("../assets/data/deck"); var DeckData = require("../assets/data/deck");
var Deck = require("./Deck"); var Deck = require("./Deck");
var Hand = require("./Hand"); var Hand = require("./Hand");
var Card = require("./Card");
var Field = require("./Field");
var PubSub = require("pubsub-js");
var Battleside = (function(){ var Battleside = (function(){
var Battleside = function(name, n, battle){ var Battleside = function(name, n, battle, user){
if(!(this instanceof Battleside)){ if(!(this instanceof Battleside)){
return (new Battleside(name, n, battle)); return (new Battleside(name, n, battle, user));
} }
/** /**
* constructor here * constructor here
*/ */
this._isWaiting = true;
this.socket = user.socket;
this.field = {};
this.field[Card.TYPE.LEADER] = Field(Card.TYPE.LEADER);
this.field[Card.TYPE.CLOSE_COMBAT] = Field(Card.TYPE.CLOSE_COMBAT);
this.field[Card.TYPE.RANGED] = Field(Card.TYPE.RANGED);
this.field[Card.TYPE.SIEGE] = Field(Card.TYPE.SIEGE);
this.n = n ? "p2" : "p1"; this.n = n ? "p2" : "p1";
this._name = name; this._name = name;
this.battle = battle; this.battle = battle;
this.hand = Hand(); this.hand = Hand();
this.deck = Deck(DeckData["test"]); this.deck = Deck(DeckData["test"]);
PubSub.subscribe("turn/" + this.getID(), this.onTurnStart.bind(this));
}; };
var r = Battleside.prototype; var r = Battleside.prototype;
/** /**
@ -28,21 +40,48 @@ var Battleside = (function(){
*/ */
r._name = null; r._name = null;
r._discard = null; r._discard = null;
r._leader = null; /*r.leaderField = null;
r._close = null; r.closeField = null;
r._range = null; r._range = null;
r._siege = null; r._siege = null;
r._field = null; r._field = null;*/
r._lives = 2; r._lives = 2;
r._score = 0; r._score = 0;
r._isWaiting = null;
r.field = null;
r.socket = null;
r.n = null;
r.foe = null; r.foe = null;
r.hand = null; r.hand = null;
r.battle = null; r.battle = null;
r.deck = null; r.deck = null;
r.wait = function(){
this._isWaiting = true;
this.send("set:waiting", {waiting: this._isWaiting}, true);
}
r.draw = function(times) { r.turn = function() {
this._isWaiting = false;
this.send("set:waiting", {waiting: this._isWaiting}, true);
}
r.setLeadercard = function(){
var leaderCard = this.deck.find("type", Card.TYPE.LEADER);
this.deck.removeFromDeck(leaderCard[0]);
/*
this.getYourside().setField("leader", leaderCard[0]);*/
this.field[Card.TYPE.LEADER].add(leaderCard[0]);
}
r.getID = function() {
return this.n;
}
r.draw = function(times){
while(times--) { while(times--) {
var card = this.deck.draw(); var card = this.deck.draw();
this.hand.add(card); this.hand.add(card);
@ -50,28 +89,85 @@ var Battleside = (function(){
console.log("update:hand fired"); console.log("update:hand fired");
this.send("update:hand", {cards: JSON.stringify(this.hand.getCards())}); this.update();
} }
r.getInfo = function() { r.calcScore = function() {
var score = 0;
for(var key in this.field) {
score += +this.field[key].getScore();
}
return this._score = score;
}
r.getInfo = function(){
console.log(this.getName(), this._isWaiting);
return { return {
name: this.getName(), name: this.getName(),
lives: this._lives, lives: this._lives,
score: this._score, score: this.calcScore(),
hand: this.hand.length() hand: this.hand.length()
} }
} }
r.getName = function() { r.getName = function(){
return this._name; return this._name;
} }
r.send = function(event, msg) { r.send = function(event, msg, isPrivate){
msg = msg || {}; msg = msg || {};
isPrivate = typeof isPrivate === "undefined" ? false : isPrivate;
msg._roomSide = this.n; msg._roomSide = this.n;
if(isPrivate) {
return this.socket.emit(event, msg);
}
this.battle.send(event, msg); this.battle.send(event, msg);
} }
r.receive = function(event, cb) {
this.socket.on(event, cb);
}
r.update = function(){
this.send("update:info", {
info: this.getInfo(),
leader: this.field[Card.TYPE.LEADER].get()[0]
})
this.send("update:hand", {
cards: JSON.stringify(this.hand.getCards())
});
this.send("update:fields", {
close: this.field[Card.TYPE.CLOSE_COMBAT],
ranged: this.field[Card.TYPE.RANGED],
siege: this.field[Card.TYPE.SIEGE]
})
}
r.onTurnStart = function() {
this.foe.wait();
this.turn();
var self = this;
this.receive("play:cardFromHand", function(data) {
var cardID = data.id;
var card = self.hand.getCard(cardID);
self.hand.remove(cardID);
self.playCard(card);
})
};
r.playCard = function(card) {
if(card === -1) return;
var field = this.field[card.getType()];
field.add(card);
this.update();
PubSub.publish("nextTurn");
}
return Battleside; return Battleside;

View File

@ -73,7 +73,7 @@ var Card = (function(){
return this._key; return this._key;
} }
r.getId = function(){ r.getID = function(){
return this._id; return this._id;
} }

View File

@ -36,7 +36,7 @@ var Deck = (function(){
return this._deck.length; return this._deck.length;
} }
r.length = function() { r.length = function(){
return this.getLength(); return this.getLength();
} }
@ -50,45 +50,50 @@ var Deck = (function(){
return card; return card;
} }
/* /*
r._loadCards = function(){ r._loadCards = function(){
var n = this._originalDeck.length; var n = this._originalDeck.length;
for(var i = 0; i < n; i++) { for(var i = 0; i < n; i++) {
this._deck.push(CardManager().add(this._originalDeck[i], this._owner)); this._deck.push(CardManager().add(this._originalDeck[i], this._owner));
} }
}*/ }*/
r._loadCards = function() { r._loadCards = function(){
this._deck = this.getDeck().map(function(cardkey) { this._deck = this.getDeck().map(function(cardkey){
return Card(cardkey); return Card(cardkey);
}); });
} }
r.pop = function(){ r.pop = function(){
var id = this._deck.pop();/* var id = this._deck.pop();
var card = CardManager().getCardById(id);*/ /*
var card = CardManager().getCardById(id);*/
return id; return id;
} }
/*r.find = function(key, val){ r.find = function(key, val){
var res = []; var res = [];
this.getDeck().forEach(function(id){ this.getDeck().forEach(function(card){
var card = CardManager().getCardById(id);
if(card.getProperty(key) == val){ if(card.getProperty(key) == val){
res.push(card); res.push(card);
} }
}); });
return res; return res;
}*/ }
r.removeFromDeck = function(id){ r.removeFromDeck = function(card){
var n = this.length(); var n = this.length();
for(var i = 0; i < n; i++) { for(var i = 0; i < n; i++) {
var cardID = this.getDeck()[i]; /*var cardID = this.getDeck()[i];
if(id == cardID){ if(id == cardID){
this.getDeck().splice(i, 1); this.getDeck().splice(i, 1);
return id; return id;
}*/
var c = this.getDeck()[i];
if(c.getID() === card.getID()){
return this.getDeck().splice(i, 1);
} }
} }
return -1; return -1;

47
server/Field.js Normal file
View File

@ -0,0 +1,47 @@
var Field = (function(){
var Field = function(){
if(!(this instanceof Field)){
return (new Field());
}
/**
* constructor here
*/
this._cards = [];
};
var r = Field.prototype;
/**
* methods && properties here
* r.property = null;
* r.getProperty = function() {...}
*/
r._cards = null;
r._score = 0;
r.add = function(card) {
this._cards.push(card);
this.updateScore();
}
r.get = function() {
return this._cards;
}
r.getScore = function() {
return this._score;
}
r.updateScore = function() {
this._score = 0;
for(var i=0; i<this._cards.length; i++) {
var card = this._cards[i];
this._score += card.getPower();
}
}
return Field;
})();
module.exports = Field;

View File

@ -30,11 +30,19 @@ var Hand = (function(){
return this._hand; return this._hand;
} }
r.getCard = function(id) {
for(var i=0; i< this.length(); i++) {
var card = this.getCards()[i];
if(card.getID() === id) return card;
}
return -1;
}
r.remove = function(id){ r.remove = function(id){
var n = this.length(); var n = this.length();
for(var i = 0; i < n; i++) { for(var i = 0; i < n; i++) {
if(this._hand[i].getId() != id) continue; if(this._hand[i].getID() != id) continue;
return this._hand.splice(i, 1); return this._hand.splice(i, 1);
} }
return -1; return -1;