edits to the bone copy metarig type from Cessen, pointcache warning fix
[blender.git] / release / scripts / modules / rigify / copy.py
1 # ##### BEGIN GPL LICENSE BLOCK #####
2 #
3 #  This program is free software; you can redistribute it and/or
4 #  modify it under the terms of the GNU General Public License
5 #  as published by the Free Software Foundation; either version 2
6 #  of the License, or (at your option) any later version.
7 #
8 #  This program is distributed in the hope that it will be useful,
9 #  but WITHOUT ANY WARRANTY; without even the implied warranty of
10 #  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
11 #  GNU General Public License for more details.
12 #
13 #  You should have received a copy of the GNU General Public License
14 #  along with this program; if not, write to the Free Software Foundation,
15 #  Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
16 #
17 # ##### END GPL LICENSE BLOCK #####
18
19 # <pep8 compliant>
20
21 import bpy
22 from rigify import get_layer_dict
23 from rigify_utils import bone_class_instance
24
25 METARIG_NAMES = ("cpy",)
26
27
28 def metarig_template():
29     # generated by rigify.write_meta_rig
30     bpy.ops.object.mode_set(mode='EDIT')
31     obj = bpy.context.active_object
32     arm = obj.data
33     bone = arm.edit_bones.new('Bone')
34     bone.head[:] = 0.0000, 0.0000, 0.0000
35     bone.tail[:] = 0.0000, 0.0000, 1.0000
36     bone.roll = 0.0000
37     bone.connected = False
38
39     bpy.ops.object.mode_set(mode='OBJECT')
40     pbone = obj.pose.bones['Bone']
41     pbone['type'] = 'copy'
42
43
44 def metarig_definition(obj, orig_bone_name):
45     return [orig_bone_name]
46
47
48 def main(obj, bone_definition, base_names, options):
49     arm = obj.data
50     mt = bone_class_instance(obj, METARIG_NAMES)
51     mt.cpy = bone_definition[0]
52     mt.update()
53     cp = bone_class_instance(obj, ["cpy"])
54     cp.cpy_e = copy_bone_simple(arm, mt.cpy, base_names[mt.cpy], parent=True)
55     cp.cpy = cp.cpy_e.name
56     
57     bpy.ops.object.mode_set(mode='OBJECT')
58
59     cp.update()
60     mt.update()
61
62     if not cp.cpy_b.connected:
63         con = cp.cpy_p.constraints.new('COPY_LOCATION')
64         con.target = obj
65         con.subtarget = mt.cpy
66
67     con = cp.cpy_p.constraints.new('COPY_ROTATION')
68     con.target = obj
69     con.subtarget = cp.cpy
70
71     con = mt.cpy_p.constraints.new('COPY_SCALE')
72     con.target = obj
73     con.subtarget = cp.cpy
74     
75     # Rotation mode and axis locks
76     cp.cpy_p.rotation_mode = mt.cpy_p.rotation_mode
77     cp.cpy_p.lock_location = tuple(mt.cpy_p.lock_location)
78     cp.cpy_p.lock_rotations_4d = mt.cpy_p.lock_rotations_4d
79     cp.cpy_p.lock_rotation = tuple(mt.cpy_p.lock_rotation)
80     cp.cpy_p.lock_rotation_w = mt.cpy_p.lock_rotation_w
81     cp.cpy_p.lock_scale = tuple(mt.cpy_p.lock_scale)
82
83     # setup layers last
84     layers = get_layer_dict(options)
85     cp.cpy_b.layer = layers["main"]
86
87     return [mt.cpy]