feat(Blenvy:Blender): settings/configuration is now also tabbed for less scrolling & confusion

This commit is contained in:
kaosat.dev 2024-07-19 14:13:48 +02:00
parent 4519fb94a5
commit 5aa666ef00
4 changed files with 139 additions and 90 deletions

View File

@ -49,7 +49,7 @@ from .blueprints.operators import BLENVY_OT_blueprint_select
# blenvy core
from .core.blenvy_manager import BlenvyManager
from .core.operators import BLENVY_OT_tooling_switch
from .core.operators import BLENVY_OT_configuration_switch, BLENVY_OT_tooling_switch
from .core.ui.ui import (BLENVY_PT_SidePanel)
from .core.ui.scenes_list import BLENVY_OT_scenes_list_actions
from .assets.assets_folder_browser import BLENVY_OT_assets_paths_browse
@ -110,6 +110,7 @@ classes = [
# blenvy
BlenvyManager,
BLENVY_OT_tooling_switch,
BLENVY_OT_configuration_switch,
Asset,
AssetsRegistry,

View File

@ -54,6 +54,17 @@ class BlenvyManager(PropertyGroup):
update=save_settings
) # type: ignore
config_mode: EnumProperty(
items=(
('COMMON', "Common", "Switch to common configuration"),
('COMPONENTS', "Components", "Switch to components configuration"),
('EXPORT', "Export", "Switch to export configuration"),
),
default="COMMON",
update=save_settings
) # type: ignore
project_root_path: StringProperty(
name = "Project Root Path",
description="The root folder of your (Bevy) project (not assets!)",

View File

@ -1,11 +1,8 @@
from bpy_types import (Operator)
from bpy.props import (EnumProperty)
class BLENVY_OT_tooling_switch(Operator):
"""Switch bevy tooling"""
"""Switch blenvy tooling"""
bl_idname = "bevy.tooling_switch"
bl_label = "Switch bevy tooling"
#bl_options = {}
@ -29,3 +26,27 @@ class BLENVY_OT_tooling_switch(Operator):
context.window_manager.blenvy.mode = self.tool
return {'FINISHED'}
class BLENVY_OT_configuration_switch(Operator):
"""Switch tooling configuration"""
bl_idname = "bevy.config_switch"
bl_label = "Switch blenvy configuration"
#bl_options = {}
tool: EnumProperty(
items=(
('COMMON', "Common", "Switch to common configuration"),
('COMPONENTS', "Components", "Switch to components configuration"),
('EXPORT', "Export", "Switch to export configuration"),
)
) # type: ignore
@classmethod
def description(cls, context, properties):
return properties.tool
def execute(self, context):
context.window_manager.blenvy.config_mode = self.tool
return {'FINISHED'}

View File

@ -72,38 +72,66 @@ class BLENVY_PT_SidePanel(bpy.types.Panel):
tool_switch_components = target.operator(operator="bevy.tooling_switch", text="", icon="TOOL_SETTINGS")
tool_switch_components.tool = "TOOLS"
# Debug stuff
"""layout.label(text="Active Blueprint: "+ active_collection.name.upper())
layout.label(text="World scene active: "+ str(world_scene_active))
layout.label(text="Library scene active: "+ str(library_scene_active))
layout.label(text=blenvy.mode)"""
if blenvy.mode == "SETTINGS":
config_mode = blenvy.config_mode
row = layout.row()
config_target = row.box() if config_mode == 'COMMON' else row
config_switch = config_target.operator(operator="bevy.config_switch", text="", icon="OPTIONS")
config_switch.tool = "COMMON"
config_target = row.box() if config_mode == 'COMPONENTS' else row
config_switch = config_target.operator(operator="bevy.config_switch", text="", icon="PROPERTIES")
config_switch.tool = "COMPONENTS"
config_target = row.box() if config_mode == 'EXPORT' else row
config_switch = config_target.operator(operator="bevy.config_switch", text="", icon="EXPORT")
config_switch.tool = "EXPORT"
if config_mode == 'COMMON':
header, panel = layout.panel("common", default_closed=False)
header.label(text="Common")
if panel:
row = panel.row()
draw_common_settings_ui(panel, blenvy)
if config_mode == 'COMPONENTS':
header, panel = layout.panel("components", default_closed=False)
header.label(text="Components")
if panel:
components_ui.draw_settings_ui(panel, blenvy.components)
if config_mode == 'EXPORT':
header, panel = layout.panel("auto_export", default_closed=False)
header.label(text="Auto Export")
if panel:
auto_export_ui.draw_settings_ui(panel, blenvy.auto_export)
def draw_common_settings_ui(layout, settings):
blenvy = settings
row = layout.row()
draw_folder_browser(layout=row, label="Root Folder", prop_origin=blenvy, target_property="project_root_path")
row = panel.row()
row = layout.row()
draw_folder_browser(layout=row, label="Assets Folder", prop_origin=blenvy, target_property="assets_path")
row = panel.row()
row = layout.row()
draw_folder_browser(layout=row, label="Blueprints Folder", prop_origin=blenvy, target_property="blueprints_path")
row = panel.row()
row = layout.row()
draw_folder_browser(layout=row, label="Levels Folder", prop_origin=blenvy, target_property="levels_path")
row = panel.row()
row = layout.row()
draw_folder_browser(layout=row, label="Materials Folder", prop_origin=blenvy, target_property="materials_path")
panel.separator()
layout.separator()
# scenes selection
if len(blenvy.level_scenes) == 0 and len(blenvy.library_scenes) == 0:
row = panel.row()
row = layout.row()
row.alert = True
panel.alert = True
layout.alert = True
row.label(text="NO library or level scenes specified! at least one level scene or library scene is required!")
row = panel.row()
row = layout.row()
row.label(text="Please select and add one using the UI below")
section = panel
section = layout
rows = 2
row = section.row()
col = row.column()
@ -152,15 +180,3 @@ class BLENVY_PT_SidePanel(bpy.types.Panel):
remove_operator.scene_type = 'LEVEL'
remove_operator.scene_name = scene.name
col.separator()
header, panel = layout.panel("components", default_closed=False)
header.label(text="Components")
if panel:
components_ui.draw_settings_ui(panel, blenvy.components)
header, panel = layout.panel("auto_export", default_closed=False)
header.label(text="Auto Export")
if panel:
auto_export_ui.draw_settings_ui(panel, blenvy.auto_export)