summaryrefslogtreecommitdiff
path: root/public/assets/javascripts
diff options
context:
space:
mode:
Diffstat (limited to 'public/assets/javascripts')
-rw-r--r--public/assets/javascripts/rectangles/engine/rooms/clipper.js22
-rw-r--r--public/assets/javascripts/rectangles/models/rect.js3
-rw-r--r--public/assets/javascripts/rectangles/models/vec2.js13
-rw-r--r--public/assets/javascripts/rectangles/util/sort.js7
4 files changed, 43 insertions, 2 deletions
diff --git a/public/assets/javascripts/rectangles/engine/rooms/clipper.js b/public/assets/javascripts/rectangles/engine/rooms/clipper.js
index 365ae8c..d67f6ad 100644
--- a/public/assets/javascripts/rectangles/engine/rooms/clipper.js
+++ b/public/assets/javascripts/rectangles/engine/rooms/clipper.js
@@ -52,7 +52,7 @@
base.reset_rects()
base.clip_rects()
- base.cull_rects()
+ base.cull_rects_iterative()
Rooms.regions = sort.rects_by_position(regions)
}
@@ -131,6 +131,26 @@
return regions
}
+ // Find overlapping regions and dedupe the smaller ones
+ base.cull_rects_iterative = function(){
+ regions = sort.rects_by_area( regions )
+
+ var region_i, region_j, i, j, _len
+
+ for (i = 0, _len = regions.length; i < _len-1; i++) {
+ region_i = regions[i]
+ for (j = i+1; j < _len; j++) {
+ region_j = regions[j]
+ if (region_j.dupe) continue;
+ if (region_i.overlaps(region_j)) {
+ region_i.dupe = true
+ }
+ }
+ }
+
+ return regions
+ }
+
return base
}
diff --git a/public/assets/javascripts/rectangles/models/rect.js b/public/assets/javascripts/rectangles/models/rect.js
index 3341239..590440a 100644
--- a/public/assets/javascripts/rectangles/models/rect.js
+++ b/public/assets/javascripts/rectangles/models/rect.js
@@ -94,6 +94,9 @@
Rect.prototype.containsDisc = function(x,y,r){
return this.x.containsDisc(x,r) && this.y.containsDisc(y,r)
}
+ Rect.prototype.overlaps = function(rect){
+ return this.x.overlaps(rect.x) && this.y.overlaps(rect.y)
+ }
Rect.prototype.intersects = function(r){
var corner_intersect = (this.x.b === r.x.a && this.y.b === r.y.a)
return this.x.intersects(r.x) && this.y.intersects(r.y) && ! corner_intersect
diff --git a/public/assets/javascripts/rectangles/models/vec2.js b/public/assets/javascripts/rectangles/models/vec2.js
index b0c88c1..ee02088 100644
--- a/public/assets/javascripts/rectangles/models/vec2.js
+++ b/public/assets/javascripts/rectangles/models/vec2.js
@@ -93,6 +93,19 @@
return (this.a < v.b && v.b <= this.b) || (v.a < this.b && this.b <= v.b)
}
}
+ vec2.prototype.overlaps = function(v){
+ if (this.a == v.a || this.b == v.b) {
+ return true
+ }
+ if (this.a < v.a) {
+ return (v.a < this.b && this.b < v.b) || (this.a < v.b && v.b < this.b)
+ }
+ else if (v.a < this.a) {
+ return (this.a < v.b && v.b < this.b) || (v.a < this.b && this.b < v.b)
+ }
+ }
+
+
vec2.prototype.adjacent = function(v){
if (this.a == v.a || this.b == v.b || this.a == v.b || this.b == v.a) {
return true
diff --git a/public/assets/javascripts/rectangles/util/sort.js b/public/assets/javascripts/rectangles/util/sort.js
index c0b5d54..3b4771c 100644
--- a/public/assets/javascripts/rectangles/util/sort.js
+++ b/public/assets/javascripts/rectangles/util/sort.js
@@ -39,6 +39,7 @@
function room_height_tuple (r){ return [r.height, r] }
function room_area_tuple (r){ return [r.rect.area(), r] }
function rect_area_tuple (r){ return [r.area(), r] }
+ function rect_area_tuple_larger (r){ return [-r.area(), r] }
function room_rect_tuple (r){ return [r.rect, r] }
function identity_tuple (r){ return [r, r] }
@@ -78,7 +79,11 @@
.sort(compare_car)
.map(cdr)
}
-
+ sort.rects_by_larger_area = function (list){
+ return list.map(rect_area_tuple_larger)
+ .sort(compare_car)
+ .map(cdr)
+ }
sort.compare_z = function (a,b){
return a.rect.y.a < b.rect.y.a ? -1 : a.rect.y.a == b.rect.y.a ? 0 : 1
}