Welcome to mirror list, hosted at ThFree Co, Russian Federation.

git.blender.org/blender.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBrecht Van Lommel <brecht@blender.org>2020-08-19 19:12:52 +0300
committerBrecht Van Lommel <brecht@blender.org>2020-09-09 18:01:17 +0300
commit370d6e50252b979433f27959070315911cc340e5 (patch)
treef270972dd522a928e74b23334bb91a1cf174382f /release
parenta1397a3cc69382a64ab97bb71e4769fc0add0791 (diff)
Geometry: add Attributes panel for PointCloud and Hair
There is a list of attributes, along with operators to add and remove attributes. For adding, there are a few standard attributes that can be added quickly, as well as a popup to create a custom attribute. Ref T76659 Differential Revision: https://developer.blender.org/D8636
Diffstat (limited to 'release')
-rw-r--r--release/scripts/startup/bl_ui/properties_data_hair.py68
-rw-r--r--release/scripts/startup/bl_ui/properties_data_pointcloud.py67
2 files changed, 123 insertions, 12 deletions
diff --git a/release/scripts/startup/bl_ui/properties_data_hair.py b/release/scripts/startup/bl_ui/properties_data_hair.py
index 6017765b83d..58491f16c6e 100644
--- a/release/scripts/startup/bl_ui/properties_data_hair.py
+++ b/release/scripts/startup/bl_ui/properties_data_hair.py
@@ -18,7 +18,7 @@
# <pep8 compliant>
import bpy
-from bpy.types import Panel, UIList
+from bpy.types import Menu, Panel, UIList
from rna_prop_ui import PropertyPanel
@@ -51,14 +51,68 @@ class DATA_PT_context_hair(DataButtonsPanel, Panel):
layout.template_ID(space, "pin_id")
-class DATA_PT_hair(DataButtonsPanel, Panel):
- bl_label = "Hair"
- COMPAT_ENGINES = {'BLENDER_RENDER', 'BLENDER_EEVEE', 'BLENDER_WORKBENCH'}
+class HAIR_MT_add_attribute(Menu):
+ bl_label = "Add Attribute"
+
+ @staticmethod
+ def add_standard_attribute(layout, hair, name, data_type, domain):
+ exists = hair.attributes.get(name) != None
+
+ col = layout.column()
+ col.enabled = not exists
+ col.operator_context = 'EXEC_DEFAULT'
+
+ props = col.operator("geometry.attribute_add", text=name)
+ props.name = name
+ props.data_type = data_type
+ props.domain = domain
def draw(self, context):
layout = self.layout
hair = context.hair
- pass
+
+ self.add_standard_attribute(layout, hair, 'Radius', 'FLOAT', 'POINT')
+ self.add_standard_attribute(layout, hair, 'Color', 'FLOAT_COLOR', 'POINT')
+
+ layout.separator()
+
+ layout.operator_context = 'INVOKE_DEFAULT'
+ layout.operator("geometry.attribute_add", text="Custom...")
+
+
+class HAIR_UL_attributes(UIList):
+ def draw_item(self, context, layout, data, attribute, icon, active_data, active_propname, index):
+ data_type = attribute.bl_rna.properties['data_type'].enum_items[attribute.data_type]
+ domain = attribute.bl_rna.properties['domain'].enum_items[attribute.domain]
+
+ split = layout.split(factor=0.5)
+ row = split.row()
+ row.prop(attribute, "name", text="", emboss=False)
+ sub = split.split()
+ sub.alignment = 'RIGHT'
+ sub.active = False
+ sub.label(text=domain.name)
+ sub.label(text=data_type.name)
+
+
+class DATA_PT_hair_attributes(DataButtonsPanel, Panel):
+ bl_label = "Attributes"
+ COMPAT_ENGINES = {'BLENDER_RENDER', 'BLENDER_EEVEE', 'BLENDER_WORKBENCH'}
+
+ def draw(self, context):
+ hair = context.hair
+
+ layout = self.layout
+ row = layout.row()
+
+ col = row.column()
+ col.template_list("HAIR_UL_attributes", "attributes", hair, "attributes", hair.attributes, "active_index", rows=3)
+
+ col = row.column(align=True)
+ col.menu("HAIR_MT_add_attribute", icon='ADD', text="")
+ col.operator("geometry.attribute_remove", icon='REMOVE', text="")
+
+
class DATA_PT_custom_props_hair(DataButtonsPanel, PropertyPanel, Panel):
COMPAT_ENGINES = {'BLENDER_RENDER', 'BLENDER_EEVEE', 'BLENDER_WORKBENCH'}
@@ -68,8 +122,10 @@ class DATA_PT_custom_props_hair(DataButtonsPanel, PropertyPanel, Panel):
classes = (
DATA_PT_context_hair,
- DATA_PT_hair,
+ DATA_PT_hair_attributes,
DATA_PT_custom_props_hair,
+ HAIR_MT_add_attribute,
+ HAIR_UL_attributes,
)
if __name__ == "__main__": # only for live edit.
diff --git a/release/scripts/startup/bl_ui/properties_data_pointcloud.py b/release/scripts/startup/bl_ui/properties_data_pointcloud.py
index 10ebdea3155..d7ff7389fc3 100644
--- a/release/scripts/startup/bl_ui/properties_data_pointcloud.py
+++ b/release/scripts/startup/bl_ui/properties_data_pointcloud.py
@@ -18,7 +18,7 @@
# <pep8 compliant>
import bpy
-from bpy.types import Panel, UIList
+from bpy.types import Menu, Panel, UIList
from rna_prop_ui import PropertyPanel
@@ -51,14 +51,67 @@ class DATA_PT_context_pointcloud(DataButtonsPanel, Panel):
layout.template_ID(space, "pin_id")
-class DATA_PT_pointcloud(DataButtonsPanel, Panel):
- bl_label = "Point Cloud"
- COMPAT_ENGINES = {'BLENDER_RENDER', 'BLENDER_EEVEE', 'BLENDER_WORKBENCH'}
+class POINTCLOUD_MT_add_attribute(Menu):
+ bl_label = "Add Attribute"
+
+ @staticmethod
+ def add_standard_attribute(layout, pointcloud, name, data_type, domain):
+ exists = pointcloud.attributes.get(name) != None
+
+ col = layout.column()
+ col.enabled = not exists
+ col.operator_context = 'EXEC_DEFAULT'
+
+ props = col.operator("geometry.attribute_add", text=name)
+ props.name = name
+ props.data_type = data_type
+ props.domain = domain
def draw(self, context):
layout = self.layout
pointcloud = context.pointcloud
- pass
+
+ self.add_standard_attribute(layout, pointcloud, 'Radius', 'FLOAT', 'POINT')
+ self.add_standard_attribute(layout, pointcloud, 'Color', 'FLOAT_COLOR', 'POINT')
+ self.add_standard_attribute(layout, pointcloud, 'Particle ID', 'INT', 'POINT')
+ self.add_standard_attribute(layout, pointcloud, 'Velocity', 'FLOAT_VECTOR', 'POINT')
+
+ layout.separator()
+
+ layout.operator_context = 'INVOKE_DEFAULT'
+ layout.operator("geometry.attribute_add", text="Custom...")
+
+
+class POINTCLOUD_UL_attributes(UIList):
+ def draw_item(self, context, layout, data, attribute, icon, active_data, active_propname, index):
+ data_type = attribute.bl_rna.properties['data_type'].enum_items[attribute.data_type]
+
+ split = layout.split(factor=0.75)
+ split.prop(attribute, "name", text="", emboss=False)
+ sub = split.row()
+ sub.alignment = 'RIGHT'
+ sub.active = False
+ sub.label(text=data_type.name)
+
+
+class DATA_PT_pointcloud_attributes(DataButtonsPanel, Panel):
+ bl_label = "Attributes"
+ COMPAT_ENGINES = {'BLENDER_RENDER', 'BLENDER_EEVEE', 'BLENDER_WORKBENCH'}
+
+ def draw(self, context):
+ pointcloud = context.pointcloud
+
+ layout = self.layout
+ row = layout.row()
+
+ col = row.column()
+ col.template_list("POINTCLOUD_UL_attributes", "attributes", pointcloud, "attributes", pointcloud.attributes, "active_index", rows=3)
+
+ col = row.column(align=True)
+ col.menu("POINTCLOUD_MT_add_attribute", icon='ADD', text="")
+ col.operator("geometry.attribute_remove", icon='REMOVE', text="")
+
+
class DATA_PT_custom_props_pointcloud(DataButtonsPanel, PropertyPanel, Panel):
COMPAT_ENGINES = {'BLENDER_RENDER', 'BLENDER_EEVEE', 'BLENDER_WORKBENCH'}
@@ -68,8 +121,10 @@ class DATA_PT_custom_props_pointcloud(DataButtonsPanel, PropertyPanel, Panel):
classes = (
DATA_PT_context_pointcloud,
- DATA_PT_pointcloud,
+ DATA_PT_pointcloud_attributes,
DATA_PT_custom_props_pointcloud,
+ POINTCLOUD_MT_add_attribute,
+ POINTCLOUD_UL_attributes,
)
if __name__ == "__main__": # only for live edit.