File size: 6,267 Bytes
6b56a65
 
 
d286231
 
 
ca7bdf2
d286231
ca7bdf2
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
d286231
 
ca7bdf2
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
d286231
6b56a65
 
ca7bdf2
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
@tool
extends EditorScript

var data:Dictionary = {"bathroom1": [9.507042253521128, 5.422535211267606, 7.464788732394367, 5.422535211267606, 7.464788732394367, 3.3098591549295775, 9.507042253521128, 3.3098591549295775], "bedroom1": [11.619718309859156, 4.366197183098592, 9.507042253521128, 4.366197183098592, 9.507042253521128, 1.267605633802817, 11.619718309859156, 1.267605633802817], "living_room": [9.507042253521128, 8.52112676056338, 4.366197183098592, 8.52112676056338, 4.366197183098592, 5.422535211267606, 9.507042253521128, 5.422535211267606], "kitchen": [9.507042253521128, 12.605633802816902, 7.464788732394367, 12.605633802816902, 7.464788732394367, 8.52112676056338, 9.507042253521128, 8.52112676056338], "bathroom2": [11.619718309859156, 9.507042253521128, 9.507042253521128, 9.507042253521128, 9.507042253521128, 6.408450704225352, 11.619718309859156, 6.408450704225352], "bedroom2": [12.605633802816902, 6.408450704225352, 9.507042253521128, 6.408450704225352, 9.507042253521128, 4.366197183098592, 12.605633802816902, 4.366197183098592], "bedroom3": [12.605633802816902, 14.71830985915493, 9.507042253521128, 14.71830985915493, 9.507042253521128, 11.619718309859156, 12.605633802816902, 11.619718309859156], "bathroom3": [9.507042253521128, 16.760563380281692, 7.464788732394367, 16.760563380281692, 7.464788732394367, 12.605633802816902, 9.507042253521128, 12.605633802816902], "bedroom4": [13.661971830985916, 11.619718309859156, 9.507042253521128, 11.619718309859156, 9.507042253521128, 9.507042253521128, 13.661971830985916, 9.507042253521128]}

const architext_colors = [[0, 0, 0], [249, 222, 182], [195, 209, 217], [250, 120, 128], [126, 202, 234], [190, 0, 198], [255, 255, 255], 
				   [6, 53, 17], [17, 33, 58], [132, 151, 246], [197, 203, 159], [6, 53, 17],]
const housegan_labels = {"living_room": 1, "kitchen": 2, "bedroom": 3, "bathroom": 4, "missing": 5, "closet": 6, 
						 "balcony": 7, "hallway": 8, "dining_room": 9, "laundry_room": 10, "corridor": 8}
	
func create_room(name: String, coords: Array, parent: Node, root: Node, depth: float = 0.1, inset: float = 0.0, operation: int = CSGPolygon3D.OPERATION_UNION, color: Color = Color.TRANSPARENT) -> void:
	# Calculate the center of the room
	var center = Vector2.ZERO
	for i in range(0, coords.size(), 2):
		center += Vector2(coords[i], coords[i+1])
	center /= (coords.size() / 2)

	# Create vertices for the room with inset
	var verts = PackedVector2Array()
	for i in range(0, coords.size(), 2):
		var vertex = Vector2(coords[i], coords[i+1])
		var direction = (vertex - center).normalized()
		verts.append(vertex + direction * inset)
	
	# Create a new CSGPolygon3D with given name
	var polygon = CSGPolygon3D.new()
	polygon.polygon = verts
	polygon.name = name
	polygon.mode = CSGPolygon3D.MODE_DEPTH
	polygon.depth = depth
	polygon.operation = operation

	polygon.rotate_x(deg_to_rad(90))

	# Apply color coding
	var material: StandardMaterial3D = StandardMaterial3D.new()
	for room_name in housegan_labels.keys():
		if not name.begins_with(room_name):
			continue
		var color_values = architext_colors[housegan_labels[room_name]]
		material.albedo_color =Color(color_values[0]/255.0, color_values[1]/255.0, color_values[2]/255.0).srgb_to_linear()
		if color != Color.TRANSPARENT:
			material.albedo_color = color
	polygon.material = material
	
	# Add polygons to the parent node
	parent.add_child(polygon, true)
	polygon.owner = root

func create_corridor(name: String, coords: Array, parent: Node, root: Node, depth: float = 0.1, inset: float = 0.0, operation: int = CSGPolygon3D.OPERATION_SUBTRACTION) -> void:
	# Calculate the center of the corridor
	var center = Vector2.ZERO
	for i in range(0, coords.size(), 2):
		center += Vector2(coords[i], coords[i+1])
	center /= (coords.size() / 2)

	# Create vertices for the corridor with inset
	var verts = PackedVector2Array()
	for i in range(0, coords.size(), 2):
		var vertex = Vector2(coords[i], coords[i+1])
		var direction = (vertex - center).normalized()
		verts.append(vertex + direction * inset)
	
	# Create a new CSGPolygon3D with given name
	var polygon = CSGPolygon3D.new()
	polygon.polygon = verts
	polygon.name = name
	polygon.mode = CSGPolygon3D.MODE_DEPTH
	polygon.depth = depth
	polygon.operation = CSGPolygon3D.OPERATION_SUBTRACTION  # Set operation to subtraction
	polygon.operation = operation

	polygon.rotate_x(deg_to_rad(90))

	# Apply color coding
	var material = StandardMaterial3D.new()
	material.albedo_color = Color(architext_colors[housegan_labels[name]][0]/255.0, architext_colors[housegan_labels[name]][1]/255.0, architext_colors[housegan_labels[name]][2]/255.0).srgb_to_linear()
	polygon.material = material
	
	# Add polygons to the parent node
	parent.add_child(polygon, true)
	polygon.owner = root


func _run():
	var root = get_scene()
	for child in root.get_children():
		child.queue_free()

	# First layer of CSGCombiner3D
	var csg_combiner: CSGCombiner3D = CSGCombiner3D.new()
	csg_combiner.name = "CSGCombiner3D"
	root.add_child(csg_combiner, true)
	csg_combiner.owner = root

	# Second layer of CSGCombiner3D for the place plate
	var csg_combiner_plate: CSGCombiner3D = CSGCombiner3D.new()
	csg_combiner_plate.name = "CSGCombiner3D_Plate"
	csg_combiner_plate.transform.origin.y = csg_combiner_plate.transform.origin.y - 0.1
	root.add_child(csg_combiner_plate, true)
	csg_combiner_plate.owner = root
	
	for room_name in data.keys():
		if room_name != "corridor":
			create_room(room_name, data[room_name], csg_combiner, root, -2.74)
			
	for room_name in data.keys():
		if room_name == "corridor":
			create_corridor(room_name, data[room_name], csg_combiner, root, -2.74)
	
	for room_name in data.keys():
		if room_name != "corridor":
			create_room(room_name + "Inset", data[room_name], csg_combiner, root, -(2.74 + 0.4), -0.24, CSGPolygon3D.OPERATION_SUBTRACTION)

	for room_name in data.keys():
		if room_name == "corridor":
			create_corridor(room_name + "Inset", data[room_name], csg_combiner, root, -(2.74 + 0.4), -0.24, CSGPolygon3D.OPERATION_SUBTRACTION)

	for room_name in data.keys():
		if room_name != "corridor":
			create_room(room_name + "Inset", data[room_name], csg_combiner_plate, root, .2, 0.06, CSGPolygon3D.OPERATION_UNION, Color.from_string("#11344d", Color.WHITE))