about summary refs log tree commit diff stats
path: root/data/maps/daedalus/rooms/Pyramid 4.txtpb
Commit message (Collapse)AuthorAgeFilesLines
* Changed how door location names are formattedStar Rauchenberger2025-08-301-1/+1
| | | | | | | | | | | | | | | | | | STANDARD type doors with at most four panels in the same map area and no other trigger objects will have their location names generated from the names of the panels used to open the door, similar to Lingo 1. Other door types will use the door's name. In either case, the name can be overridden using the new location_name field. Rooms can also set a panel_display_name field, which will be used in location names for doors, and is used to group panels into areas. Panels themselves can set display names, which differentiates their locations from other panels in the same area. Many maps were updated for this, but note that the_symbolic and the_unyielding have validator failures because of duplicate panel names. This won't matter until panelsanity is implemented.
* Added daedalusStar Rauchenberger2025-08-241-0/+9
inting.gd?h=experimental-panels&id=17d2b39d0dd2d94065fbe848e0dbf85e4a80ca66'>17d2b39 ^
c068e66 ^
17d2b39 ^
c068e66 ^
17d2b39 ^












































4d2da5a ^
c068e66 ^










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





















                                                                                  

                                                                                            







                                                   


                                                                                                
 






                                                                        
 
                                                                 
 












































                                                                                                                     
 










                            
extends Spatial

var orientation = ""  # north, south, east, west
var move = false
var move_to_x
var move_to_z
var target = null
var key


func _ready():
	var _connected = get_tree().get_root().get_node("Spatial/player").connect(
		"looked_at", self, "_looked_at"
	)
	if move:
		key.get_node("Viewport/GUI/Panel/TextEdit").connect(
			"answer_correct", self, "_answer_correct"
		)


func _answer_correct():
	var apclient = global.get_node("Archipelago")
	if not apclient._door_shuffle or apclient.paintingIsVanilla(self.get_parent().name):
		movePainting()


func movePainting():
	self.get_parent().translation.x = move_to_x
	self.get_parent().translation.z = move_to_z


func _looked_at(body, painting):
	if body.is_in_group("player") and (painting.get_name() == self.get_parent().get_name()):
		var apclient = global.get_node("Archipelago")
		apclient.checkPainting(painting.get_name())

		if target != null:
			var target_dir = _dir_to_int(target.orientation)
			var source_dir = _dir_to_int(orientation)
			var rotate = target_dir - source_dir
			if rotate < 0:
				rotate += 4
			rotate *= 90

			var target_painting = target.get_parent()

			# this is ACW
			if rotate == 0:
				body.translation.x = (
					target_painting.translation.x + (body.translation.x - painting.translation.x)
				)
				body.translation.y = (
					target_painting.translation.y + (body.translation.y - painting.translation.y)
				)
				body.translation.z = (
					target_painting.translation.z + (body.translation.z - painting.translation.z)
				)
			elif rotate == 180:
				body.translation.x = (
					target_painting.translation.x - (body.translation.x - painting.translation.x)
				)
				body.translation.y = (
					target_painting.translation.y + (body.translation.y - painting.translation.y)
				)
				body.translation.z = (
					target_painting.translation.z - (body.translation.z - painting.translation.z)
				)
				body.rotate_y(PI)
				body.velocity = body.velocity.rotated(Vector3(0, 1, 0), PI)
			elif rotate == 90:
				var diff_x = body.translation.x - painting.translation.x
				var diff_y = body.translation.y - painting.translation.y
				var diff_z = body.translation.z - painting.translation.z
				body.translation.x = target_painting.translation.x + diff_z
				body.translation.y = target_painting.translation.y + diff_y
				body.translation.z = target_painting.translation.z - diff_x
				body.rotate_y(PI / 2)
				body.velocity = body.velocity.rotated(Vector3(0, 1, 0), PI / 2)
			elif rotate == 270:
				var diff_x = body.translation.x - painting.translation.x
				var diff_y = body.translation.y - painting.translation.y
				var diff_z = body.translation.z - painting.translation.z
				body.translation.x = target_painting.translation.x - diff_z
				body.translation.y = target_painting.translation.y + diff_y
				body.translation.z = target_painting.translation.z + diff_x
				body.rotate_y(3 * PI / 2)
				body.velocity = body.velocity.rotated(Vector3(0, 1, 0), 3 * PI / 2)

			if !apclient._pilgrimage_allows_paintings:
				global.sunwarp = 1
				body.get_node("pivot/camera/sunwarp_background").visible = false


func _dir_to_int(dir):
	if dir == "north":
		return 0
	elif dir == "west":
		return 1
	elif dir == "south":
		return 2
	elif dir == "east":
		return 3
	return 4