unity3d鼠标拖拽模型,旋转模型

简介: 直接挂载到模型上using UnityEngine;using System.Collections;public class OnDrag : MonoBehaviour{ //目标物体 public Transform ...

直接挂载到模型上

using UnityEngine;
using System.Collections;

public class OnDrag : MonoBehaviour
{

    //目标物体
    public Transform target;
    private int MouseWheelSensitivity = 1; //放大倍数的快慢
    private int MouseZoomMin = 1; //最小倍数
    private int MouseZoomMax = 5; //最大倍数
    //默认距离
    private float normalDistance = 3;


    private Vector3 normalized;

    //拖拽的移动速度
    private float xSpeed = 250.0f;
    private float ySpeed = 120.0f;

    //拖拽的高度限制
    private int yMinLimit = -20;
    private int yMaxLimit = 80;

    //角度
    private float x = 0.0f;
    private float y = 0.0f;

    //记录目标物体的坐标
    private Vector3 screenPoint;
    private Vector3 offset;

    //围绕x旋转30°
    private Quaternion rotation = Quaternion.Euler(new Vector3(30f, 0f, 0f));

    //目标的3D坐标
    private Vector3 CameraTarget;

    //打印欧拉角:绕各个轴旋转的角度,顺时针为正方向
    public void Awake()
    {
        target = transform;
        print(transform.eulerAngles.x);
        print(transform.eulerAngles.y);
        print(transform.eulerAngles.z);
    }

    void Start()
    {
        //找到目标飞机的3d坐标
        CameraTarget = target.position;

        //目标飞机的z-3,距离摄像机更近了
        float z = target.transform.position.z - normalDistance;
        //给当前相机给定位,现在的3D坐标乘以30°
        transform.position = rotation * new Vector3(transform.position.x, transform.position.y, z);

        //将视角转向物体
        transform.LookAt(target);

        //记录各个轴偏离的角度
        var angles = transform.eulerAngles;
        x = angles.y;
        y = angles.x;
    }

    void OnGUI()
    {
        GUI.Label(new Rect(10, 10, 300, 30), "左击:旋转;滚轮:缩放;中击:拖拽");
    }

    void Update()
    {
        //如果左击了,旋转
        if (Input.GetMouseButton(0))
        {
            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, -normalDistance) + CameraTarget;

            transform.rotation = rotation;
            transform.position = position;

        }
        //滚轮缩放
        else if (Input.GetAxis("Mouse ScrollWheel") != 0)
        {
            //摄像机3d坐标-物体的3d坐标
            normalized = (transform.position - CameraTarget).normalized;

            if (normalDistance >= MouseZoomMin && normalDistance <= MouseZoomMax)
            {
                normalDistance -= Input.GetAxis("Mouse ScrollWheel") * MouseWheelSensitivity;
            }
            if (normalDistance < MouseZoomMin)
            {
                normalDistance = MouseZoomMin;
            }
            if (normalDistance > MouseZoomMax)
            {
                normalDistance = MouseZoomMax;
            }
            //改变摄像机的远近
            transform.position = normalized * normalDistance;
        }
        //案件按下 记录鼠标的
        else if (Input.GetMouseButtonDown(2))
        {
            //将目标物体的坐标转化成平面坐标
            screenPoint = Camera.main.WorldToScreenPoint(target.transform.position);
            //计算鼠标的3维坐标跟物体的3维坐标的差值
            offset = target.transform.position - Camera.main.ScreenToWorldPoint(new Vector3(Input.mousePosition.x, Input.mousePosition.y, screenPoint.z));
        }

        //中键拖拽,改变飞机的坐标,每帧调用
        if (Input.GetMouseButton(2))
        {
            //鼠标的平面坐标
            Vector3 curScreenPoint = new Vector3(Input.mousePosition.x, Input.mousePosition.y, screenPoint.z);
            //鼠标转移的3d空间坐标值
            Vector3 curPosition = Camera.main.ScreenToWorldPoint(curScreenPoint) + offset;
            //改变鼠标的3D空间坐标
            target.transform.position = curPosition;
        }
        //朝向,每动一帧都要改变朝向
        transform.LookAt(CameraTarget);
    }

    //控制旋转的角度,如果旋转的角度大于360或者小于360都要加上或者减去对应的角度
    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);
    }
}
相关文章
|
3月前
|
图形学
Unity精华☀️一、从旋转到万向锁之:Unity的旋转
Unity精华☀️一、从旋转到万向锁之:Unity的旋转
|
3月前
|
图形学
小功能⭐️Unity动态更换天空盒、旋转天空盒
小功能⭐️Unity动态更换天空盒、旋转天空盒
|
5月前
|
存储 图形学
【unity小技巧】unity中导入下载的3D模型及albedo/baseColor、normal 、AO/Occlus、metallic、roughness贴图纹理设置
【unity小技巧】unity中导入下载的3D模型及albedo/baseColor、normal 、AO/Occlus、metallic、roughness贴图纹理设置
98 0
|
5月前
|
图形学
初识Unity——基本模型、场景操作、世界坐标系和局部坐标系
初识Unity——基本模型、场景操作、世界坐标系和局部坐标系
146 1
|
存储 图形学
浅谈Unity之模型裁剪shader
Unity之模型裁剪shader
|
图形学
浅谈Unity之ShaderGraph-模型膨胀流动
Unity之ShaderGraph-模型膨胀流动
|
图形学
【Unity实战系列】如何把你的二次元老婆/老公导入Unity进行二创并且进行二次元渲染?(附模型网站分享)
【Unity实战系列】如何把你的二次元老婆/老公导入Unity进行二创并且进行二次元渲染?(附模型网站分享)
526 0
|
3月前
|
图形学 C#
超实用!深度解析Unity引擎,手把手教你从零开始构建精美的2D平面冒险游戏,涵盖资源导入、角色控制与动画、碰撞检测等核心技巧,打造沉浸式游戏体验完全指南
【8月更文挑战第31天】本文是 Unity 2D 游戏开发的全面指南,手把手教你从零开始构建精美的平面冒险游戏。首先,通过 Unity Hub 创建 2D 项目并导入游戏资源。接着,编写 `PlayerController` 脚本来实现角色移动,并添加动画以增强视觉效果。最后,通过 Collider 2D 组件实现碰撞检测等游戏机制。每一步均展示 Unity 在 2D 游戏开发中的强大功能。
172 6
|
2月前
|
测试技术 C# 图形学
掌握Unity调试与测试的终极指南:从内置调试工具到自动化测试框架,全方位保障游戏品质不踩坑,打造流畅游戏体验的必备技能大揭秘!
【9月更文挑战第1天】在开发游戏时,Unity 引擎让创意变为现实。但软件开发中难免遇到 Bug,若不解决,将严重影响用户体验。调试与测试成为确保游戏质量的最后一道防线。本文介绍如何利用 Unity 的调试工具高效排查问题,并通过 Profiler 分析性能瓶颈。此外,Unity Test Framework 支持自动化测试,提高开发效率。结合单元测试与集成测试,确保游戏逻辑正确无误。对于在线游戏,还需进行压力测试以验证服务器稳定性。总之,调试与测试贯穿游戏开发全流程,确保最终作品既好玩又稳定。
98 4
|
3月前
|
图形学 缓存 算法
掌握这五大绝招,让您的Unity游戏瞬间加载完毕,从此告别漫长等待,大幅提升玩家首次体验的满意度与留存率!
【8月更文挑战第31天】游戏的加载时间是影响玩家初次体验的关键因素,特别是在移动设备上。本文介绍了几种常见的Unity游戏加载优化方法,包括资源的预加载与异步加载、使用AssetBundles管理动态资源、纹理和模型优化、合理利用缓存系统以及脚本优化。通过具体示例代码展示了如何实现异步加载场景,并提出了针对不同资源的优化策略。综合运用这些技术可以显著缩短加载时间,提升玩家满意度。
136 5