mirror of
https://github.com/CalcProgrammer1/OpenRGB.git
synced 2026-05-24 22:45:55 -04:00
Settings Rework
* Add JSON string configuration field to RGBController to store device-specific configurations
* This JSON string holds both configuration and schema
* Add settings schema tracking to SettingsManager
* Implement dynamic settings widget that generates a settings UI based on a JSON schema
* Implement SettingsManager callback for notifying of settings changes and settings schema updates
* Always enable Entire Device zone option and use it to enable Edit Device
* Rename SaveSizes to SaveConfiguration in ProfileManager and Sizes.json to Configuration.json
* Add zone flag for indicating that a zone's geometry may change, informing profile manager to ignore this check
* Remove Theme setting and Theme Manager, as this didn't work on most setups anyways and Qt6 has proper Windows dark theming
This commit is contained in:
@@ -32,6 +32,13 @@ void PluginManagerResourceManagerCallback(void * this_ptr, unsigned int update_r
|
||||
this_obj->ResourceManagerCallback(update_reason);
|
||||
}
|
||||
|
||||
void PluginManagerSettingsManagerCallback(void * this_ptr, unsigned int update_reason)
|
||||
{
|
||||
PluginManager * this_obj = (PluginManager *)this_ptr;
|
||||
|
||||
this_obj->SettingsManagerCallback(update_reason);
|
||||
}
|
||||
|
||||
PluginManager::PluginManager()
|
||||
{
|
||||
/*-----------------------------------------------------*\
|
||||
@@ -54,6 +61,7 @@ PluginManager::PluginManager()
|
||||
\*-----------------------------------------------------*/
|
||||
ResourceManager::get()->GetProfileManager()->RegisterProfileManagerCallback(PluginManagerProfileManagerCallback, this);
|
||||
ResourceManager::get()->RegisterResourceManagerCallback(PluginManagerResourceManagerCallback, this);
|
||||
ResourceManager::get()->GetSettingsManager()->RegisterSettingsManagerCallback(PluginManagerSettingsManagerCallback, this);
|
||||
}
|
||||
|
||||
PluginManager::~PluginManager()
|
||||
@@ -61,8 +69,9 @@ PluginManager::~PluginManager()
|
||||
/*-----------------------------------------------------*\
|
||||
| Unegister callbacks |
|
||||
\*-----------------------------------------------------*/
|
||||
ResourceManager::get()->GetProfileManager()->RegisterProfileManagerCallback(PluginManagerProfileManagerCallback, this);
|
||||
ResourceManager::get()->RegisterResourceManagerCallback(PluginManagerResourceManagerCallback, this);
|
||||
ResourceManager::get()->GetProfileManager()->UnregisterProfileManagerCallback(PluginManagerProfileManagerCallback, this);
|
||||
ResourceManager::get()->UnregisterResourceManagerCallback(PluginManagerResourceManagerCallback, this);
|
||||
ResourceManager::get()->GetSettingsManager()->UnregisterSettingsManagerCallback(PluginManagerSettingsManagerCallback, this);
|
||||
}
|
||||
|
||||
void PluginManager::RegisterAddPluginCallback(AddPluginCallback new_callback, void * new_callback_arg)
|
||||
@@ -682,6 +691,17 @@ void PluginManager::ResourceManagerCallback(unsigned int update_reason)
|
||||
}
|
||||
}
|
||||
|
||||
void PluginManager::SettingsManagerCallback(unsigned int update_reason)
|
||||
{
|
||||
for(std::size_t plugin_idx = 0; plugin_idx < ActivePlugins.size(); plugin_idx++)
|
||||
{
|
||||
if(ActivePlugins[plugin_idx].enabled && ActivePlugins[plugin_idx].loader->isLoaded())
|
||||
{
|
||||
ActivePlugins[plugin_idx].plugin->SettingsManagerUpdated(update_reason);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/*---------------------------------------------------------*\
|
||||
| Plugin Information |
|
||||
\*---------------------------------------------------------*/
|
||||
|
||||
Reference in New Issue
Block a user