mirror of
https://github.com/Relintai/broken_seals.git
synced 2025-01-25 14:19:19 +01:00
Now the mesh data resource editor's gizmo just stored the editoed mesh data resource. Also smaller changes / comments.
This commit is contained in:
parent
556d3062b8
commit
98e50d4a64
@ -19,7 +19,10 @@ func create_gizmo(spatial):
|
|||||||
if spatial is MeshDataInstance:
|
if spatial is MeshDataInstance:
|
||||||
var gizmo = MDIGizmo.new()
|
var gizmo = MDIGizmo.new()
|
||||||
|
|
||||||
gizmo.plugin = plugin
|
gizmo.set_spatial_node(spatial)
|
||||||
|
gizmo.setup()
|
||||||
|
|
||||||
|
#gizmo.plugin = plugin
|
||||||
plugin.register_gizmo(gizmo)
|
plugin.register_gizmo(gizmo)
|
||||||
|
|
||||||
return gizmo
|
return gizmo
|
||||||
|
@ -2,6 +2,7 @@ tool
|
|||||||
extends EditorSpatialGizmo
|
extends EditorSpatialGizmo
|
||||||
|
|
||||||
var MeshOutline = preload("res://addons/mesh_data_resource_editor/utilities/mesh_outline.gd")
|
var MeshOutline = preload("res://addons/mesh_data_resource_editor/utilities/mesh_outline.gd")
|
||||||
|
var MeshDecompose = preload("res://addons/mesh_data_resource_editor/utilities/mesh_decompose.gd")
|
||||||
|
|
||||||
enum EditMode {
|
enum EditMode {
|
||||||
NONE, TRANSLATE, SCALE, ROTATE
|
NONE, TRANSLATE, SCALE, ROTATE
|
||||||
@ -13,9 +14,13 @@ enum AxisConstraint {
|
|||||||
Z = 1 << 2,
|
Z = 1 << 2,
|
||||||
}
|
}
|
||||||
|
|
||||||
var gizmo_size = 3.0
|
enum SelectionMode {
|
||||||
|
SELECTION_MODE_VERTEX = 0,
|
||||||
|
SELECTION_MODE_EDGE = 1,
|
||||||
|
SELECTION_MODE_FACE = 2,
|
||||||
|
}
|
||||||
|
|
||||||
var plugin : EditorPlugin
|
var gizmo_size = 3.0
|
||||||
|
|
||||||
var vertices : PoolVector3Array
|
var vertices : PoolVector3Array
|
||||||
var indices : PoolIntArray
|
var indices : PoolIntArray
|
||||||
@ -29,14 +34,21 @@ var selected_vertices_original : PoolVector3Array
|
|||||||
|
|
||||||
var edit_mode = EditMode.TRANSLATE
|
var edit_mode = EditMode.TRANSLATE
|
||||||
var axis_constraint = AxisConstraint.X | AxisConstraint.Y | AxisConstraint.Z
|
var axis_constraint = AxisConstraint.X | AxisConstraint.Y | AxisConstraint.Z
|
||||||
|
var selection_mode = SelectionMode.SELECTION_MODE_VERTEX
|
||||||
var previous_point : Vector2
|
var previous_point : Vector2
|
||||||
var is_dragging : bool = false
|
var is_dragging : bool = false
|
||||||
|
|
||||||
|
var _mdr : MeshDataResource = null
|
||||||
|
|
||||||
var _mesh_outline
|
var _mesh_outline
|
||||||
|
|
||||||
func _init():
|
func _init():
|
||||||
_mesh_outline = MeshOutline.new()
|
_mesh_outline = MeshOutline.new()
|
||||||
|
|
||||||
|
func setup() -> void:
|
||||||
|
get_spatial_node().connect("mesh_data_resource_changed", self, "on_mesh_data_resource_changed")
|
||||||
|
on_mesh_data_resource_changed(get_spatial_node().mesh_data)
|
||||||
|
|
||||||
func set_handle(index: int, camera: Camera, point: Vector2):
|
func set_handle(index: int, camera: Camera, point: Vector2):
|
||||||
var relative : Vector2 = point - previous_point
|
var relative : Vector2 = point - previous_point
|
||||||
|
|
||||||
@ -96,27 +108,24 @@ func commit_handle(index: int, restore, cancel: bool = false) -> void:
|
|||||||
func redraw():
|
func redraw():
|
||||||
clear()
|
clear()
|
||||||
|
|
||||||
var node : MeshDataInstance = get_spatial_node()
|
if !_mdr:
|
||||||
|
|
||||||
if !node:
|
|
||||||
return
|
return
|
||||||
|
|
||||||
var mdr : MeshDataResource = node.mesh_data
|
if _mdr.array.size() != ArrayMesh.ARRAY_MAX:
|
||||||
|
|
||||||
if !mdr:
|
|
||||||
return
|
|
||||||
|
|
||||||
if mdr.array.size() != ArrayMesh.ARRAY_MAX:
|
|
||||||
return
|
return
|
||||||
|
|
||||||
var handles_material : SpatialMaterial = get_plugin().get_material("handles", self)
|
var handles_material : SpatialMaterial = get_plugin().get_material("handles", self)
|
||||||
var material = get_plugin().get_material("main", self)
|
var material = get_plugin().get_material("main", self)
|
||||||
|
|
||||||
_mesh_outline.setup(mdr)
|
_mesh_outline.setup(_mdr)
|
||||||
add_lines(_mesh_outline.lines, material, false)
|
add_lines(_mesh_outline.lines, material, false)
|
||||||
|
|
||||||
|
#do this setup somewhere else
|
||||||
if vertices.size() == 0:
|
if vertices.size() == 0:
|
||||||
vertices = mdr.array[ArrayMesh.ARRAY_VERTEX]
|
vertices = _mdr.array[ArrayMesh.ARRAY_VERTEX]
|
||||||
|
|
||||||
|
#displace selected handle verts too on drag, so this code just works.
|
||||||
|
#draw handles though instead ov vertices
|
||||||
|
|
||||||
var vs : PoolVector3Array = PoolVector3Array()
|
var vs : PoolVector3Array = PoolVector3Array()
|
||||||
|
|
||||||
@ -126,23 +135,13 @@ func redraw():
|
|||||||
add_handles(vs, handles_material)
|
add_handles(vs, handles_material)
|
||||||
|
|
||||||
func apply() -> void:
|
func apply() -> void:
|
||||||
var node : MeshDataInstance = get_spatial_node()
|
if !_mdr:
|
||||||
|
|
||||||
if !node:
|
|
||||||
return
|
return
|
||||||
|
|
||||||
var mdr : MeshDataResource = node.mesh_data
|
var arrs : Array = _mdr.array
|
||||||
|
|
||||||
if !mdr:
|
|
||||||
return
|
|
||||||
|
|
||||||
var arrs : Array = mdr.array
|
|
||||||
|
|
||||||
arrs[ArrayMesh.ARRAY_VERTEX] = vertices
|
arrs[ArrayMesh.ARRAY_VERTEX] = vertices
|
||||||
|
_mdr.array = arrs
|
||||||
|
|
||||||
mdr.array = arrs
|
|
||||||
|
|
||||||
node.refresh()
|
|
||||||
|
|
||||||
func forward_spatial_gui_input(index, camera, event):
|
func forward_spatial_gui_input(index, camera, event):
|
||||||
if event is InputEventMouseButton:
|
if event is InputEventMouseButton:
|
||||||
@ -280,5 +279,14 @@ func set_axis_z(on : bool) -> void:
|
|||||||
|
|
||||||
func _notification(what):
|
func _notification(what):
|
||||||
if what == NOTIFICATION_PREDELETE:
|
if what == NOTIFICATION_PREDELETE:
|
||||||
if plugin:
|
if get_plugin():
|
||||||
plugin.unregister_gizmo(self)
|
get_plugin().unregister_gizmo(self)
|
||||||
|
|
||||||
|
func on_mesh_data_resource_changed(mdr : MeshDataResource) -> void:
|
||||||
|
|
||||||
|
#if changed recalc handles
|
||||||
|
#if selection type changed recalc handles aswell
|
||||||
|
#add method recalc handles -> check for type
|
||||||
|
|
||||||
|
_mdr = mdr
|
||||||
|
redraw()
|
||||||
|
@ -1,8 +1,15 @@
|
|||||||
tool
|
tool
|
||||||
extends Object
|
extends Object
|
||||||
|
|
||||||
static func get_handle_vertex_to_vertex_map() -> Array:
|
#you can use MeshUtils.merge_mesh_array(arr) to get optimalized handle points. Just get the vertices from it.
|
||||||
return Array()
|
|
||||||
|
static func get_handle_vertex_to_vertex_map(arrays : Array, handle_points : PoolVector3Array) -> Array:
|
||||||
|
var handle_to_vertex_map : Array
|
||||||
|
|
||||||
|
#foreach handle points
|
||||||
|
#get all equal approx vertex and put it into the map
|
||||||
|
|
||||||
|
return handle_to_vertex_map
|
||||||
|
|
||||||
static func get_handle_edge_to_vertex_map() -> Array:
|
static func get_handle_edge_to_vertex_map() -> Array:
|
||||||
return Array()
|
return Array()
|
||||||
|
Loading…
Reference in New Issue
Block a user