Unity 3D还原Scene场景、市面多数游戏视角高度自定义、第三人称视角分离功能:平移、拖动、看向中心等

简介: Unity视角的高度自定义本文提供全流程,中文翻译。 Chinar 坚持将简单的生活方式,带给世人!(拥有更好的阅读体验 —— 高分辨率用户请根据需求调整网页缩放比例) Chinar —— 心...

Unity视角的高度自定义


本文提供全流程,中文翻译。

Chinar 坚持将简单的生活方式,带给世人!

(拥有更好的阅读体验 —— 高分辨率用户请根据需求调整网页缩放比例)



Chinar —— 心分享、心创新!

助力快速完成视角的自定义、逐个功能分离

为新手节省宝贵的时间,避免采坑!


Chinar 教程效果:
这里写图片描述
同一个脚本,同时实现拖动视角平移、竖轴限定俯仰角
这里写图片描述



全文高清图片,点击即可放大观看 (很多人竟然不知道)


1

ChinarCamera —— 相机视角专用脚本


Unity 3D第三人称视角、视野竖轴限定角度,用途广泛!

之前做的第三人称视角,如果还不能满足你的要求

那么这个脚本的分离、封装,且高度自定义性,应该足够满足市面上大多数游戏对视角的要求

Chinar 已经对 脚本 进行了极为简化的封装
举个栗子黑白88

using UnityEngine;
using UnityEngine.EventSystems;


/// <summary>
/// 枚举按钮操作类型
/// </summary>
public enum ButtonType
{
    Up,
    Down,
    Left,
    Right,
    Near,
    Far,
    Null
}


/// <summary>
/// Chinar相机专用脚本:挂载到相机上
/// </summary>
public class ChinarCamera : MonoBehaviour
{
    public        Transform  pivot;                            // 被跟踪的对象:当前无用:留作扩展
    public        Vector3    pivotOffset    = Vector3.zero;    // 与目标的偏移量
    public        float      distance       = 15.0f;           // 距目标距离(使用变焦)
    public        float      minDistance    = 2f;              //最小距离
    public        float      maxDistance    = 15f;             //最大距离
    public        float      zoomSpeed      = 1f;              //速度倍率
    public        float      NFzoomSpeed    = 20f;             //远近速度倍率
    public        float      xSpeed         = 250.0f;          //x速度
    public        float      ySpeed         = 120.0f;          //y速度
    public        bool       allowYTilt     = true;            //允许Y轴倾斜
    public        float      yMinLimit      = -90f;            //相机向下最大角度
    public        float      yMaxLimit      = 90f;             //相机向上最大角度
    private       float      x              = 0.0f;            //x变量
    private       float      y              = 0.0f;            //y变量
    private       float      targetX        = 0f;              //目标x
    private       float      targetY        = 0f;              //目标y
    private       float      targetDistance = 0f;              //目标距离
    private       float      xVelocity      = 1f;              //x速度
    private       float      yVelocity      = 1f;              //y速度
    private       float      zoomVelocity   = 1f;              //速度倍率
    public        float      testSpeed      = 30f;             //用于外部动态测试相机速度
    public        ButtonType buttonType     = ButtonType.Null; //默认为空操作
    public static bool       isStart        = true;            //默认第一次开始,另外通过控制此变量可重置视角
    private       Main       main;


    void Start()
    {
        if (GameObject.Find("GlobalScripts"))
        {
            main = GameObject.Find("GlobalScripts").GetComponent<Main>();
        }

        var angles     = transform.eulerAngles;
        targetX        = x = angles.x;
        targetY        = y = ClampAngle(angles.y, yMinLimit, yMaxLimit);
        targetDistance = distance;
        isStart        = true; //默认第一次启动
    }


    /// <summary>
    /// 相机的控制写在Late比较好
    /// </summary>
    void LateUpdate()
    {
        if (GameObject.Find("GlobalScripts"))
        {
            if (main.userOp == OperationState.HandMove) 
            {
                if (Input.GetMouseButtonUp(0))
                {
                    pivot.SetParent(null);
                }

                if (Input.GetMouseButton(0) && !EventSystem.current.IsPointerOverGameObject())
                {
                    pivot.SetParent(Camera.main.transform);

                    float x;
                    float y;
                    x = Input.GetAxis("Mouse X");
                    y = Input.GetAxis("Mouse Y");
                    transform.Translate(new Vector3(-x, -y, 0) * Time.deltaTime * 10);
                    return;
                }
            }
            else
            {
                pivot.parent = null;
            }
        }


        if (!EventSystem.current.IsPointerOverGameObject())
        {
            GunLun();
            MouseControlCamera();
        }

        switch (buttonType)
        {
            case ButtonType.Up:
                SetDirectional(0);
                break;
            case ButtonType.Down:
                SetDirectional(1);
                break;
            case ButtonType.Left:
                SetDirectional(2);
                break;
            case ButtonType.Right:
                SetDirectional(3);
                break;
            case ButtonType.Near:
                SetDirectional(4);
                break;
            case ButtonType.Far:
                SetDirectional(5);
                break;
            case ButtonType.Null:
                break;
        }

        AddTransform();
    }


    /// <summary>
    /// 根据点击按钮类型,设置方向
    /// </summary>
    /// <param name="arg"></param>
    void SetDirectional(int arg)
    {
        switch (arg)
        {
            case 0:
                targetY += testSpeed * 0.02f * Time.deltaTime;
                break;
            case 1:
                targetY -= testSpeed * 0.02f * Time.deltaTime;
                break;
            case 2:
                targetX += testSpeed * 0.04f * Time.deltaTime;
                break;
            case 3:
                targetX -= testSpeed * 0.04f * Time.deltaTime;
                break;
            case 4:
                if (targetDistance <= minDistance) break;
                targetDistance -= NFzoomSpeed * Time.deltaTime;
                break;
            case 5:
                if (targetDistance >= maxDistance) break;
                targetDistance += NFzoomSpeed * Time.deltaTime;
                break;
        }
    }


    /// <summary>
    /// 鼠标控制镜头
    /// </summary>
    void MouseControlCamera()
    {
        if (Input.GetMouseButton(1)) //鼠标右键
        {
            targetX += Input.GetAxis("Mouse X") * xSpeed * 0.02f;
            targetY -= Input.GetAxis("Mouse Y") * ySpeed * 0.02f;
        }
    }


    /// <summary>
    /// 添加矩阵信息
    /// </summary>
    void AddTransform()
    {
        if (isStart)
        {
            //默认第一次启动的位置
            targetX = 178f;
            targetY = 36.956f;
            isStart = false;
        }

        targetY             = ClampAngle(targetY, yMinLimit, yMaxLimit);
        Quaternion rotation = Quaternion.Euler(targetY, targetX, 0);
        transform.rotation  = rotation;
        transform.position  = rotation * new Vector3(0.0f, 0.0f, -targetDistance) + pivot.position + pivotOffset;
    }


    /// <summary>
    /// 滚轮放大缩小
    /// </summary>
    void GunLun()
    {
        float scroll                      = Input.GetAxis("Mouse ScrollWheel");
        if (scroll > 0.0f) targetDistance -= zoomSpeed;
        else if (scroll < 0.0f)
            targetDistance += zoomSpeed;
        targetDistance     =  Mathf.Clamp(targetDistance, minDistance, maxDistance);
    }


    /// <summary>
    /// 限定范围
    /// </summary>
    /// <param name="angle"></param>
    /// <param name="min"></param>
    /// <param name="max"></param>
    /// <returns></returns>
    private float ClampAngle(float angle, float min, float max)
    {
        if (angle < -360) angle += 360;
        if (angle > 360) angle  -= 360;
        return Mathf.Clamp(angle, min, max);
    }


    /// <summary>
    /// 镜头方向控制
    /// </summary>
    public void DirectionalControl(int arg)
    {
        switch (arg)
        {
            case 0:
                buttonType = ButtonType.Up;
                break;
            case 1:
                buttonType = ButtonType.Down;
                break;
            case 2:
                buttonType = ButtonType.Left;
                break;
            case 3:
                buttonType = ButtonType.Right;
                break;
            case 4:
                buttonType = ButtonType.Null;
                break;
            case 5: //近
                buttonType = ButtonType.Near;
                break;
            case 6: //远
                buttonType = ButtonType.Far;
                break;
            case 7: //重置视野
                targetDistance = 15;
                break;
        }
    }
}

拖动视角平移
这里写图片描述


支持

May Be —— 搞开发,总有一天要做的事!


拥有自己的服务器,无需再找攻略!

Chinar 提供一站式教程,闭眼式创建!

为新手节省宝贵时间,避免采坑!


先点击领取 —— 阿里全产品优惠券 (享受最低优惠)


1 —— 云服务器超全购买流程 (新手必备!)

2 —— 阿里ECS云服务器自定义配置 - 购买教程(新手必备!)

3—— Windows 服务器配置、运行、建站一条龙 !

4 —— Linux 服务器配置、运行、建站一条龙 !





Chinar


END

本博客为非营利性个人原创,除部分有明确署名的作品外,所刊登的所有作品的著作权均为本人所拥有,本人保留所有法定权利。违者必究

对于需要复制、转载、链接和传播博客文章或内容的,请及时和本博主进行联系,留言,Email: ichinar@icloud.com

对于经本博主明确授权和许可使用文章及内容的,使用时请注明文章或内容出处并注明网址

相关文章
|
5月前
|
图形学 C#
超实用!深度解析Unity引擎,手把手教你从零开始构建精美的2D平面冒险游戏,涵盖资源导入、角色控制与动画、碰撞检测等核心技巧,打造沉浸式游戏体验完全指南
【8月更文挑战第31天】本文是 Unity 2D 游戏开发的全面指南,手把手教你从零开始构建精美的平面冒险游戏。首先,通过 Unity Hub 创建 2D 项目并导入游戏资源。接着,编写 `PlayerController` 脚本来实现角色移动,并添加动画以增强视觉效果。最后,通过 Collider 2D 组件实现碰撞检测等游戏机制。每一步均展示 Unity 在 2D 游戏开发中的强大功能。
244 6
|
4月前
|
测试技术 C# 图形学
掌握Unity调试与测试的终极指南:从内置调试工具到自动化测试框架,全方位保障游戏品质不踩坑,打造流畅游戏体验的必备技能大揭秘!
【9月更文挑战第1天】在开发游戏时,Unity 引擎让创意变为现实。但软件开发中难免遇到 Bug,若不解决,将严重影响用户体验。调试与测试成为确保游戏质量的最后一道防线。本文介绍如何利用 Unity 的调试工具高效排查问题,并通过 Profiler 分析性能瓶颈。此外,Unity Test Framework 支持自动化测试,提高开发效率。结合单元测试与集成测试,确保游戏逻辑正确无误。对于在线游戏,还需进行压力测试以验证服务器稳定性。总之,调试与测试贯穿游戏开发全流程,确保最终作品既好玩又稳定。
188 4
|
4月前
|
前端开发 图形学 开发者
【独家揭秘】那些让你的游戏瞬间鲜活起来的Unity UI动画技巧:从零开始打造动态按钮,提升玩家交互体验的绝招大公开!
【9月更文挑战第1天】在游戏开发领域,Unity 是最受欢迎的游戏引擎之一,其强大的跨平台发布能力和丰富的功能集让开发者能够迅速打造出高质量的游戏。优秀的 UI 设计对于游戏至关重要,尤其是在手游市场,出色的 UI 能给玩家留下深刻的第一印象。Unity 的 UGUI 系统提供了一整套解决方案,包括 Canvas、Image 和 Button 等组件,支持添加各种动画效果。
214 3
|
4月前
|
设计模式 存储 人工智能
深度解析Unity游戏开发:从零构建可扩展与可维护的游戏架构,让你的游戏项目在模块化设计、脚本对象运用及状态模式处理中焕发新生,实现高效迭代与团队协作的完美平衡之路
【9月更文挑战第1天】游戏开发中的架构设计是项目成功的关键。良好的架构能提升开发效率并确保项目的长期可维护性和可扩展性。在使用Unity引擎时,合理的架构尤为重要。本文探讨了如何在Unity中实现可扩展且易维护的游戏架构,包括模块化设计、使用脚本对象管理数据、应用设计模式(如状态模式)及采用MVC/MVVM架构模式。通过这些方法,可以显著提高开发效率和游戏质量。例如,模块化设计将游戏拆分为独立模块。
235 3
|
4月前
|
图形学 C++ C#
Unity插件开发全攻略:从零起步教你用C++扩展游戏功能,解锁Unity新玩法的详细步骤与实战技巧大公开
【8月更文挑战第31天】Unity 是一款功能强大的游戏开发引擎,支持多平台发布并拥有丰富的插件生态系统。本文介绍 Unity 插件开发基础,帮助读者从零开始编写自定义插件以扩展其功能。插件通常用 C++ 编写,通过 Mono C# 运行时调用,需在不同平台上编译。文中详细讲解了开发环境搭建、简单插件编写及在 Unity 中调用的方法,包括创建 C# 封装脚本和处理跨平台问题,助力开发者提升游戏开发效率。
370 0
|
4月前
|
vr&ar 图形学 API
Unity与VR控制器交互全解:从基础配置到力反馈应用,多角度提升虚拟现实游戏的真实感与沉浸体验大揭秘
【8月更文挑战第31天】虚拟现实(VR)技术迅猛发展,Unity作为主流游戏开发引擎,支持多种VR硬件并提供丰富的API,尤其在VR控制器交互设计上具备高度灵活性。本文详细介绍了如何在Unity中配置VR支持、设置控制器、实现按钮交互及力反馈,结合碰撞检测和物理引擎提升真实感,助力开发者创造沉浸式体验。
211 0
|
4月前
|
图形学 开发者
透视与正交之外的奇妙视界:深入解析Unity游戏开发中的相机与视角控制艺术,探索打造沉浸式玩家体验的奥秘与技巧
【8月更文挑战第31天】在Unity中,相机不仅是玩家观察游戏世界的窗口,更是塑造氛围和引导注意力的关键工具。通过灵活运用相机系统,开发者能大幅提升游戏的艺术表现力和沉浸感。本文将探讨如何实现多种相机控制,包括第三人称跟随和第一人称视角,并提供实用代码示例。
181 0
|
4月前
|
图形学 开发者
【独家揭秘】Unity游戏开发秘籍:从基础到进阶,掌握材质与纹理的艺术,打造超现实游戏视效的全过程剖析——案例教你如何让每一面墙都会“说话”
【8月更文挑战第31天】Unity 是全球领先的跨平台游戏开发引擎,以其高效性能和丰富的工具集著称,尤其在提升游戏视觉效果方面表现突出。本文通过具体案例分析,介绍如何利用 Unity 中的材质与纹理技术打造逼真且具艺术感的游戏世界。材质定义物体表面属性,如颜色、光滑度等;纹理则用于模拟真实细节。结合使用两者可显著增强场景真实感。以 FPS 游戏为例,通过调整材质参数和编写脚本动态改变属性,可实现自然视觉效果。此外,Unity 还提供了多种高级技术和优化方法供开发者探索。
65 0
|
5月前
|
图形学 缓存 算法
掌握这五大绝招,让您的Unity游戏瞬间加载完毕,从此告别漫长等待,大幅提升玩家首次体验的满意度与留存率!
【8月更文挑战第31天】游戏的加载时间是影响玩家初次体验的关键因素,特别是在移动设备上。本文介绍了几种常见的Unity游戏加载优化方法,包括资源的预加载与异步加载、使用AssetBundles管理动态资源、纹理和模型优化、合理利用缓存系统以及脚本优化。通过具体示例代码展示了如何实现异步加载场景,并提出了针对不同资源的优化策略。综合运用这些技术可以显著缩短加载时间,提升玩家满意度。
354 5
|
5月前
|
图形学 开发者 存储
超越基础教程:深度拆解Unity地形编辑器的每一个隐藏角落,让你的游戏世界既浩瀚无垠又细节满满——从新手到高手的全面技巧升级秘籍
【8月更文挑战第31天】Unity地形编辑器是游戏开发中的重要工具,可快速创建复杂多变的游戏环境。本文通过比较不同地形编辑技术,详细介绍如何利用其功能构建广阔且精细的游戏世界,并提供具体示例代码,展示从基础地形绘制到植被与纹理添加的全过程。通过学习这些技巧,开发者能显著提升游戏画面质量和玩家体验。
214 3