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

weightpaint_average.py « scripts « release - git.blender.org/blender.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: 4e8830256b293d217a1dd37061684909006fa98d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
#!BPY
"""
Name: 'Vertex Groups Island Average'
Blender: 243
Group: 'WeightPaint'
Tooltip: 'Average the vertex weights for each connected set of verts'
"""

# -------------------------------------------------------------------------- 
# ***** BEGIN GPL LICENSE BLOCK ***** 
# 
# This program is free software; you can redistribute it and/or 
# modify it under the terms of the GNU General Public License 
# as published by the Free Software Foundation; either version 2 
# of the License, or (at your option) any later version. 
# 
# This program is distributed in the hope that it will be useful, 
# but WITHOUT ANY WARRANTY; without even the implied warranty of 
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the 
# GNU General Public License for more details. 
# 
# You should have received a copy of the GNU General Public License 
# along with this program; if not, write to the Free Software Foundation, 
# Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA. 
# 
# ***** END GPL LICENCE BLOCK ***** 
# --------------------------------------------------------------------------
import Blender
from Blender import Scene, Mesh, Window, sys, Draw
from BPyMesh import meshWeight2List, list2MeshWeight, mesh2linkedFaces

import BPyMessages
import bpy

def faceGroups2VertSets(face_groups):
	'''	Return the face groups as sets of vert indicies	'''
	return [set([v.index for f in fg for v in f]) for fg in face_groups]


def vgroup_average(ob_orig, me, sce, PREF_ALL_VGROUPS=True):
	if not me.getVertGroupNames():
		return
	
	weight_names, weight_list = meshWeight2List(me)
	
	weight_names_len = len(weight_names)
	vgroup_dummy = [0.0] * weight_names_len
	vgroup_range = range(weight_names_len)
	
	if not PREF_ALL_VGROUPS:
		weight_active_index = weight_names.index(me.activeGroup)
	
	for vert_set in faceGroups2VertSets( mesh2linkedFaces(me) ):
		if not vert_set:
			continue
		
		
		if PREF_ALL_VGROUPS:
			# We need to average the vgroups
			collected_group = vgroup_dummy[:]
			for i in vert_set:
				vert_group = weight_list[i]			# get the original weight
				weight_list[i] = collected_group	# replace with the collected group
				
				for j in vgroup_range: # iter through the vgroups
					collected_group[j] += vert_group[j]
			
			for j in vgroup_range:
				collected_group[j] /= len(vert_set)
		else:
			# Active group only
			vert_weight = 0.0
			for i in vert_set:
				vert_weight += weight_list[i][weight_active_index]
			
			vert_weight /= len(vert_set)
			
			for i in vert_set:
				weight_list[i][weight_active_index] = vert_weight
	
	list2MeshWeight(me, weight_names, weight_list)

def main():
	
	# Gets the current scene, there can be many scenes in 1 blend file.
	sce = bpy.data.scenes.active
	
	# Get the active object, there can only ever be 1
	# and the active object is always the editmode object.
	ob_act = sce.objects.active
	
	if not ob_act or ob_act.type != 'Mesh':
		BPyMessages.Error_NoMeshActive()
		return 
	
	# Saves the editmode state and go's out of 
	# editmode if its enabled, we cant make
	# changes to the mesh data while in editmode.
	is_editmode = Window.EditMode()
	Window.EditMode(0)
	
	PREF_ALL_VGROUPS = Draw.PupMenu("All Groups?%t|All Groups%x1|Active Group Only%x0")
	if PREF_ALL_VGROUPS==-1:
		return
	
	Window.WaitCursor(1)
	me = ob_act.getData(mesh=1) # old NMesh api is default
	t = sys.time()
	
	# Run the mesh editing function
	vgroup_average(ob_act, me, sce, PREF_ALL_VGROUPS)
	
	# Timing the script is a good way to be aware on any speed hits when scripting
	print 'Average VGroups in %.2f seconds' % (sys.time()-t)
	Window.WaitCursor(0)
	if is_editmode: Window.EditMode(1)
	
	
# This lets you can import the script without running it
if __name__ == '__main__':
	main()