adds select feature to editor

This commit is contained in:
Michel Fedde 2024-02-01 12:08:11 +01:00
parent 40a7e4b8ba
commit f763479a64
7 changed files with 106 additions and 7 deletions

View file

@ -1,9 +1,11 @@
import bpy
from src.menu import id_mask_select_menu
from src.operators.create_id_mask import CreateIDMaskOperator
from src.operators.id_editor_create_id import IDEDITOR_CreateIDOperator
from src.operators.id_editor_paint import IDEDITOR_PaintIDMaskOperator
from src.operators.id_editor_remove_id import IDEDITOR_RemoveIDOperator
from src.operators.id_mask_select import IDEDITOR_SelectIDMaskOperator
from src.panels.id_mask_editor_id_list import IDMaskEditorIDList
from src.properties.id_mask_editor_value_properties import IDMaskEditorValueProperties
from . panels.bake_panel_options import BakeToIDOptionsPanel
@ -38,21 +40,32 @@ classes = (
IDMaskEditorIDList,
IDEDITOR_CreateIDOperator,
IDEDITOR_RemoveIDOperator,
IDEDITOR_PaintIDMaskOperator
IDEDITOR_PaintIDMaskOperator,
IDEDITOR_SelectIDMaskOperator
)
menu_additions = [
id_mask_select_menu
]
def register():
for cls in classes:
bpy.utils.register_class(cls)
for menu in menu_additions:
menu.register()
setattr(bpy.types.Scene, 'bake_to_id_props', bpy.props.PointerProperty(type=BakeToIDProperties))
setattr(bpy.types.Mesh, 'id_mask_editor_properties', bpy.props.PointerProperty(type=IDMaskEditorProperties))
def unregister():
for menu in reversed(menu_additions):
menu.unregister()
for cls in reversed(classes):
bpy.utils.unregister_class(cls)
del bpy.types.Scene.bake_to_id_props

View file

@ -0,0 +1,12 @@
import bpy
from src.operators.id_mask_select import IDEDITOR_SelectIDMaskOperator
def id_mask_select_menu_function(self, context):
self.layout.operator(IDEDITOR_SelectIDMaskOperator.bl_idname).isCalledFromEditor = False
def register():
bpy.types.VIEW3D_MT_select_edit_mesh.append(id_mask_select_menu_function)
def unregister():
bpy.types.VIEW3D_MT_select_edit_mesh.remove(id_mask_select_menu_function)

View file

@ -3,7 +3,7 @@ import bpy
class CreateIDMaskOperator(bpy.types.Operator):
bl_idname = "id_mask_editor.create_id_mask_attribute"
bl_label = ""
bl_label = "Create ID Mask - Attribute"
bl_options = {'INTERNAL'}
@classmethod

View file

@ -2,8 +2,7 @@ import bpy
class IDEDITOR_PaintIDMaskOperator(bpy.types.Operator):
bl_idname = "id_mask_editor.paint_id_mask"
bl_label = "Paint"
bl_options = {'INTERNAL'}
bl_label = "Paint ID Mask"
def execute(self, context):
obj = context.active_object
@ -24,7 +23,6 @@ class IDEDITOR_PaintIDMaskOperator(bpy.types.Operator):
color_attribute = mesh.color_attributes.get(properties.target_attribute)
selected_polygons = []
for polygon in mesh.polygons:
if not polygon.select:
continue

View file

@ -0,0 +1,71 @@
import bpy
class IDEDITOR_SelectIDMaskOperator(bpy.types.Operator):
bl_idname = "id_mask_editor.select_id_mask"
bl_label = "Select by ID Mask"
bl_description = "Selects the faces of the active object, based on current ID mask"
isCalledFromEditor: bpy.props.BoolProperty(default=False)
@classmethod
def poll(cls, context):
obj = context.active_object
if obj.type != 'MESH':
return False
if not obj.data:
return False
mesh = obj.data
properties = mesh.id_mask_editor_properties
if not properties.target_attribute:
return False
return True
def execute(self, context):
obj = context.active_object
old_mode = bpy.context.object.mode
if old_mode != "OBJECT":
bpy.ops.object.mode_set(mode='OBJECT', toggle=False)
mesh = obj.data
properties = mesh.id_mask_editor_properties
color_attribute = mesh.color_attributes.get(properties.target_attribute)
test_color = self.get_test_color(properties, mesh, color_attribute)
if not test_color:
if old_mode != "OBJECT":
bpy.ops.object.mode_set(mode=old_mode, toggle=False)
return {'FINISHED'}
for polygon in mesh.polygons:
polygon_color = self.get_color_from_polygon(color_attribute, polygon)
if test_color[0] != polygon_color[0] or test_color[1] != polygon_color[1] or test_color[2] != polygon_color[2]:
continue
polygon.select = True
if old_mode != "OBJECT":
bpy.ops.object.mode_set(mode=old_mode, toggle=False)
return {'FINISHED'}
def get_test_color(self, properties, mesh, color_attribute):
if self.isCalledFromEditor:
color = properties.possible_ids[properties.active_id].color
return (color.r, color.g, color.b, 1.0)
if mesh.polygons.active:
return self.get_color_from_polygon(color_attribute, mesh.polygons[mesh.polygons.active])
return None
def get_color_from_polygon(self, attribute, polygon):
color = attribute.data[polygon.loop_indices[0]].color
return (color[0], color[1], color[2], 1.0)

View file

@ -4,6 +4,7 @@ from src.operators.create_id_mask import CreateIDMaskOperator
from src.operators.id_editor_create_id import IDEDITOR_CreateIDOperator
from src.operators.id_editor_paint import IDEDITOR_PaintIDMaskOperator
from src.operators.id_editor_remove_id import IDEDITOR_RemoveIDOperator
from src.operators.id_mask_select import IDEDITOR_SelectIDMaskOperator
from src.types.colors import get_color
@ -55,7 +56,11 @@ class IDMaskEditorPanel(bpy.types.Panel):
row = layout.row()
col = row.column()
col.operator(IDEDITOR_PaintIDMaskOperator.bl_idname, icon='VPAINT_HLT')
button_row = col.row()
button_row.operator(IDEDITOR_PaintIDMaskOperator.bl_idname, text='Paint', icon='VPAINT_HLT')
button_row.operator(IDEDITOR_SelectIDMaskOperator.bl_idname, text='Select', icon='SELECT_SET').isCalledFromEditor = True
col.template_list(
'IDMaskEditorIDList',
'IDMaskEditorIDList',