如何设置多个对象的移动和旋转的动画?

2024-06-10 09:19:21 发布

您现在位置:Python中文网/ 问答频道 /正文

我有一架由多个物体组成的无人机。问题是,当我旋转无人机并将其移动到另一个点时,它的形状会松动(撕成碎片),无人机的每个部分都会与主体断开连接。我如何旋转和移动无人机而不失去它的形状

我试着让无人机的身体成为所有碎片的母体。当我只旋转或移动身体的时候它就起作用了。 config

import math
import bpy
import mathutils
import subprocess as sp
from math import sqrt, degrees, acos, pow

sp.call('cls', shell=True)

drone_objects_names = ['Cube.008', 'Cylinder.007', 'Cube.007', 'Cube.006', 'Sphere.005', 'Sphere.004', 'Cylinder.008',
                       'Sphere.003', 'Cylinder.006', 'Cube.005', 'Cube.004', 'Sphere.002', 'Cylinder.005', 'Sphere.001',
                       'Cylinder.004', 'Sphere', 'Cylinder.003', 'Cube.003', 'Cylinder.002', 'Cylinder.001', 'Cube.002',
                       'Cube.001', 'Cylinder', 'Cube']

X = 10
Y = 10
Z = 5

frame_num = 0
teta = 0

factor = 0.97


def set_keyframe():
    for object_name in drone_objects_names:
        bpy.data.objects[object_name].keyframe_insert(data_path="location", index=-1)


def send_drone_to_center():
    move_drone(-bpy.data.objects['Cylinder.003'].location)


def select_drone():
    for object_name in drone_objects_names:
        bpy.data.objects[object_name].select_set(True)


def move_drone(v):
    bpy.ops.transform.translate(value=v)


def angle_between_z(vc, uc):
    nominator = vc[0] * uc[0] + vc[2] * uc[2]
    denominator = sqrt(pow(vc[0], 2) + pow(vc[2], 2)) * sqrt(pow(uc[0], 2) + pow(uc[2], 2))
    return acos(nominator / denominator)


def angle_between_y(vc, uc):
    nominator = vc[0] * uc[0] + vc[2] * uc[2]
    denominator = sqrt(pow(vc[0], 2) + pow(vc[2], 2)) * sqrt(pow(uc[0], 2) + pow(uc[2], 2))
    return acos(nominator / denominator)


def do_step():
    global factor, teta, frame_num, X, Y, Z
    factor = 0.97

    x_new = X * math.cos(math.radians(teta))
    y_new = Y * math.sin(math.radians(teta))

    bpy.context.scene.frame_set(frame_num)

    move_drone(-bpy.data.objects['Cylinder.003'].location)
    move_drone((x_new, y_new, Z * factor))

    angle = angle_between_z((x_new, y_new, Z * factor), (X, Y, Z))
    bpy.data.objects['Cylinder.003'].rotate_euler[2] = angle

    set_keyframe()

    frame_num += 3

    X *= factor
    Y *= factor
    Z *= factor
    teta += 10


select_drone()
send_drone_to_center()
move_drone((X, Y, Z))

while math.sqrt(X * X + Y * Y + Z * Z) > 1:
    do_step()
    e = bpy.data.objects['Cylinder.003'].location
    print(X, Y, e[0], e[2])

bpy.context.scene.frame_end = frame_num

我希望无人机能在不失去形状的情况下,处于参照物的中心。。。 drone lose it's shape

我在这个项目中使用的无人机(如果你想试试……):drone


Tags: importnewdataobjectsdefmathsqrtframe
1条回答
网友
1楼 · 发布于 2024-06-10 09:19:21

你的脚本对无人机的每个部分都应用了相同的移动。作为子对象,对象的位置是相对于父对象的,通过更改子对象的位置,它将从父对象移开,父对象也将移开

删除父对象,或者只设置父对象的动画

相关问题 更多 >