mirror of
https://github.com/kaosat-dev/Blender_bevy_components_workflow.git
synced 2024-12-23 08:04:10 +00:00
cfbda24da7
* adds a new crate: ```bevy_registry_export``` to be able to create a json import of the registered component/type definitions * adds a new Blender addon: ```bevy_components``` that takes that json data to generate custom UIs for components , to be to add & edit components easily in Blender * also adds component metadata per object for more advanced features * etc * updates to bevy_gltf_components & bevy_gltf_blueprints to add legacy_mode to support the "old"/current style component definitions * same with gltf_auto_export Blender add_on * closes #60
60 lines
2.3 KiB
Python
60 lines
2.3 KiB
Python
# helper function that returns a lambda, used for the PropertyGroups update function
|
|
def update_calback_helper(definition, update, component_name_override):
|
|
return lambda self, context: update(self, context, definition, component_name_override)
|
|
|
|
import bpy
|
|
from bpy.props import (StringProperty)
|
|
from bpy_types import PropertyGroup
|
|
|
|
# this helper creates a "fake"/wrapper property group that is NOT a real type in the registry
|
|
# usefull for things like value types in list items etc
|
|
def generate_wrapper_propertyGroup(short_name, item_long_name, definition, registry, update):
|
|
value_types_defaults = registry.value_types_defaults
|
|
blender_property_mapping = registry.blender_property_mapping
|
|
is_item_value_type = item_long_name in value_types_defaults
|
|
|
|
wrapper_name = "wrapper_" + short_name
|
|
|
|
wrapper_definition = {
|
|
"isComponent": False,
|
|
"isResource": False,
|
|
"items": False,
|
|
"prefixItems": [
|
|
{
|
|
"type": {
|
|
"$ref": definition
|
|
}
|
|
}
|
|
],
|
|
"short_name": wrapper_name,
|
|
"title": wrapper_name,
|
|
"type": "array",
|
|
"typeInfo": "TupleStruct"
|
|
}
|
|
registry.add_custom_type(wrapper_name, wrapper_definition)
|
|
|
|
blender_property = StringProperty(default="", update=update)
|
|
if item_long_name in blender_property_mapping:
|
|
value = value_types_defaults[item_long_name] if is_item_value_type else None
|
|
blender_property_def = blender_property_mapping[item_long_name]
|
|
blender_property = blender_property_def["type"](
|
|
**blender_property_def["presets"],# we inject presets first
|
|
name = "property_name",
|
|
default = value,
|
|
update = update
|
|
)
|
|
|
|
wrapper_annotations = {
|
|
'0' : blender_property
|
|
}
|
|
property_group_params = {
|
|
'__annotations__': wrapper_annotations,
|
|
'tupple_or_struct': "tupple",
|
|
'field_names': ['0'],
|
|
**dict(with_properties = False, with_items= True, with_enum= False, with_list= False, short_name= wrapper_name, type_name=wrapper_name),
|
|
#'root_component': root_component
|
|
}
|
|
property_group_class = type(wrapper_name, (PropertyGroup,), property_group_params)
|
|
bpy.utils.register_class(property_group_class)
|
|
|
|
return property_group_class |