當前位置: 首頁>>代碼示例>>Python>>正文


Python Quaternion.normalize方法代碼示例

本文整理匯總了Python中mathutils.Quaternion.normalize方法的典型用法代碼示例。如果您正苦於以下問題:Python Quaternion.normalize方法的具體用法?Python Quaternion.normalize怎麽用?Python Quaternion.normalize使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在mathutils.Quaternion的用法示例。


在下文中一共展示了Quaternion.normalize方法的5個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: process

# 需要導入模塊: from mathutils import Quaternion [as 別名]
# 或者: from mathutils.Quaternion import normalize [as 別名]
    def process(self):
        if not self.outputs['Quaternions'].is_linked:
            return

        inputs = self.inputs

        quaternionList = []

        if self.mode == "WXYZ":
            I = [inputs[n].sv_get()[0] for n in "WXYZ"]
            params = match_long_repeat(I)
            for wxyz in zip(*params):
                q = Quaternion(wxyz)
                if self.normalize:
                    q.normalize()
                quaternionList.append(q)

        elif self.mode == "SCALARVECTOR":
            I = [inputs[n].sv_get()[0] for n in ["Scalar", "Vector"]]
            params = match_long_repeat(I)
            for scalar, vector in zip(*params):
                q = Quaternion([scalar, *vector])
                if self.normalize:
                    q.normalize()
                quaternionList.append(q)

        elif self.mode == "EULER":
            I = [inputs["Angle " + n].sv_get()[0] for n in "XYZ"]
            params = match_long_repeat(I)
            au = angleConversion[self.angleUnits]
            for angleX, angleY, angleZ in zip(*params):
                euler = Euler((angleX * au, angleY * au, angleZ * au), self.eulerOrder)
                q = euler.to_quaternion()
                if self.normalize:
                    q.normalize()
                quaternionList.append(q)

        elif self.mode == "AXISANGLE":
            I = [inputs[n].sv_get()[0] for n in ["Axis", "Angle"]]
            params = match_long_repeat(I)
            au = angleConversion[self.angleUnits]
            for axis, angle in zip(*params):
                q = Quaternion(axis, angle * au)
                if self.normalize:
                    q.normalize()
                quaternionList.append(q)

        elif self.mode == "MATRIX":
            input_M = inputs["Matrix"].sv_get(default=idMat)
            for m in input_M:
                q = Matrix(m).to_quaternion()
                if self.normalize:
                    q.normalize()
                quaternionList.append(q)

        self.outputs['Quaternions'].sv_set([quaternionList])
開發者ID:nortikin,項目名稱:sverchok,代碼行數:58,代碼來源:quaternion_in.py

示例2: _arc_segment

# 需要導入模塊: from mathutils import Quaternion [as 別名]
# 或者: from mathutils.Quaternion import normalize [as 別名]
def _arc_segment(v_1, v_2):
	ELorigin = bpy.context.scene.objects['ELorigin']
	ELground = bpy.context.scene.objects['ELground']

	v = v_2 - v_1
	d = v.length

	ELorigin.location = Vector((0, 0, 0))
	ELground.location = Vector((0, 0, -d))

	v_L = ELground.location - ELorigin.location

	q = Quaternion()
	c = Vector.cross(v_L, v)
	q.x = c.x
	q.y = c.y
	q.z = c.z
	q.w = sqrt((v_L.length ** 2) * (v.length ** 2)) + \
		Vector.dot(v_L, v)
	q.normalize()
	euler = q.to_euler()

	bpy.ops.object.runfslg_operator()

	laALL = bpy.context.scene.objects['laALL']
	laALL.name = 'lARC'
	laALL.rotation_euler = euler
	laALL.location = v_1

	bpy.context.active_object.select = False
	laALL.select = True
	bpy.ops.object.transform_apply(location=True, rotation=True, scale=True)
	laALL.select = False
	bpy.context.active_object.select = True	

	return laALL
開發者ID:sadaszewski,項目名稱:blender-addons,代碼行數:38,代碼來源:lightning_arcs.py

示例3: drawBone2

# 需要導入模塊: from mathutils import Quaternion [as 別名]
# 或者: from mathutils.Quaternion import normalize [as 別名]
def drawBone2(p1, p2, radiuses, material):
  length = dist(p1,p2)
  print('length :',length)
  v = Vector(diffv(p1, p2))
  up = Vector((0,0,1))
  if v!=-up:
    rot = up.rotation_difference(v)
  else:
    rot = Quaternion((1,0,0),math.pi)
  s1 = drawEllipsoid((0,0,-0.5*length),radiuses,material)
  s2 = drawEllipsoid((0,0,0.5*length),radiuses,material)
  c1 = drawCylinder(zero,radiuses,length,materials.blue)
  s1.select = True
  s2.select = True
  c1.select = True
  #bpy.ops.transform.translate(value=(0,0,length/2))
  #bpy.ops.object.editmode_toggle()
  bpy.ops.transform.rotate(value=rot.angle, axis=rot.axis)
  #bpy.ops.object.editmode_toggle()
  #bpy.ops.transform.translate(value=Vector((0,0,-0.5*length))*rot.to_matrix())
  rot.normalize();
  bpy.ops.transform.translate(value=Vector((0,0,0.5*length))*rot.to_matrix())
  bpy.ops.transform.translate(value=p1)
  return (s1,s2,c1)
開發者ID:willcode4fun,項目名稱:scriptools,代碼行數:26,代碼來源:character.py

示例4: transform_rotation

# 需要導入模塊: from mathutils import Quaternion [as 別名]
# 或者: from mathutils.Quaternion import normalize [as 別名]
def transform_rotation(rotation: Quaternion, transform: Matrix = Matrix.Identity(4)) -> Quaternion:
    """Transform rotation."""
    rotation.normalize()
    m = rotation.to_matrix().to_4x4()
    m = multiply(transform, m)
    return m.to_quaternion()
開發者ID:sambler,項目名稱:myblenderaddons,代碼行數:8,代碼來源:gltf2_blender_math.py

示例5: save

# 需要導入模塊: from mathutils import Quaternion [as 別名]
# 或者: from mathutils.Quaternion import normalize [as 別名]
def save(operator, context, filepath=""):
    bpy.ops.object.mode_set(mode='OBJECT')

    poseLib = None
    armature = None
    for object in bpy.data.objects:
        if object.type == 'ARMATURE':
            poseLib = object.pose_library
            armature = object.data
            break
    if poseLib == None or armature == None:
        raise NameError("Cannot export Pose Library %s, there is no armatures" % filepath)
    
    
    numPoses = len(poseLib.groups[0].channels[4].keyframe_points)
    numBones = len(poseLib.groups)
    poseArray = []
    nameArray = []
    
    print("Exporting")
    
    oglBoneArray = []
    oglBoneDirectionArray = []
    
    startNodes = []
    for i in range(0, len(armature.bones)):
        bone = armature.bones[i]
        if bone.parent == None:
            dupIndex = -1
            for j in range(0, len(startNodes)):
                if bone.head[:] == startNodes[j][:]:
                    dupIndex = j
                    break
            if dupIndex == -1:
                baseNode = bone.head_local
                startNodes.append((baseNode.x, baseNode.y, baseNode.z))
                oglBoneArray.append(-1)
        oglBoneArray.append(i)
        boneDirection = bone.tail_local - bone.head_local
        oglBoneDirectionArray.append(boneDirection)
    
    for i in range(0, numPoses):
        nameArray.append(poseLib.pose_markers[i].name)
        boneArray = []
        for j in range(0, len(oglBoneArray)):
            index = oglBoneArray[j]
            q = Quaternion()
            if index == -1:
                q = Quaternion([1, 0, 0, 0])
            else:
                quat = Quaternion([1, 0, 0, 0])
                for k in range(0, 4):
                    quat[k] = poseLib.groups[index].channels[k + 3].keyframe_points[i].co.y
                axisVector = Vector([0, 1, 0])
                boneVector = oglBoneDirectionArray[index]
                quatBetween = getQuatBetweenVectors(boneVector, axisVector)
                q = quatBetween.inverted() * quat * quatBetween
                q.normalize()
            boneArray.append(tuple([q.w, q.x, q.z, -q.y]))
        poseArray.append(boneArray)
    
    print(filepath)
    file = open(filepath, 'w')
    fw = file.write
    
    fw("poslib\n")
    fw("%d %d\n" % (numPoses, len(oglBoneArray)))
    for i in range(0, numPoses):
        fw("n " + nameArray[i] + '\n')
        for j in range(0, len(oglBoneArray)):
            q = poseArray[i][j]
            fw("q %f %f %f %f\n" % (q[0], q[1], q[2], q[3]))
        fw('f\n')
        
    file.close()
    
    print("Finished Exporting")
    
    return {'FINISHED'}
開發者ID:tschicke,項目名稱:Python-PoseLib-Exporter,代碼行數:81,代碼來源:export_poslib.py


注:本文中的mathutils.Quaternion.normalize方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。