Install Asset
Install via Godot
To maintain one source of truth, Godot Asset Library is just a mirror of the old asset library so you can download directly on Godot via the integrated asset library browser
 
                            Quick Information
 
        Smart Graphics Settings is an adaptive graphics system that automatically adjusts visual quality based on performance to maintain a smooth framerate. It features comprehensive settings management for render scale, anti-aliasing, shadows, reflections, and more, along with a user-friendly UI for players to customize their experience. The system includes real-time FPS tracking, performance analysis, and platform-specific optimizations that detect and apply optimal settings for different devices. This beta release (v0.1.0) is open for testing and feedback from the community.
Smart Graphics Settings - Technical Documentation
This document provides detailed technical information about the Smart Graphics Settings addon for Godot 4.4, including its architecture, available settings, and API reference.
Architecture
The addon consists of several key components:
- SmartGraphicsSettings (smart_graphics_settings.gd): The main controller that manages the UI and serves as the entry point.
- AdaptiveGraphics (adaptive_graphics.gd): Handles the automatic adjustment of graphics settings based on performance.
- GraphicsSettingsManager (graphics_settings_manager.gd): Manages all available graphics settings and their application.
- FPSMonitor (fps_monitor.gd): Monitors and analyzes framerate performance.
- AdaptiveGraphicsUI (adaptive_graphics_ui.gd): Provides the user interface for adjusting settings.
Installation and Setup
Manual Installation
- Copy the addons/smart_graphics_settingsfolder to your project'saddonsdirectory
- Enable the plugin in Project Settings → Plugins
Autoload Singleton (Recommended)
The plugin automatically registers a singleton named SmartGraphicsSettings. To use it:
var settings: Node = get_node("/root/SmartGraphicsSettings")
Manual Node Addition
You can also add the SmartGraphicsSettings node manually to any scene:
var settings_node: Node = preload("res://addons/smart_graphics_settings/smart_graphics_settings.gd").new()
add_child(settings_node)
Configuration Options
AdaptiveGraphics Properties
| Property | Type | Description | 
|---|---|---|
| target_fps | int | Target framerate to maintain (default: 60) | 
| fps_tolerance | int | Acceptable FPS range around target (default: 5) | 
| adjustment_cooldown | float | Seconds between adjustments (default: 3.0) | 
| measurement_period | float | Seconds to measure FPS before adjusting (default: 2.0) | 
| enabled | bool | Whether adaptive graphics is enabled (default: true) | 
| allow_quality_increase | bool | Whether to increase quality when FPS is high (default: false) | 
| use_threading | bool | Whether to use threading for adjustments (default: true) | 
| setting_change_delay | float | Seconds between applying each setting change (default: 0.5) | 
| match_refresh_rate | bool | Whether to match target FPS to display refresh rate (default: false) | 
Available Graphics Settings
The following settings can be adjusted automatically or manually:
Render Scale
- Controls the internal rendering resolution
- Priority: Highest (adjusted first)
- Values: 0.5, 0.6, 0.7, 0.75, 0.8, 0.9, 1.0
Anti-Aliasing
- Controls the anti-aliasing method
- Priority: High
- Values: Off, FXAA, MSAA 2x, MSAA 4x, MSAA 8x, TAA
Shadows
- Controls shadow quality and resolution
- Priority: Medium
- Values: Off, Low, Medium, High, Ultra
Reflections
- Controls screen-space reflections quality
- Priority: Low
- Values: Off, Low, Medium, High
Global Illumination
- Controls global illumination method and quality
- Priority: Lowest (adjusted last)
- Values: Off, Low, Medium, High
API Reference
SmartGraphicsSettings
# Toggle the settings UI visibility
func toggle_ui() -> void
# Apply a specific quality preset (1-5)
func apply_quality_preset(preset_index: int) -> void
# Save current settings to config file
func save_settings() -> void
# Load settings from config file
func load_settings() -> void
AdaptiveGraphics
# Signal emitted when settings change
signal changed_settings
# Start the adaptive graphics system
func start() -> void
# Stop the adaptive graphics system
func stop() -> void
# Force an immediate adjustment
func force_adjustment() -> void
# Get the current action being performed
func get_current_action() -> String
# Set a specific setting value
func set_setting(setting_name: String, value_index: int) -> void
# Get the current value of a setting
func get_setting(setting_name: String) -> int
GraphicsSettingsManager
# Apply a specific quality preset (1-5)
func apply_preset(preset_index: int) -> void
# Get all available settings
func get_available_settings() -> Dictionary
# Get the current value of a setting
func get_setting_value(setting_name: String) -> Variant
# Set a specific setting value
func set_setting_value(setting_name: String, value_index: int) -> void
# Register a custom setting
func register_setting(setting_name: String, values: Array[Variant], 
                     current_index: int, priority: SettingPriority, 
                     type: SettingType) -> void
Custom Settings
You can register custom settings to be managed by the system:
var settings = get_node("/root/SmartGraphicsSettings")
var settings_manager = settings.adaptive_graphics.settings_manager
# Register a custom setting
var values: Array[Variant] = [false, true]
settings_manager.register_setting(
    "my_custom_setting",
    values,
    1, # Current index (true)
    GraphicsSettingsManager.SettingPriority.POST_PROCESSING,
    GraphicsSettingsManager.SettingType.ENVIRONMENT
)
# Connect to the changed_settings signal
settings.adaptive_graphics.changed_settings.connect(_on_settings_changed)
func _on_settings_changed() -> void:
    # Handle custom setting changes
    var custom_value = settings_manager.get_setting_value("my_custom_setting")
    print("Custom setting value: ", custom_value)
Troubleshooting
Performance Issues
- If you experience stuttering during adjustments, try setting use_threadingto false
- Increase adjustment_cooldownto reduce the frequency of adjustments
UI Issues
- If the UI doesn't appear, check that the input action toggle_graphics_settingsis properly registered
- The default key to toggle the UI is F7
Custom Renderer Support
- For custom renderers, you may need to manually register compatible settings
- Use the register_settingmethod to add renderer-specific settings
Best Practices
- Initialize Early: Set up the SmartGraphicsSettings at the start of your game
- Default Presets: Provide sensible default presets for different hardware capabilities
- Save User Preferences: Always save and restore user settings between sessions
- Testing: Test on various hardware configurations to ensure proper adaptation
- Feedback: Provide visual feedback when settings are being adjusted automatically
Smart Graphics Settings is an adaptive graphics system that automatically adjusts visual quality based on performance to maintain a smooth framerate. It features comprehensive settings management for render scale, anti-aliasing, shadows, reflections, and more, along with a user-friendly UI for players to customize their experience. The system includes real-time FPS tracking, performance analysis, and platform-specific optimizations that detect and apply optimal settings for different devices. This beta release (v0.1.0) is open for testing and feedback from the community.
Reviews
Quick Information
 
        Smart Graphics Settings is an adaptive graphics system that automatically adjusts visual quality based on performance to maintain a smooth framerate. It features comprehensive settings management for render scale, anti-aliasing, shadows, reflections, and more, along with a user-friendly UI for players to customize their experience. The system includes real-time FPS tracking, performance analysis, and platform-specific optimizations that detect and apply optimal settings for different devices. This beta release (v0.1.0) is open for testing and feedback from the community.
 
    