require 'matrix'
require_relative '../line'
require_relative '../face_parser'
require_relative 'facing_square_factory'
module GridGenerator
module Cubic
class BorderedGrid
COLOURS = {
fill: "#d0d0d0",
stroke: "#404040"
}
def initialize(x:, y:, units:, squares: )
@x, @y = x, y
@units = units
@squares = case squares
when String
FaceParser.new(squares).parse
when Array
squares
else
raise ArgumentError, "squares must be array or string"
end
end
attr_reader :x, :y, :units, :squares
def width
squares.first.size
end
def height
squares.size
end
def border_unit
units / 4
end
def max_x
x + (width - 2) * units + (2 * border_unit)
end
def max_y
y + (height - 2) * units + (2 * border_unit)
end
def unit_x(n)
if n == 0
x
else
x + border_unit + (n - 1) * units
end
end
def unit_y(n)
if n == 0
y
else
y + border_unit + (n - 1) * units
end
end
def unit_width(n)
if n == 0 || n == (width - 1)
border_unit
else
units
end
end
def unit_height(n)
if n == 0 || n == (height - 1)
border_unit
else
units
end
end
def rows
Array.new(height) do |i|
a = Matrix.column_vector([
x,
unit_y(i+1),
])
b = Matrix.column_vector([
max_x,
unit_y(i+1)
])
GridGenerator::Line.new(a: a, b: b)
end
end
def columns
Array.new(width) do |i|
a = Matrix.column_vector([
unit_x(i+1),
y,
])
b = Matrix.column_vector([
unit_x(i+1),
max_y
])
GridGenerator::Line.new(a: a, b: b)
end
end
def element_shapes
squares.map.each_with_index do |row, row_num|
row.map.each_with_index do |col, col_num|
if col
Cubic::FacingSquareFactory.new(x: unit_x(col_num), y: unit_y(row_num), width: unit_width(col_num), height: unit_height(row_num), colour: col[:colour], opacity: col[:opacity]).build
end
end
end.flatten.compact
end
def points
[
Matrix.column_vector([ x, y ]),
Matrix.column_vector([ max_x, y ]),
Matrix.column_vector([ max_x, max_y ]),
Matrix.column_vector([ x, max_y ])
]
end
def points_string
points.map { |p| "#{p[0,0].round},#{p[1,0].round}" }.join(' ')
end
def as_json
{
"points_string" => points_string,
"rows" => rows,
"columns" => columns,
"element_shapes" => element_shapes.map(&:as_json)
}
end
def to_svg
output = ""
for row in rows do
output += ""
end
for col in columns do
output += ""
end
for shape in element_shapes do
output += ""
end
output
end
end
end
end