[Unity3d]鼠标旋转缩放拖动模型

简介: 实现鼠标旋转拖动缩放模型,非常不错的代码: using UnityEngine;using System.Collections;public class MouseControl : MonoBehaviour{ //目标物体 ...

实现鼠标旋转拖动缩放模型,非常不错的代码:

using UnityEngine;
using System.Collections;

public class MouseControl : 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()
    {
        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);
    }
}




相关文章
|
自然语言处理 达摩院 搜索推荐
阿里推出文本搜索排序新技术,登顶国际权威NLP榜单MS MARCO
3月28日,阿里巴巴团队以0.450的得分,刷新了国际权威自然语言处理(NLP)榜单MS MARCO短文本检索排序任务历史纪录。据悉,搜索团队最新研发的文本检索及排序技术已通过阿里云智能开放搜索OpenSearch产品对外输出。
1267 0
阿里推出文本搜索排序新技术,登顶国际权威NLP榜单MS MARCO
|
存储 编解码 弹性计算
云存储-对象存储的介绍和使用场景 | 学习笔记
快速学习云存储-对象存储的介绍和使用场景
云存储-对象存储的介绍和使用场景 | 学习笔记
|
SQL 网络协议 程序员
【Sql Server】2019设置远程访问
本地电脑安装的ssms连接到服务器的ssms
1421 0
【Sql Server】2019设置远程访问
|
存储 域名解析 Prometheus
K8S原理剖析:Pod、工作负载与服务
K8S原理剖析:Pod、工作负载与服务
919 0
K8S原理剖析:Pod、工作负载与服务
|
IDE Java 程序员
如何使用Visual Studio Code进行Java编程
任何一个程序员都有自己喜爱的编辑器、工具、开发利器,有这样一群人,对于vim这种上古神器难以...
1223 0
|
云安全 存储 运维
想转行加入云计算行业的同学看这里
近年来,云计算市场前景火爆,越来越多的企业将业务迁移到云上,云计算人才也成为企业高薪招聘的对象。有人看到这一点,就想转行加入云计算行业。
610 0
想转行加入云计算行业的同学看这里
|
人工智能 运维 监控
新发布:免费的防疫数据分析与可视化平台---阿里云新冠病毒疫情分析App
免费的防疫数据分析与可视化平台能力---阿里云新冠病毒疫情分析App 新冠病毒疫情分析App是基于阿里云日志服务中台,提供的一站式的数据处理可视化分析系统。借助它,可以在全球范围内了解各省份、市区的全面一手疫情信息和防疫新闻动态。目前该能力全面开放给政府、社区、第三方平台和开放者进行广泛应用。
4588 0
|
存储 分布式计算 数据挖掘
HDF5文件的读取与储存| 学习笔记
快速学习 HDF5文件的读取与储存
1753 0
浙政钉的扫码登录
有关浙政钉的扫码登录
2312 0

热门文章

最新文章