Camera system YAY!!!

This commit is contained in:
2026-03-27 10:35:03 -07:00
parent a04d7699ae
commit 7ba95c5949
15 changed files with 281 additions and 53 deletions

View File

@@ -0,0 +1,49 @@
class_name cCamera
var cam: Dictionary
var camID: String
var camGraph = Global.loadJSON("res://Data/cameras.json")
var name: String
var disabled: bool
var rendersChart: Dictionary
var renders: Dictionary
var locationID: String
var location: cLocation
# Called when the node enters the scene tree for the first time.
func _init(id: String) -> void:
camID = id
cam = camGraph[camID]
print("Setting up camera " + camID)
name = cam.get("name")
disabled = cam.get("disabled")
rendersChart = cam.get("renders")
locationID = str( int( cam.get("location") ) )
location = cLocation.new(locationID)
print(name)
print(disabled)
print(rendersChart)
print(location)
_loadRenders()
func _loadRenders():
renders = {}
for key in rendersChart:
var renderPath = rendersChart[key]
if renderPath == null or not FileAccess.file_exists(renderPath):
push_error("Missing render: " + str(renderPath))
continue
renders[key] = load(renderPath)
func getFeed() -> Texture2D:
var hash = location.makeHash()
if not renders.has(hash): return null
return renders[hash]

View File

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

View File

@@ -0,0 +1,53 @@
class_name cCameraViewer
extends TextureRect
var defaultTexture: Texture2D
var activeCamera: cCamera = null
var activeCameraID: int = -1
var activeTexture: Texture2D = null
func _ready() -> void:
clearCamera()
func _process(delta: float) -> void:
if activeCamera == null:
return
var newTexture = getCameraRender()
if newTexture != activeTexture:
activeTexture = newTexture
renderCamera()
func setCamera(id: int) -> void:
clearCamera()
activeCameraID = id
activeCamera = Global.game.camera
renderCamera()
func renderCamera() -> void:
if activeTexture == null:
self.texture = defaultTexture
else:
self.texture = activeTexture
func clearCamera() -> void:
activeCamera = null
activeCameraID = -1
activeTexture = defaultTexture
renderCamera()
func getCameraRender() -> Texture2D:
if activeCamera == null:
return defaultTexture
var feed = activeCamera.getFeed()
if feed == null:
return defaultTexture
return feed

View File

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