implement event loading, load all sounds, add step sounds

This commit is contained in:
Holly Stubbs 2025-03-06 01:15:53 +00:00
parent 30c4a321d9
commit df41dc7686
Signed by: tgpholly
GPG key ID: B8583C4B7D18119E
28 changed files with 11149 additions and 133 deletions

View file

@ -3,6 +3,8 @@
[ext_resource type="Script" uid="uid://c4vf0qbhcfk1p" path="res://src/LoadingScreen.gd" id="1_grr4e"] [ext_resource type="Script" uid="uid://c4vf0qbhcfk1p" path="res://src/LoadingScreen.gd" id="1_grr4e"]
[node name="LoadingScreen" type="Control"] [node name="LoadingScreen" type="Control"]
z_index = 4096
z_as_relative = false
layout_mode = 3 layout_mode = 3
anchors_preset = 15 anchors_preset = 15
anchor_right = 1.0 anchor_right = 1.0
@ -11,6 +13,16 @@ grow_horizontal = 2
grow_vertical = 2 grow_vertical = 2
script = ExtResource("1_grr4e") script = ExtResource("1_grr4e")
[node name="ColorRect" type="ColorRect" parent="."]
z_index = -4
layout_mode = 1
anchors_preset = 15
anchor_right = 1.0
anchor_bottom = 1.0
grow_horizontal = 2
grow_vertical = 2
color = Color(0, 0, 0, 1)
[node name="Background" type="TextureRect" parent="."] [node name="Background" type="TextureRect" parent="."]
visible = false visible = false
z_index = -1 z_index = -1

View file

@ -1,6 +1,7 @@
[gd_scene load_steps=3 format=3 uid="uid://bc46lc1tdvrio"] [gd_scene load_steps=4 format=3 uid="uid://bc46lc1tdvrio"]
[ext_resource type="Script" uid="uid://b08xfsygxqj6a" path="res://src/DynamicMap.gd" id="1_mytgt"] [ext_resource type="Script" uid="uid://b08xfsygxqj6a" path="res://src/DynamicMap.gd" id="1_mytgt"]
[ext_resource type="Script" uid="uid://pga6iqmmq4w0" path="res://src/EventSystem.gd" id="2_vb526"]
[sub_resource type="Environment" id="Environment_d5g72"] [sub_resource type="Environment" id="Environment_d5g72"]
background_mode = 1 background_mode = 1
@ -11,5 +12,8 @@ sdfgi_use_occlusion = true
[node name="DynamicMap" type="Node3D"] [node name="DynamicMap" type="Node3D"]
script = ExtResource("1_mytgt") script = ExtResource("1_mytgt")
[node name="EventSystem" type="Node" parent="."]
script = ExtResource("2_vb526")
[node name="WorldEnvironment" type="WorldEnvironment" parent="."] [node name="WorldEnvironment" type="WorldEnvironment" parent="."]
environment = SubResource("Environment_d5g72") environment = SubResource("Environment_d5g72")

View file

@ -17,3 +17,16 @@ const gridsz = 19 # Same size as the main map itself (better for the map creator
const RoomScale = 8.0 / 2048.0 const RoomScale = 8.0 / 2048.0
const HideDistance = 15 const HideDistance = 15
const SAFE = 0
const EUCLID = 1
const KETER = 2
const CUSTOM = 3
const SAVEANYWHERE = 0
const SAVEONQUIT = 1
const SAVEONSCREENS = 2
const EASY = 0
const NORMAL = 1
const HARD = 2

View file

@ -31,6 +31,9 @@ func EntityParent(obj: Node, parent: Node):
else: else:
obj.reparent(parent, true) obj.reparent(parent, true)
func EntityDistance(ent1: Node3D, ent2: Node3D):
return ent1.global_position.distance_to(ent2.global_position)
func ScaleEntity(obj: Node3D, x: float, y: float, z: float): func ScaleEntity(obj: Node3D, x: float, y: float, z: float):
if obj == null: if obj == null:
pass pass
@ -224,7 +227,7 @@ func UpdateDoors():
var temp = Node3D.new() var temp = Node3D.new()
add_child(temp) add_child(temp)
#PositionEntity(temp, EntityX(Camera), EntityY(Camera), EntityZ(Camera)) #PositionEntity(temp, EntityX(Camera), EntityY(Camera), EntityZ(Camera))
PointEntity(temp, d.buttons[i]) #TODO: UNCOMMENT!!! PointEntity(temp, d.buttons[i])
#if EntityPick(temp, 0.6) == d.buttons[i]: #if EntityPick(temp, 0.6) == d.buttons[i]:
#If ClosestButton = 0 Then #If ClosestButton = 0 Then
@ -403,19 +406,7 @@ func UpdateParticles():
p.pvt.queue_free() p.pvt.queue_free()
particles.erase(p) particles.erase(p)
# TODO: Remove when real loader is in!! var ParticleTextures = []
var ParticleTextures = [
load(Utils.GetCaseiFileName("GFX/smoke.png")),
load(Utils.GetCaseiFileName("GFX/flash.jpg")),
load(Utils.GetCaseiFileName("GFX/dust.jpg")),
load(Utils.GetCaseiFileName("GFX/npcs/hg.pt")),
load(Utils.GetCaseiFileName("GFX/map/sun.jpg")),
load(Utils.GetCaseiFileName("GFX/bloodsprite.png")),
load(Utils.GetCaseiFileName("GFX/smoke2.png")),
load(Utils.GetCaseiFileName("GFX/spark.jpg")),
load(Utils.GetCaseiFileName("GFX/particle.png"))
]
var DecalTextures = [] var DecalTextures = []
var MenuOpen = false var MenuOpen = false
@ -429,6 +420,8 @@ var CanSave = false
var SelectedScreen = null var SelectedScreen = null
var SelectedDoor: Door = null var SelectedDoor: Door = null
var UpdateDoorsTimer: float = 0.0 var UpdateDoorsTimer: float = 0.0
var QuickLoadPercent: int = -1
var RemoteDoorOn: bool = false
func _process(delta: float) -> void: func _process(delta: float) -> void:
if not MenuOpen and not InvOpen and OtherOpen == null and SelectedDoor == null and not ConsoleOpen and not Using294 and SelectedScreen == null and EndingTimer >= 0: if not MenuOpen and not InvOpen and OtherOpen == null and SelectedDoor == null and not ConsoleOpen and not Using294 and SelectedScreen == null and EndingTimer >= 0:
@ -467,9 +460,8 @@ func _process(delta: float) -> void:
#UpdateRoomLights(Camera) #UpdateRoomLights(Camera)
#Else #Else
UpdateDoors() UpdateDoors()
#If QuickLoadPercent = -1 Or QuickLoadPercent = 100 if QuickLoadPercent == -1 or QuickLoadPercent == 100:
#UpdateEvents() eventSystem.UpdateEvents()
#EndIf
#UpdateScreens() #UpdateScreens()
#TimeCheckpointMonitors() #TimeCheckpointMonitors()
#Update294() #Update294()
@ -578,7 +570,123 @@ func CreateEmitter(x: float, y: float, z: float, emittertype: int) -> Emitter:
emitters.push_back(e) emitters.push_back(e)
return e return e
var OpenDoorSFX: Array = Utils.Init2DArray(3, 3)
var CloseDoorSFX: Array = Utils.Init2DArray(3, 3)
var KeyCardSFX1: AudioStream
var KeyCardSFX2: AudioStream
var ButtonSFX2: AudioStream
var ScannerSFX1: AudioStream
var ScannerSFX2: AudioStream
var OpenDoorFastSFX: AudioStream
var CautionSFX: AudioStream
var NuclearSirenSFX: AudioStream
var CameraSFX: AudioStream
var StoneDragSFX: AudioStream
var GunshotSFX: AudioStream
var Gunshot2SFX: AudioStream
var Gunshot3SFX: AudioStream
var BullethitSFX: AudioStream
var TeslaIdleSFX: AudioStream
var TeslaActivateSFX: AudioStream
var TeslaPowerUpSFX: AudioStream
var MagnetUpSFX: AudioStream
var MagnetDownSFX: AudioStream
var FemurBreakerSFX: AudioStream
var EndBreathCHN: AudioStream
var EndBreathSFX: AudioStream
var DecaySFX = Utils.Init1DArray(5)
var BurstSFX: AudioStream
var RustleSFX = Utils.Init1DArray(3)
var Use914SFX: AudioStream
var Death914SFX: AudioStream
var DripSFX = Utils.Init1DArray(4)
var LeverSFX: AudioStream
var LightSFX: AudioStream
var ButtGhostSFX: AudioStream
var RadioSFX = Utils.Init2DArray(5, 10)
var RadioSquelch: AudioStream
var RadioStatic: AudioStream
var RadioBuzz: AudioStream
var ElevatorBeepSFX: AudioStream
var ElevatorMoveSFX: AudioStream
var PickSFX = Utils.Init1DArray(10)
var AmbientSFXCHN: AudioStream
var CurrAmbientSFX: AudioStream
var AmbientSFXAmount = Utils.Init1DArray(6)
var AmbientSFX = Utils.Init2DArray(6, 15)
var OldManSFX = Utils.Init1DArray(8)
var Scp173SFX = Utils.Init1DArray(3)
var HorrorSFX = Utils.Init1DArray(20)
var IntroSFX = Utils.Init1DArray(20)
# IntroSFX(13) = LoadSound_Strict("SFX\intro\shoot1.ogg")
# IntroSFX(14) = LoadSound_Strict("SFX\intro\shoot2.ogg")
var AlarmSFX = Utils.Init1DArray(5)
var CommotionState = Utils.Init1DArray(25)
var HeartBeatSFX: AudioStream
var VomitSFX: AudioStream
var BreathSFX = Utils.Init2DArray(2, 5)
var NeckSnapSFX = Utils.Init1DArray(3)
var DamageSFX = Utils.Init1DArray(9)
var MTFSFX = Utils.Init1DArray(8)
var CoughSFX = Utils.Init1DArray(3)
#Global CoughCHN%, VomitCHN%
var MachineSFX: AudioStream
var ApacheSFX: AudioStream
#var CurrStepSFX
var StepSFX = Utils.Init3DArray(5, 2, 8) # (normal/metal, walk/run, id)
var Step2SFX = Utils.Init1DArray(6)
var eventSystem: EventSystem
func _ready() -> void: func _ready() -> void:
# 0 = light containment, 1 = heavy containment, 2 = entrance
AmbientSFXAmount[0] = 8
AmbientSFXAmount[1] = 11
AmbientSFXAmount[2] = 12
# 3 = general, 4 = pre-breach
AmbientSFXAmount[3] = 15
AmbientSFXAmount[4] = 5
# 5 = forest
AmbientSFXAmount[5] = 10
eventSystem = $EventSystem
OtherOpen = load("res://scenes/screens/LoadWorld.tscn").instantiate() OtherOpen = load("res://scenes/screens/LoadWorld.tscn").instantiate()
add_child(OtherOpen) add_child(OtherOpen)
#add_child(RMesh.LoadRMesh("GFX\\map\\gatea_opt.rmesh", RoomTemplate.new())) #add_child(RMesh.LoadRMesh("GFX\\map\\gatea_opt.rmesh", RoomTemplate.new()))
@ -606,13 +714,13 @@ var I_Zone: MapZones = MapZones.new()
var RandomSeed: String = "" var RandomSeed: String = ""
var SelectedEnding: String = "" var SelectedEnding: String = ""
var MapWidth = Main.options.get("options").get("map size").to_int() @onready var MapWidth = Global.options.get("options").get("map size").to_int()
var MapHeight = Main.options.get("options").get("map size").to_int() @onready var MapHeight = Global.options.get("options").get("map size").to_int()
const HideDistance = 15.0 const HideDistance = 15.0
var MapTemp = Utils.Init2DArray(MapWidth + 1, MapHeight + 1, 0) @onready var MapTemp = Utils.Init2DArray(MapWidth + 1, MapHeight + 1, 0)
var MapFound = Utils.Init2DArray(MapWidth + 1, MapHeight + 1, 0) @onready var MapFound = Utils.Init2DArray(MapWidth + 1, MapHeight + 1, 0)
var RoomTempID = 0 var RoomTempID = 0
var RoomAmbience = Utils.Init1DArray(20) var RoomAmbience = Utils.Init1DArray(20)
@ -4467,7 +4575,7 @@ func LoadRoomTemplates(file: String):
i += 1 i += 1
var MapRoom: Array var MapRoom: Array
var MapName = Utils.Init2DArray(MapWidth, MapHeight, "") @onready var MapName = Utils.Init2DArray(MapWidth, MapHeight, "")
var MapRoomID = Utils.Init1DArray(Constants.ROOM4 + 1, 0) var MapRoomID = Utils.Init1DArray(Constants.ROOM4 + 1, 0)
func GetZone(y): func GetZone(y):
@ -4554,6 +4662,8 @@ func CalculateRoomExtents(r: Room):
print("roomextents: ", r.MinX, ", ", r.MinY, ", ", r.MinZ, ", ", r.MaxX, ", ", r.MaxY, ", ", r.MaxZ) print("roomextents: ", r.MinX, ", ", r.MinY, ", ", r.MinZ, ", ", r.MaxX, ", ", r.MaxY, ", ", r.MaxZ)
var mapMade: bool = false
var loadedRoomMeshes: int = 0 var loadedRoomMeshes: int = 0
func LoadRoomMesh(rt: RoomTemplate): func LoadRoomMesh(rt: RoomTemplate):
var path = Utils.GetCaseiFileName(str("res://", rt.objPath.replace("\\", "/"))).replace("res://", "") var path = Utils.GetCaseiFileName(str("res://", rt.objPath.replace("\\", "/"))).replace("res://", "")
@ -5317,3 +5427,4 @@ func CreateMap():
r1.AdjDoor[3] = r2.AdjDoor[1] r1.AdjDoor[3] = r2.AdjDoor[1]
if (r1.Adjacent[0] != null) and (r1.Adjacent[1] != null) and (r1.Adjacent[2] != null) and (r1.Adjacent[3] != null): if (r1.Adjacent[0] != null) and (r1.Adjacent[1] != null) and (r1.Adjacent[2] != null) and (r1.Adjacent[3] != null):
break break
mapMade = true

10409
src/EventSystem.gd Normal file

File diff suppressed because it is too large Load diff

1
src/EventSystem.gd.uid Normal file
View file

@ -0,0 +1 @@
uid://pga6iqmmq4w0

View file

@ -4,9 +4,9 @@ var skipIntro = false
func _ready() -> void: func _ready() -> void:
DisplayServer.window_set_title(str("SCP - Containment Breach v", Global.GAME_VERSION)) DisplayServer.window_set_title(str("SCP - Containment Breach v", Global.GAME_VERSION))
var width = Main.options.get("options").get("width").to_int() var width = Global.options.get("options").get("width").to_int()
var height = Main.options.get("options").get("height").to_int() var height = Global.options.get("options").get("height").to_int()
var fullscreen = Main.options.get("options").get("fullscreen").to_lower() == "true" var fullscreen = Global.options.get("options").get("fullscreen").to_lower() == "true"
DisplayServer.window_set_max_size(Vector2i(width, height)) DisplayServer.window_set_max_size(Vector2i(width, height))
DisplayServer.window_set_min_size(Vector2i(width, height)) DisplayServer.window_set_min_size(Vector2i(width, height))
var window = get_window() var window = get_window()

View file

@ -109,26 +109,125 @@ var EnableVRam: int
var NavImages: Array = Utils.Init1DArray(5, null) var NavImages: Array = Utils.Init1DArray(5, null)
var MusicVolume: float = 1.0 var MusicVolume: float = 1.0
var SFXVolume: float = 1.0
var PlayerSoundVolume: float = 0
var materials: Dictionary
func StepSoundFromTexture(textureName: String):
if materials.has(textureName):
if materials[textureName].has("stepsound"):
return INI.GetInt(materials[textureName], "stepsound")
return 0
# TODO: Set SFX volume! # TODO: Set SFX volume!
func PlayTempSound(path: String): func PlayTempSound(path) -> AudioStreamPlayer:
var audioPlayer = AudioStreamPlayer.new() var audioPlayer = AudioStreamPlayer.new()
add_child(audioPlayer) add_child(audioPlayer)
audioPlayer.connect("finished", func(): audioPlayer.connect("finished", func():
audioPlayer.queue_free() audioPlayer.queue_free()
) )
if path is String:
audioPlayer.stream = LoadAudio(path)
elif path is AudioStream:
audioPlayer.stream = path
audioPlayer.play()
return audioPlayer
func PlayTempSound3D(path: String, targetPos: Node3D):
var audioPlayer = AudioStreamPlayer3D.new()
add_child(audioPlayer)
audioPlayer.global_position = targetPos.global_position
audioPlayer.connect("finished", func():
audioPlayer.queue_free()
)
audioPlayer.stream = LoadAudio(path) audioPlayer.stream = LoadAudio(path)
audioPlayer.play() audioPlayer.play()
return audioPlayer return audioPlayer
func PlaySound2(path: String, cam: Node3D, entity: Node3D, range: float = 10, volume: float = 1.0):
range = max(range, 1.0)
var audioPlayer = PlayTempSound3D(path, entity)
if volume > 0:
var dist: float = cam.global_position.distance_to(entity.global_position) / range
if 1.0 - dist > 0.0 and 1.0 - dist < 1.0:
audioPlayer.volume_db = linear_to_db(volume * (1 - dist) * SFXVolume)
else:
audioPlayer.stop()
return audioPlayer
var musicSystem: MusicSystem
var options: Dictionary
var difficulties: Array = Utils.Init1DArray(4)
var SelectedDifficulty: Difficulty
func _ready(): func _ready():
#BumpEnabled = GetINIInt("options.ini", "options", "bump mapping enabled") options = INI.Load("res://options.ini")
#Brightness = GetINIFloat("options.ini", "options", "brightness") materials = INI.Load("res://Data/materials.ini")
#HUDenabled = GetINIInt("options.ini", "options", "HUD enabled")
#CameraFogNear = GetINIFloat("options.ini", "options", "camera fog near") musicSystem = MusicSystem.new()
#CameraFogFar = GetINIFloat("options.ini", "options", "camera fog far") add_child(musicSystem)
#MouseSens = GetINIFloat("options.ini", "options", "mouse sensitivity") var optionsSection = options["options"]
#EnableVRam = GetINIInt("options.ini", "options", "enable vram") BumpEnabled = INI.GetInt(optionsSection, "bump mapping enabled")
Brightness = INI.GetFloat(optionsSection, "brightness")
HUDenabled = INI.GetInt(optionsSection, "HUD enabled")
CameraFogNear = INI.GetFloat(optionsSection, "camera fog near")
CameraFogFar = INI.GetFloat(optionsSection, "camera fog far")
MouseSens = INI.GetFloat(optionsSection, "mouse sensitivity")
EnableVRam = INI.GetInt(optionsSection, "enable vram")
MusicVolume = INI.GetFloat(options["audio"], "music volume")
SFXVolume = INI.GetFloat(options["audio"], "sound volume")
difficulties[Constants.SAFE] = Difficulty.new()
difficulties[Constants.SAFE].name = "Safe"
difficulties[Constants.SAFE].description = "The game can be saved any time. However, as in the case of SCP Objects, a Safe classification does not mean that handling it does not pose a threat."
difficulties[Constants.SAFE].permaDeath = false
difficulties[Constants.SAFE].aggressiveNPCs = 0
difficulties[Constants.SAFE].saveType = Constants.SAVEANYWHERE
difficulties[Constants.SAFE].otherFactors = Constants.EASY
difficulties[Constants.SAFE].r = 120
difficulties[Constants.SAFE].g = 150
difficulties[Constants.SAFE].b = 50
difficulties[Constants.EUCLID] = Difficulty.new()
difficulties[Constants.EUCLID].name = "Euclid"
difficulties[Constants.EUCLID].description = "In Euclid difficulty, saving is only allowed at specific locations marked by lit up computer screens. " + "Euclid-class objects are inherently unpredictable, so that reliable containment is not always possible."
difficulties[Constants.EUCLID].permaDeath = false
difficulties[Constants.EUCLID].aggressiveNPCs = 0
difficulties[Constants.EUCLID].saveType = Constants.SAVEONSCREENS
difficulties[Constants.EUCLID].otherFactors = Constants.NORMAL
difficulties[Constants.EUCLID].r = 200
difficulties[Constants.EUCLID].g = 200
difficulties[Constants.EUCLID].b = 0
difficulties[Constants.KETER] = Difficulty.new()
difficulties[Constants.KETER].name = "Keter"
difficulties[Constants.KETER].description = "Keter-class objects are considered the most dangerous ones in Foundation containment. " + "The same can be said for this difficulty level: the SCPs are more aggressive, and you have only one life - when you die, the game is over. "
difficulties[Constants.KETER].permaDeath = true
difficulties[Constants.KETER].aggressiveNPCs = 1
difficulties[Constants.KETER].saveType = Constants.SAVEONQUIT
difficulties[Constants.KETER].otherFactors = Constants.HARD
difficulties[Constants.KETER].r = 200
difficulties[Constants.KETER].g = 0
difficulties[Constants.KETER].b = 0
difficulties[Constants.CUSTOM] = Difficulty.new()
difficulties[Constants.CUSTOM].name = "Custom"
difficulties[Constants.CUSTOM].permaDeath = false
difficulties[Constants.CUSTOM].aggressiveNPCs = 1
difficulties[Constants.CUSTOM].saveType = Constants.SAVEANYWHERE
difficulties[Constants.CUSTOM].customizable = true
difficulties[Constants.CUSTOM].otherFactors = Constants.EASY
difficulties[Constants.CUSTOM].r = 255
difficulties[Constants.CUSTOM].g = 255
difficulties[Constants.CUSTOM].b = 255
SelectedDifficulty = difficulties[Constants.SAFE]
MusicCHN.name = "MusicCHN" MusicCHN.name = "MusicCHN"
add_child(MusicCHN) add_child(MusicCHN)
@ -156,12 +255,12 @@ var PrevTime = 0
func _process(delta): func _process(delta):
#FPSfactor = delta * 1000 #FPSfactor = delta * 1000
#FPSfactor = max(min(delta * 70, 5.0), 0.2) FPSfactor = max(min(delta * 70, 5.0), 0.2)
#print(max(min(delta * 70, 5.0), 0.2)) #print(max(min(delta * 70, 5.0), 0.2))
CurTime = Time.get_ticks_usec() #CurTime = Time.get_ticks_usec()
ElapsedTime = (CurTime - PrevTime) / 1000000.0 #ElapsedTime = (CurTime - PrevTime) / 1000000.0
PrevTime = CurTime #PrevTime = CurTime
FPSfactor = max(min(ElapsedTime * 70, 5.0), 0.2) #FPSfactor = max(min(ElapsedTime * 70, 5.0), 0.2)
if Engine.time_scale == 0: if Engine.time_scale == 0:
FPSfactor = 0 FPSfactor = 0

View file

@ -5,8 +5,8 @@ func _ready() -> void:
$SelectionList.connect("selection_changed", func(resolutionRaw: String): $SelectionList.connect("selection_changed", func(resolutionRaw: String):
var resSplit = resolutionRaw.split("x") var resSplit = resolutionRaw.split("x")
Main.options.get("options")["width"] = resSplit[0] Global.options.get("options")["width"] = resSplit[0]
Main.options.get("options")["height"] = resSplit[1] Global.options.get("options")["height"] = resSplit[1]
) )
$Launch.connect("clicked", func(): $Launch.connect("clicked", func():
get_tree().change_scene_to_file("res://scenes/screens/GameStartup.tscn") get_tree().change_scene_to_file("res://scenes/screens/GameStartup.tscn")

198
src/LoadAllSounds.gd Normal file
View file

@ -0,0 +1,198 @@
class_name LoadAllSounds
static func Go(map: DynamicMap):
# Dim OpenDoorSFX%(3,3), CloseDoorSFX%(3,3)
for i in range(3):
map.OpenDoorSFX[0][i] = Global.LoadAudio(str("SFX/Door/DoorOpen", (i + 1), ".ogg"))
map.CloseDoorSFX[0][i] = Global.LoadAudio(str("SFX/Door/DoorClose", (i + 1), ".ogg"))
map.OpenDoorSFX[2][i] = Global.LoadAudio(str("SFX/Door/Door2Open", (i + 1), ".ogg"))
map.CloseDoorSFX[2][i] = Global.LoadAudio(str("SFX/Door/Door2Close", (i + 1), ".ogg"))
map.OpenDoorSFX[3][i] = Global.LoadAudio(str("SFX/Door/ElevatorOpen", (i + 1), ".ogg"))
map.CloseDoorSFX[3][i] = Global.LoadAudio(str("SFX/Door/ElevatorClose", (i + 1), ".ogg"))
for i in range(2):
map.OpenDoorSFX[1][i] = Global.LoadAudio(str("SFX/Door/BigDoorOpen", (i + 1), ".ogg"))
map.CloseDoorSFX[1][i] = Global.LoadAudio(str("SFX/Door/BigDoorClose", (i + 1), ".ogg"))
map.KeyCardSFX1 = Global.LoadAudio("SFX/Interact/KeyCardUse1.ogg")
map.KeyCardSFX2 = Global.LoadAudio("SFX/Interact/KeyCardUse2.ogg")
map.ButtonSFX2 = Global.LoadAudio("SFX/Interact/Button2.ogg")
map.ScannerSFX1 = Global.LoadAudio("SFX/Interact/ScannerUse1.ogg")
map.ScannerSFX2 = Global.LoadAudio("SFX/Interact/ScannerUse2.ogg")
map.OpenDoorFastSFX = Global.LoadAudio("SFX/Door/DoorOpenFast.ogg")
map.CautionSFX = Global.LoadAudio("SFX/Room/LockroomSiren.ogg")
# NuclearSirenSFX%
map.CameraSFX = Global.LoadAudio("SFX/General/Camera.ogg")
map.StoneDragSFX = Global.LoadAudio("SFX/SCP/173/StoneDrag.ogg")
map.GunshotSFX = Global.LoadAudio("SFX/General/Gunshot.ogg")
map.Gunshot2SFX = Global.LoadAudio("SFX/General/Gunshot2.ogg")
map.Gunshot3SFX = Global.LoadAudio("SFX/General/BulletMiss.ogg")
map.BullethitSFX = Global.LoadAudio("SFX/General/BulletHit.ogg")
map.TeslaIdleSFX = Global.LoadAudio("SFX/Room/Tesla/Idle.ogg")
map.TeslaActivateSFX = Global.LoadAudio("SFX/Room/Tesla/WindUp.ogg")
map.TeslaPowerUpSFX = Global.LoadAudio("SFX/Room/Tesla/PowerUp.ogg")
map.MagnetUpSFX = Global.LoadAudio("SFX/Room/106Chamber/MagnetUp.ogg")
map.MagnetDownSFX = Global.LoadAudio("SFX/Room/106Chamber/MagnetDown.ogg")
# FemurBreakerSFX%
# EndBreathCHN%
# EndBreathSFX%
# Dim DecaySFX%(5)
for i in range(4):
map.DecaySFX[i] = Global.LoadAudio(str("SFX/SCP/106/Decay", i, ".ogg"))
map.BurstSFX = Global.LoadAudio("SFX/Room/TunnelBurst.ogg")
# DrawLoading(20, True)
# Dim RustleSFX%(3)
for i in range(3):
map.RustleSFX[i] = Global.LoadAudio(str("SFX/SCP/372/Rustle", i, ".ogg"))
map.Death914SFX = Global.LoadAudio("SFX/SCP/914/PlayerDeath.ogg")
map.Use914SFX = Global.LoadAudio("SFX/SCP/914/PlayerUse.ogg")
# Dim DripSFX%(4)
for i in range(4):
map.DripSFX[i] = Global.LoadAudio(str("SFX/Character/D9341/BloodDrip", i, ".ogg"))
map.LeverSFX = Global.LoadAudio("SFX/Interact/LeverFlip.ogg")
map.LightSFX = Global.LoadAudio("SFX/General/LightSwitch.ogg")
map.ButtGhostSFX = Global.LoadAudio("SFX/SCP/Joke/789J.ogg")
# Dim RadioSFX(5,10)
map.RadioSFX[1][0] = Global.LoadAudio("SFX/Radio/RadioAlarm.ogg")
map.RadioSFX[1][1] = Global.LoadAudio("SFX/Radio/RadioAlarm2.ogg")
for i in range(9):
map.RadioSFX[2][i] = Global.LoadAudio(str("SFX/Radio/scpradio", i, ".ogg"))
map.RadioSquelch = Global.LoadAudio("SFX/Radio/squelch.ogg")
map.RadioStatic = Global.LoadAudio("SFX/Radio/static.ogg")
map.RadioBuzz = Global.LoadAudio("SFX/Radio/buzz.ogg")
map.ElevatorBeepSFX = Global.LoadAudio("SFX/General/Elevator/Beep.ogg")
map.ElevatorMoveSFX = Global.LoadAudio("SFX/General/Elevator/Moving.ogg")
# Dim PickSFX%(10)
for i in range(4):
map.PickSFX[i] = Global.LoadAudio(str("SFX/Interact/PickItem", i, ".ogg"))
# AmbientSFXCHN%
# CurrAmbientSFX%
# Dim AmbientSFXAmount(6)
# 0 = light containment, 1 = heavy containment, 2 = entrance
map.AmbientSFXAmount[0] = 11
map.AmbientSFXAmount[1] = 11
map.AmbientSFXAmount[2] = 12
# 3 = general, 4 = pre-breach
map.AmbientSFXAmount[3] = 15
map.AmbientSFXAmount[4] = 5
# 5 = forest
map.AmbientSFXAmount[5] = 10
# Dim AmbientSFX%(6, 15)
# Dim OldManSFX%(6)
for i in range(3):
map.OldManSFX[i] = Global.LoadAudio(str("SFX/SCP/106/Corrosion", (i + 1), ".ogg"))
map.OldManSFX[3] = Global.LoadAudio("SFX/SCP/106/Laugh.ogg")
map.OldManSFX[4] = Global.LoadAudio("SFX/SCP/106/Breathing.ogg")
map.OldManSFX[5] = Global.LoadAudio("SFX/Room/PocketDimension/Enter.ogg")
for i in range(3):
map.OldManSFX[6 + i] = Global.LoadAudio(str("SFX/SCP/106/WallDecay", (i + 1), ".ogg"))
# Dim Scp173SFX%(3)
for i in range(3):
map.Scp173SFX[i] = Global.LoadAudio(str("SFX/SCP/173/Rattle", (i + 1), ".ogg"))
# Dim HorrorSFX%(20)
for i in range(12):
map.HorrorSFX[i] = Global.LoadAudio(str("SFX/Horror/Horror", i, ".ogg"))
for i in range(14, 16):
map.HorrorSFX[i] = Global.LoadAudio(str("SFX/Horror/Horror", i, ".ogg"))
# DrawLoading(25, True)
# Dim IntroSFX%(20)
for i in range(7, 10):
map.IntroSFX[i] = Global.LoadAudio(str("SFX/Room/Intro/Bang", (i - 6), ".ogg"))
for i in range(10, 13):
map.IntroSFX[i] = Global.LoadAudio(str("SFX/Room/Intro/Light", (i - 9), ".ogg"))
# IntroSFX(13) = Global.LoadAudio("SFX\intro\shoot1.ogg")
# IntroSFX(14) = Global.LoadAudio("SFX\intro\shoot2.ogg")
map.IntroSFX[15] = Global.LoadAudio("SFX/Room/Intro/173Vent.ogg")
# Dim AlarmSFX%(5)
map.AlarmSFX[0] = Global.LoadAudio("SFX/Alarm/Alarm.ogg")
# AlarmSFX(1) = Global.LoadAudio("SFX\Alarm\Alarm2.ogg")
map.AlarmSFX[2] = Global.LoadAudio("SFX/Alarm/Alarm3.ogg")
# room_gw alarms
map.AlarmSFX[3] = Global.LoadAudio("SFX/Alarm/Alarm4.ogg")
map.AlarmSFX[4] = Global.LoadAudio("SFX/Alarm/Alarm5.ogg")
# Dim CommotionState%(23)
map.HeartBeatSFX = Global.LoadAudio("SFX/Character/D9341/Heartbeat.ogg")
# VomitSFX%
# Dim BreathSFX(2,5)
# BreathCHN%
for i in range(0, 5):
map.BreathSFX[0][i] = Global.LoadAudio(str("SFX/Character/D9341/breath", i, ".ogg"))
map.BreathSFX[1][i] = Global.LoadAudio(str("SFX/Character/D9341/breath", i, "gas.ogg"))
# Dim NeckSnapSFX(3)
for i in range(0, 3):
map.NeckSnapSFX[i] = Global.LoadAudio(str("SFX/SCP/173/NeckSnap", (i + 1), ".ogg"))
# Dim DamageSFX%(9)
for i in range(0, 9):
map.DamageSFX[i] = Global.LoadAudio(str("SFX/Character/D9341/Damage", (i + 1), ".ogg"))
# Dim MTFSFX%(8)
# Dim CoughSFX%(3)
# CoughCHN%
# VomitCHN%
for i in range(0, 3):
map.CoughSFX[i] = Global.LoadAudio(str("SFX/Character/D9341/Cough", (i + 1), ".ogg"))
map.MachineSFX = Global.LoadAudio("SFX/SCP/914/Refining.ogg")
map.ApacheSFX = Global.LoadAudio("SFX/Character/Apache/Propeller.ogg")
# CurrStepSFX
# Dim StepSFX%(4, 2, 8) ;(normal/metal, walk/run, id)
for i in range(0, 8):
map.StepSFX[0][0][i] = Global.LoadAudio(str("SFX/Step/Step", (i + 1), ".ogg"))
map.StepSFX[1][0][i] = Global.LoadAudio(str("SFX/Step/StepMetal", (i + 1), ".ogg"))
map.StepSFX[0][1][i] = Global.LoadAudio(str("SFX/Step/Run", (i + 1), ".ogg"))
map.StepSFX[1][1][i] = Global.LoadAudio(str("SFX/Step/RunMetal", (i + 1), ".ogg"))
if i < 3:
map.StepSFX[2][0][i] = Global.LoadAudio(str("SFX/Character/MTF/Step", (i + 1), ".ogg"))
map.StepSFX[3][0][i] = Global.LoadAudio(str("SFX/SCP/049/Step", (i + 1), ".ogg"))
if i < 4:
map.StepSFX[4][0][i] = Global.LoadAudio(str("SFX/Step/SCP/StepSCP", (i + 1), ".ogg")) # new one 1.3.9
# Dim Step2SFX(6)
for i in range(0, 3):
map.Step2SFX[i] = Global.LoadAudio(str("SFX/Step/StepPD", (i + 1), ".ogg"))
map.Step2SFX[i + 3] = Global.LoadAudio(str("SFX/Step/StepForest", (i + 1), ".ogg"))

1
src/LoadAllSounds.gd.uid Normal file
View file

@ -0,0 +1 @@
uid://bq5s2xnh5mlyh

View file

@ -20,10 +20,9 @@ func loadThread():
#Include "dreamfilter.bb" #Include "dreamfilter.bb"
Global.MusicVolume = INI.GetFloat(Main.options["audio"], "music volume")
Global.MusicCHN.stream = Global.LoadAudio("SFX/Music/"+ str(Global.Music[2]) + ".ogg") Global.MusicCHN.stream = Global.LoadAudio("SFX/Music/"+ str(Global.Music[2]) + ".ogg")
Global.MusicCHN.stream.loop = true Global.MusicCHN.stream.loop = true
#Global.MusicCHN.volume_linear = Global.MusicVolume Global.MusicCHN.volume_db = linear_to_db(Global.MusicVolume)
Global.MusicCHN.play.call_deferred() Global.MusicCHN.play.call_deferred()
loadingScreen.LoadProgress(10) loadingScreen.LoadProgress(10)
@ -69,7 +68,7 @@ func loadThread():
var nomore = false var nomore = false
func _process(delta: float) -> void: func _process(delta: float) -> void:
if not nomore and loadingScreen.loaded and Input.is_anything_pressed(): if not nomore and loadingScreen.loaded and Input.is_action_just_pressed("ui_accept"):
nomore = true nomore = true
get_tree().change_scene_to_file("res://scenes/screens/MainMenu.tscn") get_tree().change_scene_to_file("res://scenes/screens/MainMenu.tscn")

View file

@ -11,10 +11,13 @@ func _ready():
var thread: Thread var thread: Thread
func nextFrame(): func nextFrame():
thread = Thread.new() #thread = Thread.new()
thread.start(loadThread) #thread.start(loadThread)
loadThread()
func loadThread(): func loadThread():
LoadAllSounds.Go(map)
#Local i%, de.Decals, d.Doors, it.Items, r.Rooms, sc.SecurityCams, e.Events #Local i%, de.Decals, d.Doors, it.Items, r.Rooms, sc.SecurityCams, e.Events
map.LoadRoomTemplates("Data/rooms.ini") map.LoadRoomTemplates("Data/rooms.ini")
@ -34,6 +37,10 @@ func loadThread():
#else: #else:
#LoadMap("Map Creator\Maps\"+SelectedMap) #LoadMap("Map Creator\Maps\"+SelectedMap)
#var busyWork: int
#while not map.mapMade:
#busyWork += 1
#InitWayPoints() #InitWayPoints()
loadingScreen.LoadProgress(79) loadingScreen.LoadProgress(79)
@ -43,19 +50,19 @@ func loadThread():
#Curr106.State = 70 * 60 * randi_range(12,17) #Curr106.State = 70 * 60 * randi_range(12,17)
for d: Door in map.doors: for d: Door in map.doors:
map.EntityParent(d.obj, null) map.EntityParent.call_deferred(d.obj, null)
if d.obj2 != null: if d.obj2 != null:
map.EntityParent(d.obj2, null) map.EntityParent.call_deferred(d.obj2, null)
if d.frameobj != null: if d.frameobj != null:
map.EntityParent(d.frameobj, null) map.EntityParent.call_deferred(d.frameobj, null)
if d.buttons[0] != null: if d.buttons[0] != null:
map.EntityParent(d.buttons[0], null) map.EntityParent.call_deferred(d.buttons[0], null)
if d.buttons[1] != null: if d.buttons[1] != null:
map.EntityParent(d.buttons[1], null) map.EntityParent.call_deferred(d.buttons[1], null)
if d.obj2 != null and d.dir == 0: if d.obj2 != null and d.dir == 0:
map.MoveEntity(d.obj, 0, 0, 8.0 * Constants.RoomScale) map.MoveEntity.call_deferred(d.obj, 0, 0, 8.0 * Constants.RoomScale)
map.MoveEntity(d.obj2, 0, 0, 8.0 * Constants.RoomScale) map.MoveEntity.call_deferred(d.obj2, 0, 0, 8.0 * Constants.RoomScale)
#for it: Item in map.items: #for it: Item in map.items:
#map.EntityType (it.collider, HIT_ITEM) #map.EntityType (it.collider, HIT_ITEM)
@ -70,7 +77,7 @@ func loadThread():
for r: Room in map.rooms: for r: Room in map.rooms:
for i in range(Constants.MaxRoomLights): for i in range(Constants.MaxRoomLights):
if r.Lights[i] != null: if r.Lights[i] != null:
map.EntityParent(r.Lights[i], null) map.EntityParent.call_deferred(r.Lights[i], null)
#if (not r.RoomTemplate.DisableDecals): #if (not r.RoomTemplate.DisableDecals):
#if randi_range(0, 4) == 1: #if randi_range(0, 4) == 1:
@ -125,31 +132,29 @@ func loadThread():
#ResetEntity Collider #ResetEntity Collider
#If SelectedMap = "" Then InitEvents() #if SelectedMap == "":
# map.eventSystem.InitEvents()
#For e.Events = Each Events
#If e\EventName = "room2nuke" for e: Event in map.eventSystem.events:
#e\EventState = 1 if e.EventName == "room2nuke":
#DebugLog "room2nuke" e.EventState = 1.0
#EndIf print("room2nuke")
#If e\EventName = "room106" if e.EventName == "room106":
#e\EventState2 = 1 e.EventState2 = 1.0
#DebugLog "room106" print("room106")
#EndIf if e.EventName == "room2sl":
#If e\EventName = "room2sl" e.EventState3 = 1.0
#e\EventState3 = 1 print("room2sl")
#DebugLog "room2sl"
#EndIf
#Next
#
#MoveMouse viewport_center_x,viewport_center_y;320, 240 #MoveMouse viewport_center_x,viewport_center_y;320, 240
# #
#AASetFont Font1 #AASetFont Font1
#HidePointer() #HidePointer()
Input.mouse_mode = Input.MOUSE_MODE_CAPTURED
Global.player = load("res://scenes/world/Player.tscn").instantiate() Global.player = load("res://scenes/world/Player.tscn").instantiate()
map.add_child(Global.player) map.add_child.call_deferred(Global.player)
Global.player.BlinkTimer = -10 Global.player.BlinkTimer = -10
#Global.player.BlurTimer = 100 #Global.player.BlurTimer = 100
@ -158,11 +163,11 @@ func loadThread():
for i in range(70): for i in range(70):
Global.FPSfactor = 1.0 Global.FPSfactor = 1.0
#FlushKeys() #FlushKeys()
Global.player._process(Global.FPSfactor / 70.0) #Global.player._process(Global.FPSfactor / 70.0)
Global.player._physics_process(Global.FPSfactor / 70.0) #Global.player._physics_process(Global.FPSfactor / 70.0)
map.UpdateDoors() map.UpdateDoors()
map.UpdateNPCs() #map.UpdateNPCs()
map.UpdateWorld() #map.UpdateWorld()
if (int(float(i) * 0.27) != int(float(i - 1) * 0.27)): if (int(float(i) * 0.27) != int(float(i - 1) * 0.27)):
loadingScreen.LoadProgress(80 + int(float(i) * 0.27)) loadingScreen.LoadProgress(80 + int(float(i) * 0.27))
@ -177,5 +182,13 @@ func loadThread():
#PrevTime = MilliSecs() #PrevTime = MilliSecs()
func _exit_tree() -> void: var nomore = false
thread.wait_to_finish() func _process(delta: float) -> void:
if not nomore and loadingScreen.loaded and Input.is_action_just_pressed("ui_accept"):
nomore = true
queue_free.call_deferred()
map.OtherOpen = null
#
#func _exit_tree() -> void:
#thread.wait_to_finish()

View file

@ -75,7 +75,7 @@ func LoadProgress(progress: int):
loadProgressIndex += 1 loadProgressIndex += 1
loadProgressIndex = min(loadProgressIndex, loadingText.size() - 1) loadProgressIndex = min(loadProgressIndex, loadingText.size() - 1)
percent = progress percent = progress
queue_redraw.call_deferred() queue_redraw()
func _ready() -> void: func _ready() -> void:
background = $Background background = $Background

View file

@ -1,5 +1,3 @@
class_name Main class_name Main
static var options = INI.Load("res://options.ini")
static var SeedRnd = 0 static var SeedRnd = 0

View file

@ -8,6 +8,7 @@ var backBar: ColorRect
var buttonList: Array var buttonList: Array
var jankyFix: ColorRect var jankyFix: ColorRect
func _ready() -> void: func _ready() -> void:
MusicSystem.UpdateMusic = true
jankyFix = $JankyFix jankyFix = $JankyFix
jankyFix.visible = true jankyFix.visible = true
back = $Back back = $Back
@ -21,7 +22,7 @@ func _ready() -> void:
$Buttons/Quit.connect("clicked", quitGame) $Buttons/Quit.connect("clicked", quitGame)
func newGame(): func newGame():
print("clicked new game") get_tree().change_scene_to_file.call_deferred("res://scenes/world/DynamicMap.tscn")
func quitGame(): func quitGame():
get_tree().quit.call_deferred() get_tree().quit.call_deferred()
@ -33,6 +34,23 @@ func _process(_delta: float) -> void:
else: else:
jankyCounter += 1 jankyCounter += 1
if jankyFix.visible:
return
if MusicSystem.ShouldPlay == 21:
#EndBreathSFX = LoadSound("SFX\Ending\MenuBreath.ogg")
#EndBreathCHN = PlaySound(EndBreathSFX)
#ShouldPlay = 66
pass
elif MusicSystem.ShouldPlay == 66:
#if Not ChannelPlaying(EndBreathCHN) Then
#FreeSound(EndBreathSFX)
#ShouldPlay = 11
#EndIf
pass
else:
MusicSystem.ShouldPlay = 11
Global.menuScale = size.y / 1024.0 Global.menuScale = size.y / 1024.0

44
src/MusicSystem.gd Normal file
View file

@ -0,0 +1,44 @@
extends Node
class_name MusicSystem
static var NowPlaying: int = 2
static var ShouldPlay: int = 11
static var CurrMusicVolume: float = 1.0
static var CurrMusic: int = 1
static var UpdateMusic: bool = false
func _ready():
name = "MusicSystem"
func _process(delta: float) -> void:
if not UpdateMusic:
return
#if ConsoleFlush Then
#If Not ChannelPlaying(ConsoleMusPlay) Then ConsoleMusPlay = PlaySound(ConsoleMusFlush)
#ElseIf (Not PlayCustomMusic)
if NowPlaying != ShouldPlay: # playing the wrong clip, fade out
CurrMusicVolume = max(CurrMusicVolume - (Global.FPSfactor / 250.0), 0.0)
if CurrMusicVolume == 0:
if NowPlaying < 66:
Global.MusicCHN.stop()
NowPlaying = ShouldPlay
CurrMusic = 0
else: # playing the right clip
CurrMusicVolume = CurrMusicVolume + (Global.MusicVolume - CurrMusicVolume) * (0.1 * Global.FPSfactor)
if NowPlaying < 66:
if CurrMusic == 0:
Global.MusicCHN.stop()
Global.MusicCHN.stream = Global.LoadAudio("SFX/Music/" + str(Global.Music[NowPlaying]) + ".ogg")
Global.MusicCHN.stream.loop = true
Global.MusicCHN.volume_db = linear_to_db(0)
Global.MusicCHN.play()
CurrMusic = 1
Global.MusicCHN.volume_db = linear_to_db(CurrMusicVolume)
#Else
#If FPSfactor > 0 Or OptionsMenu = 2 Then
#;CurrMusicVolume = 1.0
#If (Not ChannelPlaying(MusicCHN)) Then MusicCHN = PlaySound_Strict(CustomMusic)
#ChannelVolume MusicCHN,1.0*MusicVolume
#EndIf
#EndIf

1
src/MusicSystem.gd.uid Normal file
View file

@ -0,0 +1 @@
uid://cev5wfhvjabsb

View file

@ -10,8 +10,10 @@ var sprintIconBG: ColorRect
var blinkBar: Control var blinkBar: Control
var sprintBar: Control var sprintBar: Control
var Hud: Control var Hud: Control
var map: Node3D
func _ready() -> void: func _ready() -> void:
map = get_parent()
Global.player = self Global.player = self
head = $Head head = $Head
camera = $Head/Camera camera = $Head/Camera
@ -67,6 +69,8 @@ var EyeStuck:float = 0
var BlinkEffect:float = 1.0 var BlinkEffect:float = 1.0
var BlinkEffectTimer:float = 0 var BlinkEffectTimer:float = 0
var CurrStepSFX: int = 0
var LightBlink = 0 var LightBlink = 0
var LightFlash = 0 var LightFlash = 0
@ -84,6 +88,11 @@ const IRRITATED_RED = Color(0.78431372549, 0, 0)
var cameraMoveByVector = Vector2() var cameraMoveByVector = Vector2()
func GetStepSound():
if floorPick.is_colliding():
return Global.StepSoundFromTexture(floorPick.get_collider().get_meta("texName"))
return 0
func _process(delta: float) -> void: func _process(delta: float) -> void:
if (abs(cameraMoveByVector.x) > 0 or abs(cameraMoveByVector.y) > 0): if (abs(cameraMoveByVector.x) > 0 or abs(cameraMoveByVector.y) > 0):
Rotation.x -= rad_to_deg(cameraMoveByVector.x * 120 * delta); Rotation.x -= rad_to_deg(cameraMoveByVector.x * 120 * delta);
@ -111,13 +120,12 @@ func _process(delta: float) -> void:
if BlinkTimer <= -20: if BlinkTimer <= -20:
# Randomizes the frequency of blinking. Scales with difficulty. # Randomizes the frequency of blinking. Scales with difficulty.
#Select SelectedDifficulty\otherFactors if Global.SelectedDifficulty.otherFactors == Constants.EASY:
# Case EASY BLINKFREQ = randi_range(490,700)
BLINKFREQ = randi_range(490,700) elif Global.SelectedDifficulty.otherFactors == Constants.NORMAL:
# Case NORMAL BLINKFREQ = randi_range(455,665)
#BLINKFREQ = randi_range(455,665) elif Global.SelectedDifficulty.otherFactors == Constants.HARD:
# Case HARD BLINKFREQ = randi_range(420,630)
#BLINKFREQ = randi_range(420,630)
BlinkTimer = BLINKFREQ BlinkTimer = BLINKFREQ
BlinkTimer = BlinkTimer - Global.FPSfactor BlinkTimer = BlinkTimer - Global.FPSfactor
@ -227,33 +235,31 @@ func _process(delta: float) -> void:
Shake = fmod((Shake + Global.FPSfactor * min(Sprint, 1.5) * 7), 720) Shake = fmod((Shake + Global.FPSfactor * min(Sprint, 1.5) * 7), 720)
if shake < 180 and fmod(Shake, 360) >= 180 and KillTimer >= 0: if shake < 180 and fmod(Shake, 360) >= 180 and KillTimer >= 0:
print("step sound") print("step sound")
#if CurrStepSFX == 0: if CurrStepSFX == 0:
#temp = GetStepSound(Collider) var temp = GetStepSound()
#if Sprint == 1.0: if Sprint == 1.0:
#PlayerSoundVolume = max(4.0, PlayerSoundVolume) Global.PlayerSoundVolume = max(4.0, Global.PlayerSoundVolume)
#tempchn% = PlaySound_Strict(StepSFX(temp, 0, Rand(0, 7))) var tempchn = Global.PlayTempSound(map.StepSFX[temp][0][randi_range(0, 7)])
#ChannelVolume tempchn, (1.0-(Crouch*0.6))*SFXVolume# tempchn.volume_db = linear_to_db((1.0 - (Crouch * 0.6)) * Global.SFXVolume)
#Else else:
#PlayerSoundVolume = Max(2.5-(Crouch*0.6),PlayerSoundVolume) Global.PlayerSoundVolume = max(2.5 - (Crouch * 0.6), Global.PlayerSoundVolume)
#tempchn% = PlaySound_Strict(StepSFX(temp, 1, Rand(0, 7))) var tempchn = Global.PlayTempSound(map.StepSFX[temp][1][randi_range(0, 7)])
#ChannelVolume tempchn, (1.0-(Crouch*0.6))*SFXVolume# tempchn.volume_db = linear_to_db((1.0 - (Crouch * 0.6)) * Global.SFXVolume)
#End If elif CurrStepSFX == 1:
#elif CurrStepSFX == 1: var tempchn = Global.PlayTempSound(map.Step2SFX[randi_range(0, 2)])
#tempchn% = PlaySound_Strict(Step2SFX(Rand(0, 2))) tempchn.volume_db = linear_to_db((1.0 - (Crouch * 0.4)) * Global.SFXVolume)
#ChannelVolume tempchn, (1.0-(Crouch*0.4))*SFXVolume# elif CurrStepSFX == 2:
#elif CurrStepSFX == 2: var tempchn = Global.PlayTempSound(map.Step2SFX[randi_range(3,5)])
#tempchn% = PlaySound_Strict(Step2SFX(Rand(3,5))) tempchn.volume_db = linear_to_db((1.0 - (Crouch * 0.4)) * Global.SFXVolume)
#ChannelVolume tempchn, (1.0-(Crouch*0.4))*SFXVolume# elif CurrStepSFX == 3:
#elif CurrStepSFX == 3: if Sprint == 1.0:
#If Sprint = 1.0 Then Global.PlayerSoundVolume = max(4.0, Global.PlayerSoundVolume)
#PlayerSoundVolume = Max(4.0,PlayerSoundVolume) var tempchn = Global.PlayTempSound(map.StepSFX[0][0][randi_range(0, 7)])
#tempchn% = PlaySound_Strict(StepSFX(0, 0, Rand(0, 7))) tempchn.volume_db = linear_to_db((1.0 - (Crouch * 0.6)) * Global.SFXVolume)
#ChannelVolume tempchn, (1.0-(Crouch*0.6))*SFXVolume# else:
#Else Global.PlayerSoundVolume = max(2.5 - (Crouch * 0.6), Global.PlayerSoundVolume)
#PlayerSoundVolume = Max(2.5-(Crouch*0.6),PlayerSoundVolume) var tempchn = Global.PlayTempSound(map.StepSFX[0][1][randi_range(0, 7)])
#tempchn% = PlaySound_Strict(StepSFX(0, 1, Rand(0, 7))) tempchn.volume_db = linear_to_db((1.0 - (Crouch * 0.6)) * Global.SFXVolume)
#ChannelVolume tempchn, (1.0-(Crouch*0.6))*SFXVolume#
#End If
else: # noclip on else: # noclip on
if Input.is_action_pressed("player_sprint"): if Input.is_action_pressed("player_sprint"):
Sprint = 2.5 Sprint = 2.5
@ -350,18 +356,16 @@ func _process(delta: float) -> void:
#Next #Next
if CollidedFloor: if CollidedFloor:
#If DropSpeed# < - 0.07 Then if DropSpeed < -0.07:
#If CurrStepSFX=0 Then if CurrStepSFX == 0:
#PlaySound_Strict(StepSFX(GetStepSound(Collider), 0, Rand(0, 7))) Global.PlayTempSound(map.StepSFX[GetStepSound()][0][randi_range(0, 7)])
#ElseIf CurrStepSFX=1 elif CurrStepSFX == 1:
#PlaySound_Strict(Step2SFX(Rand(0, 2))) Global.PlayTempSound(map.Step2SFX[randi_range(0, 2)])
#ElseIf CurrStepSFX=2 elif CurrStepSFX == 2:
#PlaySound_Strict(Step2SFX(Rand(3, 5))) Global.PlayTempSound(map.Step2SFX[randi_range(3, 5)])
#ElseIf CurrStepSFX=3 elif CurrStepSFX == 3:
#PlaySound_Strict(StepSFX(0, 0, Rand(0, 7))) Global.PlayTempSound(map.StepSFX[0][0][randi_range(0, 7)])
#EndIf Global.PlayerSoundVolume = max(3.0, Global.PlayerSoundVolume)
#PlayerSoundVolume = Max(3.0,PlayerSoundVolume)
#EndIf
DropSpeed = 0 DropSpeed = 0
else: else:
DropSpeed = min(max(DropSpeed - 0.006 * Global.FPSfactor, -2.0), 0.0) DropSpeed = min(max(DropSpeed - 0.006 * Global.FPSfactor, -2.0), 0.0)

42
src/UpdateEvents.gd Normal file
View file

@ -0,0 +1,42 @@
extends Node
;~IDEal Editor Parameters:
;~F#1#14#29#13B#343#535#545#5B1#630#68D#6B4#6C2#6CC#6D9#8CA#8EB#93F#976#983#9BD
;~F#9CE#9EE#9F7#A01#A10#B0B#B2D#DE2#E29#E3F#E4B#E68#EB9#ED2#FA1#10A3#1123#113C#115B#11C6
;~F#11D3#11EC#1284#1439#152D#1581#1633#16D4#1796#17A9#187A#18A7#18C4#18EB#191B#1941#1969#19BB#19F8#1A29
;~F#1A3C#1AFD#1B6A#1B7D#1B8B#1BCF#1BF0#1CDE#1D53#1E50#1ED1#1F1F#1F24#1F73#1F79#213E
;~B#10D3#1DD1
;~C#Blitz3D

1
src/UpdateEvents.gd.uid Normal file
View file

@ -0,0 +1 @@
uid://qgv7j32s51vr

View file

@ -54,7 +54,7 @@ static func GetCaseiFileName(path: String):
static func Init1DArray(size: int, initValue: Variant = null) -> Array: static func Init1DArray(size: int, initValue: Variant = null) -> Array:
var array = [] var array = []
for i in range(size): for i in range(size + 1):
array.append(initValue) array.append(initValue)
return array return array
@ -62,14 +62,28 @@ static func Init1DArray(size: int, initValue: Variant = null) -> Array:
# I want this to be array[y][x] but this is coming from b3d # I want this to be array[y][x] but this is coming from b3d
static func Init2DArray(sizeX: int, sizeY: int, initValue: Variant = null) -> Array: static func Init2DArray(sizeX: int, sizeY: int, initValue: Variant = null) -> Array:
var array = [] var array = []
for i in range(sizeX): for i in range(sizeX + 1):
var yArray = [] var yArray = []
array.append(yArray) array.append(yArray)
for i1 in range(sizeY): for i1 in range(sizeY + 1):
yArray.append(initValue) yArray.append(initValue)
return array return array
# [x][y][z], unfortunately
static func Init3DArray(sizeX: int, sizeY: int, sizeZ: int, initValue: Variant = null) -> Array:
var array = []
for i in range(sizeX + 1):
var yArray = []
array.append(yArray)
for i1 in range(sizeY + 1):
var zArray = []
yArray.append(zArray)
for i2 in range(sizeZ + 1):
zArray.append(initValue)
return array
static func GenerateSeedNumber(seedv: String): static func GenerateSeedNumber(seedv: String):
var hashv = 0 var hashv = 0
if len(seedv) == 0: if len(seedv) == 0:

View file

@ -28,10 +28,11 @@ static func GetInt(dict: Dictionary, name: String) -> int:
return dict[name].to_int() return dict[name].to_int()
return 0 return 0
static func GetFloat(dict: Dictionary, name: String) -> int: static func GetFloat(dict: Dictionary, name: String) -> float:
if dict.has(name): if dict.has(name):
return dict[name].to_float() return dict[name].to_float()
return 0 else:
return 0
static func GetBool(dict: Dictionary, name: String) -> bool: static func GetBool(dict: Dictionary, name: String) -> bool:
if dict.has(name): if dict.has(name):

View file

@ -262,6 +262,7 @@ static func LoadRMesh(file: String, rt: RoomTemplate):
mat.transparency = BaseMaterial3D.TRANSPARENCY_ALPHA_DEPTH_PRE_PASS if activeAlbedoHasAlpha else BaseMaterial3D.TRANSPARENCY_DISABLED mat.transparency = BaseMaterial3D.TRANSPARENCY_ALPHA_DEPTH_PRE_PASS if activeAlbedoHasAlpha else BaseMaterial3D.TRANSPARENCY_DISABLED
meshInstance.set_surface_override_material(0, mat) meshInstance.set_surface_override_material(0, mat)
meshInstance.create_trimesh_collision() meshInstance.create_trimesh_collision()
meshInstance.get_child(0).set_meta("texName", textureName)
scene.add_child(meshInstance) scene.add_child(meshInstance)
#print("YOYOYO MARKER") #print("YOYOYO MARKER")

14
src/objects/Difficulty.gd Normal file
View file

@ -0,0 +1,14 @@
class_name Difficulty
var name: String
var description: String
var permaDeath: bool
var aggressiveNPCs: float
var saveType: int
var otherFactors: int
var r: int
var g: int
var b: int
var customizable: bool = false

View file

@ -0,0 +1 @@
uid://c8sh6jv0vci5p

16
src/objects/Event.gd Normal file
View file

@ -0,0 +1,16 @@
class_name Event
var EventName: String
var room: Room
var EventState: float
var EventState2: float
var EventState3: float
#var SoundCHN:, SoundCHN2%
var Sound: AudioStream
var Sound2: AudioStream
#var SoundCHN_isStream%, SoundCHN2_isStream%
var EventStr: String
var img: CompressedTexture2D

1
src/objects/Event.gd.uid Normal file
View file

@ -0,0 +1 @@
uid://ciycs8rul7vim