Camera system YAY!!!
This commit is contained in:
49
Scripts/Gameplay/Camera/cCamera.gd
Normal file
49
Scripts/Gameplay/Camera/cCamera.gd
Normal 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]
|
||||
1
Scripts/Gameplay/Camera/cCamera.gd.uid
Normal file
1
Scripts/Gameplay/Camera/cCamera.gd.uid
Normal file
@@ -0,0 +1 @@
|
||||
uid://bsxrimscxvjck
|
||||
53
Scripts/Gameplay/Camera/cCameraViewer.gd
Normal file
53
Scripts/Gameplay/Camera/cCameraViewer.gd
Normal 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
|
||||
1
Scripts/Gameplay/Camera/cCameraViewer.gd.uid
Normal file
1
Scripts/Gameplay/Camera/cCameraViewer.gd.uid
Normal file
@@ -0,0 +1 @@
|
||||
uid://be6xuapep782t
|
||||
Reference in New Issue
Block a user