Check out our latest project ✨ OpenChapter.io: free ebooks the way its meant to be 📖

Smart Graphics Settings

An asset by lucasbecker.dev
The page banner background of a mountain and forest
Smart Graphics Settings hero image

Quick Information

0 ratings
Smart Graphics Settings icon image
lucasbecker.dev
Smart Graphics Settings

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.

Supported Engine Version
4.4
Version String
0.1.2
License Version
MIT
Support Level
community
Modified Date
6 months ago
Git URL
Issue URL

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:

  1. SmartGraphicsSettings (smart_graphics_settings.gd): The main controller that manages the UI and serves as the entry point.
  2. AdaptiveGraphics (adaptive_graphics.gd): Handles the automatic adjustment of graphics settings based on performance.
  3. GraphicsSettingsManager (graphics_settings_manager.gd): Manages all available graphics settings and their application.
  4. FPSMonitor (fps_monitor.gd): Monitors and analyzes framerate performance.
  5. AdaptiveGraphicsUI (adaptive_graphics_ui.gd): Provides the user interface for adjusting settings.

Installation and Setup

Manual Installation

  1. Copy the addons/smart_graphics_settings folder to your project's addons directory
  2. Enable the plugin in Project Settings → Plugins

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_threading to false
  • Increase adjustment_cooldown to reduce the frequency of adjustments

UI Issues

  • If the UI doesn't appear, check that the input action toggle_graphics_settings is 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_setting method to add renderer-specific settings

Best Practices

  1. Initialize Early: Set up the SmartGraphicsSettings at the start of your game
  2. Default Presets: Provide sensible default presets for different hardware capabilities
  3. Save User Preferences: Always save and restore user settings between sessions
  4. Testing: Test on various hardware configurations to ensure proper adaptation
  5. 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

0 ratings

Your Rating

Headline must be at least 3 characters but not more than 50
Review must be at least 5 characters but not more than 500
Please sign in to add a review

Quick Information

0 ratings
Smart Graphics Settings icon image
lucasbecker.dev
Smart Graphics Settings

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.

Supported Engine Version
4.4
Version String
0.1.2
License Version
MIT
Support Level
community
Modified Date
6 months ago
Git URL
Issue URL

Open Source

Released under the AGPLv3 license

Plug and Play

Browse assets directly from Godot

Community Driven

Created by developers for developers