Unity实现3D模型自动分解拆解动画

这篇博客介绍了如何在Unity中实现3D模型的自动分解拆解动画,并提供了一个名为ME_MouseOrbit的脚本示例,该脚本允许用户通过鼠标操作来旋转、缩放模型。在模型动画结束后,如果位置不正确,可能需要调整原始模型的轴。此外,还讨论了如何处理鼠标输入和滚轮缩放,以及如何在鼠标交互时锁定和隐藏光标。

 

目录

效果:​

 代码:

源工程


Unity实现3D模型自动分解拆解动画

效果:

模型动画结束后位置不对的话可能需要修改原模型轴

 代码:

using System;
using UnityEngine;
using System.Collections;

public class ME_MouseOrbit : MonoBehaviour
{
    public GameObject target;
    public float distance = 10.0f;

    public float xSpeed = 250.0f;
    public float ySpeed = 120.0f;

    public float yMinLimit = -20;
    public float yMaxLimit = 80;

    float x = 0.0f;
    float y = 0.0f;

    void Start()
    {
        var angles = transform.eulerAngles;
        x = angles.y;
        y = angles.x;
    }

    float prevDistance;

    void LateUpdate()
    {
        if (distance < 2) distance = 2;
        distance -= Input.GetAxis("Mouse ScrollWheel")*2;
        if (target && (Input.GetMouseButton(0) || Input.GetMouseButton(1)))
        {
            var pos = Input.mousePosition;
            var dpiScale = 1f;
            if (Screen.dpi < 1) dpiScale = 1;
            if (Screen.dpi < 200) dpiScale = 1;
            else dpiScale = Screen.dpi/200f;

            if (pos.x < 380*dpiScale && Screen.height - pos.y < 250*dpiScale) return;

            Cursor.visible = false;
            Cursor.lockState = CursorLockMode.Locked;

            x += Input.GetAxis("Mouse X")*xSpeed*0.02f;
            y -= Input.GetAxis("Mouse Y")*ySpeed*0.02f;

            y = ClampAngle(y, yMinLimit, yMaxLimit);
            var rotation = Quaternion.Euler(y, x, 0);
            var position = rotation* new Vector3(0.0f, 0.0f, -distance) + target.transform.position;
            transform.rotation = rotation;
            transform.position = position;

        }
        else
        {
            Cursor.visible = true;
            Cursor.lockState = CursorLockMode.None;
            //Cursor.visible = true;
            //Screen.lockCursor = false;
        }

        if (Math.Abs(prevDistance - distance) > 0.001f)
        {
            prevDistance = distance;
            var rot = Quaternion.Euler(y, x, 0);
            var po = rot*new Vector3(0.0f, 0.0f, -distance) + target.transform.position;
            transform.rotation = rot;
            transform.position = po;
        }
    }

    static float ClampAngle(float angle, float min, float max)
    {
        if (angle < -360)
            angle += 360;
        if (angle > 360)
            angle -= 360;
        return Mathf.Clamp(angle, min, max);
    }
}

源工程

评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值