mirror of
https://github.com/Relintai/broken_seals.git
synced 2025-01-22 02:17:18 +01:00
An another shot at implementing the apply_seams action. Still doesn't work, need to think more about the algorithm.
This commit is contained in:
parent
04e95a0814
commit
bee904f077
@ -859,6 +859,14 @@ static func is_matching_seam(i0 : int, i1: int, si0 : int, si1: int) -> bool:
|
|||||||
|
|
||||||
return (i0 == si0) && (i1 == si1)
|
return (i0 == si0) && (i1 == si1)
|
||||||
|
|
||||||
|
static func pool_int_arr_contains(arr : PoolIntArray, val : int) -> bool:
|
||||||
|
for a in arr:
|
||||||
|
if a == val:
|
||||||
|
return true
|
||||||
|
|
||||||
|
return false
|
||||||
|
|
||||||
|
|
||||||
static func apply_seam(mdr : MeshDataResource) -> void:
|
static func apply_seam(mdr : MeshDataResource) -> void:
|
||||||
var points : PoolVector3Array = PoolVector3Array()
|
var points : PoolVector3Array = PoolVector3Array()
|
||||||
|
|
||||||
@ -879,6 +887,82 @@ static func apply_seam(mdr : MeshDataResource) -> void:
|
|||||||
var duplicate_verts_indices : PoolIntArray = PoolIntArray()
|
var duplicate_verts_indices : PoolIntArray = PoolIntArray()
|
||||||
var new_vert_size : int = vertices.size()
|
var new_vert_size : int = vertices.size()
|
||||||
|
|
||||||
|
for i in range(vertices.size()):
|
||||||
|
# first check if vertex is a part of at least 2 edge seams
|
||||||
|
var test_seam_count : int = 0
|
||||||
|
for s in seams:
|
||||||
|
if s == i:
|
||||||
|
test_seam_count += 1
|
||||||
|
|
||||||
|
if test_seam_count >= 2:
|
||||||
|
break
|
||||||
|
|
||||||
|
if test_seam_count < 2:
|
||||||
|
continue
|
||||||
|
|
||||||
|
var already_split_indices : PoolIntArray = PoolIntArray()
|
||||||
|
var already_split_indices_map : Dictionary = Dictionary()
|
||||||
|
var first : bool = true
|
||||||
|
for j in range(indices.size()):
|
||||||
|
var i0 : int = indices[j]
|
||||||
|
|
||||||
|
if i0 != i:
|
||||||
|
continue
|
||||||
|
|
||||||
|
#if first:
|
||||||
|
# Only split away the subsequent verts
|
||||||
|
# first = false
|
||||||
|
# continue
|
||||||
|
|
||||||
|
var tri_j_offset : int = j % 3
|
||||||
|
var tri_start_index : int = j - tri_j_offset
|
||||||
|
|
||||||
|
var i1 : int = indices[tri_start_index + ((tri_j_offset + 1) % 3)]
|
||||||
|
|
||||||
|
for stind in range(0, seams.size(), 2):
|
||||||
|
var si0 : int = seams[stind]
|
||||||
|
var si1 : int = seams[stind + 1]
|
||||||
|
if is_matching_seam(i0, i1, si0, si1):
|
||||||
|
|
||||||
|
if pool_int_arr_contains(already_split_indices, i0):
|
||||||
|
indices[j] = already_split_indices_map[i0]
|
||||||
|
break
|
||||||
|
|
||||||
|
duplicate_verts_indices.push_back(i0)
|
||||||
|
indices[j] = new_vert_size
|
||||||
|
|
||||||
|
already_split_indices.push_back(i0)
|
||||||
|
already_split_indices_map[i0] = new_vert_size
|
||||||
|
|
||||||
|
new_vert_size += 1
|
||||||
|
break
|
||||||
|
|
||||||
|
arrays[ArrayMesh.ARRAY_INDEX] = indices
|
||||||
|
#mdr.array = arrays
|
||||||
|
|
||||||
|
mdr.array = seam_apply_duplicate_vertices(arrays, duplicate_verts_indices)
|
||||||
|
|
||||||
|
|
||||||
|
static func apply_seam_old(mdr : MeshDataResource) -> void:
|
||||||
|
var points : PoolVector3Array = PoolVector3Array()
|
||||||
|
|
||||||
|
var arrays : Array = mdr.get_array()
|
||||||
|
|
||||||
|
if arrays.size() != ArrayMesh.ARRAY_MAX:
|
||||||
|
return
|
||||||
|
|
||||||
|
if arrays[ArrayMesh.ARRAY_VERTEX] == null:
|
||||||
|
return
|
||||||
|
|
||||||
|
var vertices : PoolVector3Array = arrays[ArrayMesh.ARRAY_VERTEX]
|
||||||
|
var indices : PoolIntArray = arrays[ArrayMesh.ARRAY_INDEX]
|
||||||
|
|
||||||
|
var seams : PoolIntArray = mdr.seams
|
||||||
|
|
||||||
|
# Duplication happens later, as it requires lots of logic
|
||||||
|
var duplicate_verts_indices : PoolIntArray = PoolIntArray()
|
||||||
|
var new_vert_size : int = vertices.size()
|
||||||
|
|
||||||
for i in range(0, seams.size(), 2):
|
for i in range(0, seams.size(), 2):
|
||||||
var si0 : int = seams[i]
|
var si0 : int = seams[i]
|
||||||
var si1 : int = seams[i + 1]
|
var si1 : int = seams[i + 1]
|
||||||
|
Loading…
Reference in New Issue
Block a user