script for automating pep8 checks.
[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_utils import copy_bone_simple, get_side_name, bone_class_instance
23 from rna_prop_ui import rna_idprop_ui_prop_get
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 = mt.copy(to_fmt="%s_cpy")
54     bpy.ops.object.mode_set(mode='OBJECT')
55
56     cp.update()
57     mt.update()
58
59     con = cp.cpy_p.constraints.new('COPY_ROTATION')
60     con.target = obj
61     con.subtarget = mt.cpy
62
63     con = cp.cpy_p.constraints.new('COPY_LOCATION')
64     con.target = obj
65     con.subtarget = mt.cpy
66
67     return [mt.cpy]