mirror of
https://github.com/Relintai/pandemonium_demo_projects.git
synced 2025-01-08 15:09:53 +01:00
41 lines
1.7 KiB
GDScript
41 lines
1.7 KiB
GDScript
extends Control
|
|
|
|
# The 3D viewport's scale factor. For instance, 1.0 is full resolution,
|
|
# 0.5 is half resolution and 2.0 is double resolution. Higher values look
|
|
# sharper but are slower to render. Values above 1 can be used for supersampling
|
|
# (SSAA), but filtering must be enabled for supersampling to work.
|
|
var scale_factor = 1.0
|
|
|
|
onready var viewport = $ViewportContainer/Viewport
|
|
onready var scale_label = $VBoxContainer/Scale
|
|
onready var filter_label = $VBoxContainer/Filter
|
|
|
|
func _ready():
|
|
viewport.get_texture().flags = Texture.FLAG_FILTER
|
|
|
|
# Required to change the 3D viewport's size when the window is resized.
|
|
# warning-ignore:return_value_discarded
|
|
get_viewport().connect("size_changed", self, "_root_viewport_size_changed")
|
|
|
|
|
|
func _unhandled_input(event):
|
|
if event.is_action_pressed("cycle_viewport_resolution"):
|
|
scale_factor = wrapf(scale_factor + 0.25, 0.25, 2.25)
|
|
viewport.size = get_viewport().size * scale_factor
|
|
scale_label.text = "Scale: %s%%" % str(scale_factor * 100)
|
|
|
|
if event.is_action_pressed("toggle_filtering"):
|
|
# Toggle the Filter flag on the ViewportTexture.
|
|
viewport.get_texture().flags ^= Texture.FLAG_FILTER
|
|
|
|
var filter_enabled = viewport.get_texture().flags & Texture.FLAG_FILTER
|
|
filter_label.text = "Filter: %s" % ("Enabled" if filter_enabled else "Disabled")
|
|
|
|
|
|
# Called when the root's viewport size changes (i.e. when the window is resized).
|
|
# This is done to handle multiple resolutions without losing quality.
|
|
func _root_viewport_size_changed():
|
|
# The viewport is resized depending on the window height.
|
|
# To compensate for the larger resolution, the viewport sprite is scaled down.
|
|
viewport.size = get_viewport().size * scale_factor
|