diff options
author | Kévin Dietrich <kevin.dietrich@mailoo.org> | 2021-12-23 20:05:00 +0300 |
---|---|---|
committer | Kévin Dietrich <kevin.dietrich@mailoo.org> | 2021-12-23 20:05:26 +0300 |
commit | 43f5e761a66e87fed664a199cda867639f8daf3e (patch) | |
tree | 58f60abb03ed87df10d69f7d9cc6a1955f599760 /source/blender/makesrna | |
parent | 7a71a95f32e57d8df51619e2e52384e5d217c439 (diff) |
Cache File: use panels to organize UI
This adds interface panels to organize the Cache File UI parameters for
modifiers and constraints into related components: velocity, time, and
render procedural.
Properties relating to the three aforementioned components are separated
from `uiTemplateCacheFile` into their own functions (e.g.
`uiTemplateCacheFileVelocity` for the velocity one), which are in turn
called from the specific panel creation routines of the modifiers and
constraints (for constraints, the functions are exposed to the RNA).
`uiTemplateCacheFile` now only shows the properties for the file path,
and in the case of constraints, the scale property.
The properties that are only defined per modifier (like the velocity
scale), are shown in the proper modifier layout panel if applicable.
Reviewed By: sybren
Differential Revision: https://developer.blender.org/D13652
Diffstat (limited to 'source/blender/makesrna')
-rw-r--r-- | source/blender/makesrna/intern/rna_ui_api.c | 52 |
1 files changed, 52 insertions, 0 deletions
diff --git a/source/blender/makesrna/intern/rna_ui_api.c b/source/blender/makesrna/intern/rna_ui_api.c index f96b3fc5eee..a406e867d6c 100644 --- a/source/blender/makesrna/intern/rna_ui_api.c +++ b/source/blender/makesrna/intern/rna_ui_api.c @@ -582,6 +582,43 @@ static void rna_uiTemplateCacheFile(uiLayout *layout, uiTemplateCacheFile(layout, C, ptr, propname); } +static void rna_uiTemplateCacheFileVelocity(uiLayout *layout, + PointerRNA *ptr, + const char *propname) +{ + PointerRNA fileptr; + if (!uiTemplateCacheFilePointer(ptr, propname, &fileptr)) { + return; + } + + uiTemplateCacheFileVelocity(layout, &fileptr); +} + +static void rna_uiTemplateCacheFileProcedural(uiLayout *layout, + bContext *C, + PointerRNA *ptr, + const char *propname) +{ + PointerRNA fileptr; + if (!uiTemplateCacheFilePointer(ptr, propname, &fileptr)) { + return; + } + + uiTemplateCacheFileProcedural(layout, C, &fileptr); +} + +static void rna_uiTemplateCacheFileTimeSettings(uiLayout *layout, + PointerRNA *ptr, + const char *propname) +{ + PointerRNA fileptr; + if (!uiTemplateCacheFilePointer(ptr, propname, &fileptr)) { + return; + } + + uiTemplateCacheFileTimeSettings(layout, &fileptr); +} + static void rna_uiTemplatePathBuilder(uiLayout *layout, PointerRNA *ptr, const char *propname, @@ -1795,6 +1832,21 @@ void RNA_api_ui_layout(StructRNA *srna) RNA_def_function_flag(func, FUNC_USE_CONTEXT); api_ui_item_rna_common(func); + func = RNA_def_function(srna, "template_cache_file_velocity", "rna_uiTemplateCacheFileVelocity"); + RNA_def_function_ui_description(func, "Show cache files velocity properties"); + api_ui_item_rna_common(func); + + func = RNA_def_function( + srna, "template_cache_file_procedural", "rna_uiTemplateCacheFileProcedural"); + RNA_def_function_ui_description(func, "Show cache files render procedural properties"); + RNA_def_function_flag(func, FUNC_USE_CONTEXT); + api_ui_item_rna_common(func); + + func = RNA_def_function( + srna, "template_cache_file_time_settings", "rna_uiTemplateCacheFileTimeSettings"); + RNA_def_function_ui_description(func, "Show cache files time settings"); + api_ui_item_rna_common(func); + func = RNA_def_function(srna, "template_recent_files", "uiTemplateRecentFiles"); RNA_def_function_ui_description(func, "Show list of recently saved .blend files"); RNA_def_int(func, "rows", 5, 1, INT_MAX, "", "Maximum number of items to show", 1, INT_MAX); |