summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--public/assets/javascripts/rectangles/engine/rooms/grouper.js73
-rw-r--r--public/assets/javascripts/rectangles/engine/scenery/_scenery.js4
-rw-r--r--public/assets/javascripts/rectangles/engine/scenery/types/_object.js4
-rw-r--r--public/assets/javascripts/rectangles/engine/scenery/types/image.js8
-rw-r--r--public/assets/javascripts/rectangles/engine/scenery/types/video.js8
-rw-r--r--public/assets/javascripts/rectangles/models/wall.js19
-rw-r--r--test/06-test-grouper.js15
-rw-r--r--test/09-test-undo.js2
8 files changed, 79 insertions, 54 deletions
diff --git a/public/assets/javascripts/rectangles/engine/rooms/grouper.js b/public/assets/javascripts/rectangles/engine/rooms/grouper.js
index 4ad3bd8..cde9fbb 100644
--- a/public/assets/javascripts/rectangles/engine/rooms/grouper.js
+++ b/public/assets/javascripts/rectangles/engine/rooms/grouper.js
@@ -1,6 +1,6 @@
(function(){
- var vec2, Rect, Rooms, UidGenerator, Wall, Surface, sort
+ var vec2, Rect, Rooms, UidGenerator, Wall, Surface, sort, _
if ('window' in this) {
vec2 = window.vec2
Rect = window.Rect
@@ -9,6 +9,7 @@
UidGenerator = window.UidGenerator
Wall = window.Wall
sort = window.sort
+ _ = window._
}
else {
Rooms = require('./_rooms')
@@ -18,6 +19,7 @@
Wall = require('../../models/wall')
Surface = require('../../models/surface')
sort = require('../../util/sort')
+ _ = require('lodash')
FRONT = 0x1, BACK = 0x2, LEFT = 0x4, RIGHT = 0x8, FLOOR = 0x10, CEILING = 0x20
PI = Math.PI
HALF_PI = PI/2
@@ -82,6 +84,7 @@
collection.sort( useX ? sort.compare_zx : sort.compare_xz )
collection.forEach(function(mx){
if (last_mx && last_mx.rect.eq(mx.rect)) {
+ // culls half-walls
if (last_mx.rect.id == mx.rect.id) {
last_mx.height += mx.height/2
last_mx.y += mx.height/4
@@ -103,41 +106,53 @@
}
base.group = function(walls, collections, side){
var collection = collections[side]
- var wall
var useX = side & FRONT_BACK
- var useA = side & (FRONT | RIGHT)
+ var useA = side & (FRONT | LEFT)
// collection.sort( useX ? sort.compare_zx : sort.compare_xz )
+ var planes = {}
+
collection.forEach(function(mx){
if (mx.culled) return
- var coplanar = wall && wall.edge == mx.rect[useX ? 'y': 'x'][useA ? 'a': 'b']
-
- if (wall && coplanar) {
- if (useX && wall.vec.b == mx.rect.x.a) {
- wall.vec.b = mx.rect.x.b
- wall.mx.push(mx)
- wall.surface.add(mx.face)
- return
- }
- else if (! useX && wall.vec.b == mx.rect.y.a) {
- wall.vec.b = mx.rect.y.b
- wall.mx.push(mx)
- wall.surface.add(mx.face)
- return
- }
- }
- wall = new Wall ({
- id: base.uid(),
- side: side,
- mx: [ mx ],
- surface: new Surface( mx.face ),
- vec: mx.rect[ useX ? 'x' : 'y' ].clone(),
- edge: mx.rect[ useX ? 'y' : 'x' ][ useA ? 'a' : 'b' ],
- })
- walls.push(wall)
+ var edge = mx.rect[useX ? 'y': 'x'][ useA ? 'a': 'b']
+ planes[edge] = planes[edge] || []
+ planes[edge].push(mx)
})
-
+
+ var edges = _.keys(planes)
+ edges.forEach(function(edge){
+
+ var wall
+
+ planes[edge].forEach(function(mx){
+
+ if (wall) {
+ if (useX && wall.vec.b == mx.rect.x.a) {
+ wall.vec.b = mx.rect.x.b
+ wall.mx.push(mx)
+ wall.surface.add(mx.face)
+ return
+ }
+ else if (! useX && wall.vec.b == mx.rect.y.a) {
+ wall.vec.b = mx.rect.y.b
+ wall.mx.push(mx)
+ wall.surface.add(mx.face)
+ return
+ }
+ }
+ wall = new Wall ({
+ id: base.uid(),
+ side: side,
+ mx: [ mx ],
+ surface: new Surface( mx.face ),
+ vec: mx.rect[ useX ? 'x' : 'y' ].clone(),
+ edge: mx.rect[ useX ? 'y' : 'x' ][ useA ? 'a' : 'b' ],
+ })
+ walls.push(wall)
+ })
+ })
+
return walls
}
diff --git a/public/assets/javascripts/rectangles/engine/scenery/_scenery.js b/public/assets/javascripts/rectangles/engine/scenery/_scenery.js
index c43ef14..b4a38f8 100644
--- a/public/assets/javascripts/rectangles/engine/scenery/_scenery.js
+++ b/public/assets/javascripts/rectangles/engine/scenery/_scenery.js
@@ -14,7 +14,7 @@ var Scenery = new function(){
base.add = function(opt){
var scene_media
- switch (media.type) {
+ switch (opt.media.type) {
case 'image':
scene_media = new Scenery.types.image (opt)
break
@@ -74,11 +74,11 @@ var Scenery = new function(){
scenery_data.forEach(function(data){
var wall = Rooms.walls[data.wall_id]
var scene_media = base.add({
+ data: data,
wall: wall,
media: data.media,
id: data.id
})
- scene_media.deserialize(data)
})
}
diff --git a/public/assets/javascripts/rectangles/engine/scenery/types/_object.js b/public/assets/javascripts/rectangles/engine/scenery/types/_object.js
index 46bc0e7..3a2dcc2 100644
--- a/public/assets/javascripts/rectangles/engine/scenery/types/_object.js
+++ b/public/assets/javascripts/rectangles/engine/scenery/types/_object.js
@@ -62,8 +62,8 @@ Scenery.types.base = Fiber.extend(function(base){
set_wall: function(wall, mx){
this.wall = wall || this.wall
- this.bounds = this.wall.bounds_for(this.media, this.scale)
- this.center = this.wall.center()
+ // this.bounds = this.wall.bounds_for(this.media, this.scale)
+ // this.center = this.wall.center()
},
set_scale: function(scale){
diff --git a/public/assets/javascripts/rectangles/engine/scenery/types/image.js b/public/assets/javascripts/rectangles/engine/scenery/types/image.js
index 99c1810..576242e 100644
--- a/public/assets/javascripts/rectangles/engine/scenery/types/image.js
+++ b/public/assets/javascripts/rectangles/engine/scenery/types/image.js
@@ -10,7 +10,13 @@ Scenery.types.image = Scenery.types.base.extend(function(base){
this.build()
this.bind()
this.set_wall()
- this.recenter()
+
+ if (opt.data) {
+ this.deserialize(opt.data)
+ }
+ else {
+ this.recenter()
+ }
},
build: function(){
diff --git a/public/assets/javascripts/rectangles/engine/scenery/types/video.js b/public/assets/javascripts/rectangles/engine/scenery/types/video.js
index a8df875..0bd5c06 100644
--- a/public/assets/javascripts/rectangles/engine/scenery/types/video.js
+++ b/public/assets/javascripts/rectangles/engine/scenery/types/video.js
@@ -10,7 +10,13 @@ Scenery.types.video = Scenery.types.base.extend(function(base){
this.build()
this.bind()
this.set_wall()
- this.recenter()
+
+ if (opt.data) {
+ this.deserialize(opt.data)
+ }
+ else {
+ this.recenter()
+ }
},
build: function(){
diff --git a/public/assets/javascripts/rectangles/models/wall.js b/public/assets/javascripts/rectangles/models/wall.js
index b66d5f5..460963b 100644
--- a/public/assets/javascripts/rectangles/models/wall.js
+++ b/public/assets/javascripts/rectangles/models/wall.js
@@ -144,18 +144,15 @@
Wall.prototype.wallpaper = function(){
var useX = this.side & FRONT_BACK
var shouldFlip = this.side & (LEFT | BACK)
- this.siblings().forEach(function(w){
- w.mx.forEach(function(mx){
-
- var partitionOffset = useX ? mx.x : mx.z
- if (shouldFlip) partitionOffset *= -1
- partitionOffset += mx.width/2
- var floorOffset = mx.y + mx.height/2
+ this.mx.forEach(function(mx){
+ var partitionOffset = useX ? mx.x : mx.z
+ if (shouldFlip) partitionOffset *= -1
+ partitionOffset += mx.width/2
+ var floorOffset = mx.y + mx.height/2
- mx.el.style.backgroundImage = Scenery.nextWallpaper
- mx.el.style.backgroundPosition = (~~partitionOffset) + "px " + (~~floorOffset) + "px"
- })
- })
+ mx.el.style.backgroundImage = Scenery.nextWallpaper
+ mx.el.style.backgroundPosition = (~~partitionOffset) + "px " + (~~floorOffset) + "px"
+ })
}
Wall.prototype.outline = function(){
diff --git a/test/06-test-grouper.js b/test/06-test-grouper.js
index 0f14217..184a3d7 100644
--- a/test/06-test-grouper.js
+++ b/test/06-test-grouper.js
@@ -194,8 +194,8 @@ describe('grouper(rect,corner,peninsula)', function(){
it("left has 3 walls", function(){
assert.equal(3, left_walls.length)
})
- it("right has 4 walls", function(){
- assert.equal(4, right_walls.length)
+ it("right has 3 walls", function(){
+ assert.equal(3, right_walls.length)
})
it("front has 2 walls", function(){
assert.equal(2, front_walls.length)
@@ -229,14 +229,15 @@ describe('grouper(rect,corner,peninsula_taller)', function(){
var front_walls = Rooms.grouper.group([], collections, FRONT)
var back_walls = Rooms.grouper.group([], collections, BACK)
var left_walls = Rooms.grouper.group([], collections, LEFT)
+ Rooms.grouper.debug = true
var right_walls = Rooms.grouper.group([], collections, RIGHT)
+ Rooms.grouper.debug = false
- it("left has 4 walls", function(){
- assert.equal(4, left_walls.length)
+ it("left has 3 walls", function(){
+ assert.equal(3, left_walls.length)
})
- it("right has 5 walls", function(){
- assert.equal(5, right_walls.length)
- // console.log(right_walls.map(function(m){ return m.vec + " " + m.edge + " " + m.surface +"" }))
+ it("right has 3 walls", function(){
+ assert.equal(3, right_walls.length)
})
it("front has 3 walls", function(){
assert.equal(3, front_walls.length)
diff --git a/test/09-test-undo.js b/test/09-test-undo.js
index dbca90e..60fbbb6 100644
--- a/test/09-test-undo.js
+++ b/test/09-test-undo.js
@@ -1,5 +1,5 @@
var assert = require("assert")
-var UndoStack = require("../public/assets/javascripts/rectangles/util/undo.js")
+var UndoStack = require("../public/assets/javascripts/rectangles/util/undostack.js")
UndoStack.debug = false
describe('undo', function(){