unity学习(68)——相机/模型的旋转/位置计算

这个比想象中要难,而且需要自己写。

1.相机可以转xy两个位置,可以点头和转圈。注意这里有一个if判断(后面返回来发现了这些问题)

2.角色不能点头,只能转圈

难得是移动方向,因为移动方向(位置)和转向是相关联的

3.先做相机的移动,相机除了和角色做同向的水平转动,还要以角色为锚点做圆弧运动。

3.1移到背后,z应该是负值,这东西再着急也没用,最好的办法就是一步一步做。

 对应调整

 调整结果,满足要求

3.2当角色和相机发生“转圈”时(绕y轴旋转),相机要已角色为轴做圆弧运动。也就是要把-4这个距离分到x轴和z轴上

确实是转了,但是转的速度是不一样的,调整转动角度用的是y角度的差值,而不是y角度的数值

把scene调成下边这样,也可以很快发现问题,现在是擦着背后和相机初始位置做圆周运动

不加距离的时候确,相机和角色确实是同朝向的,相机的朝向没问题,相机的问题有问题!不过有了俯视图这种思维问题很快应该就能解决了

如下代码后,相机确实绕着小人做圆周运动了但转速太快了

mainCamera.transform.position = model.transform.position + new Vector3(-4 * Mathf.Sin(mainCamera.transform.eulerAngles.y)+0, 0, -4 * Mathf.Cos(mainCamera.transform.eulerAngles.y));

应该是把角度和弧度给弄混了!改成弧度以后确实是同速度了

mainCamera.transform.position = model.transform.position + new Vector3(-4 * Mathf.Sin(mainCamera.transform.eulerAngles.y/180*2*Mathf.PI)+0, 0, -4 * Mathf.Cos(mainCamera.transform.eulerAngles.y / 180 * 2 * Mathf.PI));

但是相机的旋转角度有问题,并不是一直朝向小人背后

是 /360*2Π,修改后终于达成预期效果

mainCamera.transform.position = model.transform.position + new Vector3(-4 * Mathf.Sin(mainCamera.transform.eulerAngles.y/360*2*Mathf.PI)+0, 0, -4 * Mathf.Cos(mainCamera.transform.eulerAngles.y / 360 * 2 * Mathf.PI));

 4.角色移动

现在存在的问题是:角色的移动是按照坐标轴的绝对方向为基准进行移动的,我需要的是按照当前朝向进行相对移动。

当前的角色移动代码如下:

Vector3 direction = (Vector3.forward * vector3.Vertical + Vector3.right * vector3.Horizontal)* speed * Time.fixedDeltaTime;

在两句之间来一个向量旋转即可,问题不大,绕着y轴转

结果非常成功

5.角色控制器的整体代码如下:

using System.Collections;
using System.Collections.Generic;
using UnityEngine;public class JoystickPlayerExample : MonoBehaviour
{public static float speed;//这个可以在unity中赋值的public static float rotationSpeed;public VariableJoystick vector3;public VariableJoystick quaternion4;public Rigidbody rb;public static GameObject model;//这个需要赋值,在登录过程中只赋值本地玩家自身public static Camera mainCamera;public void FixedUpdate(){//Debug.Log(variableJoystick.Vertical);//Debug.Log(variableJoystick.Horizontal);//计算方向差  正负以后再说Vector3 direction = (Vector3.forward * vector3.Vertical + Vector3.right * vector3.Horizontal)* speed * Time.fixedDeltaTime;//direction = (Vector3.forward * quaternion4.Vertical + Vector3.right * quaternion4.Horizontal) * speed * Time.fixedDeltaTime;//rb.AddForce(direction * speed * Time.fixedDeltaTime, ForceMode.VelocityChange);//重力体不满足条件direction = Quaternion.Euler(0, mainCamera.transform.eulerAngles.y, 0)* direction;//绕着y轴转--这里的前后顺序不能颠倒//1.模型位置model.transform.position = model.transform.position + direction;//model.transform.rotation = model.transform.rotation + rotation;//Debug.Log(model.GetInstanceID());//Debug.Log(model.transform.position);//实测是一直刷新的,所以我觉得相机写在这里也是可以的//一个模型一个相对相机位置的参数//2.相机位置--需要做到背后朝向//mainCamera.transform.position = model.transform.position+ new Vector3(0, 1.5f,-4);//其实就是maincamera,//mainCamera.transform.position = model.transform.position + new Vector3(-4 * Mathf.Cos(mainCamera.transform.eulerAngles.y), 1.5f, -4 * Mathf.Sin(mainCamera.transform.eulerAngles.y));//mainCamera.transform.position = model.transform.position + new Vector3(0,0,-4);mainCamera.transform.position = model.transform.position + new Vector3(-4 * Mathf.Sin(mainCamera.transform.eulerAngles.y/360*2*Mathf.PI)+0, 0, -4 * Mathf.Cos(mainCamera.transform.eulerAngles.y / 360 * 2 * Mathf.PI));//-4 分到 x轴和z轴上//mainCamera.transform.position = model.transform.position;//从这里开始是旋转// 获取用户的输入轴(例如:鼠标移动)//3.相机旋转float horizontal = quaternion4.Horizontal * rotationSpeed * Time.deltaTime;float vertical = quaternion4.Vertical * rotationSpeed * Time.deltaTime;//抬头--这里z小于零时会出现反向旋转异常// 创建一个绕相机上方轴旋转的QuaternionQuaternion horizontalRotation = Quaternion.AngleAxis(horizontal, Vector3.up);//三角函数值// 创建一个绕相机右方轴旋转的QuaternionQuaternion verticalRotation = Quaternion.AngleAxis(vertical, mainCamera.transform.right);//旋转角度和旋转轴Debug.Log(mainCamera.transform.eulerAngles.y);if (Mathf.Abs(mainCamera.transform.eulerAngles.y)<90|| Mathf.Abs(mainCamera.transform.eulerAngles.y) > 270)//整整弄了一天,欧拉角判定,rotation是弧度{//Debug.Log("负重前行");//Debug.Log(mainCamera.transform.eulerAngles.y);verticalRotation = Quaternion.AngleAxis(vertical*-1, mainCamera.transform.right);//但愿不要跳屏}//不能歪头,还有一个轴必须做成固定不动的// 应用这两个旋转mainCamera.transform.rotation *= horizontalRotation;mainCamera.transform.rotation *= verticalRotation;mainCamera.transform.eulerAngles = new Vector3(mainCamera.transform.eulerAngles.x, mainCamera.transform.eulerAngles.y, 0);//Debug.Log(mainCamera.transform.rotation);//实测,//水平拖拽是第二个位置(三角函数值0-1),竖直拖拽是第一个位置,//第三个位置最好是0,第四个位置最好是1//模型同时设置水平旋转--unity脚本这么看来还是很方便的//model.transform.eulerAngles= new Vector3(mainCamera.transform.eulerAngles.x, mainCamera.transform.eulerAngles.y, 0);//4.模型旋转(ok)model.transform.eulerAngles = new Vector3(0, mainCamera.transform.eulerAngles.y, 0);//脑袋单独做,无所谓 磕头 转圈 歪脑袋}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/766710.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

在Sequence中缓存Niagara粒子轨道

当Sequence中粒子特效较多时&#xff0c;播放检查起来较为麻烦&#xff0c;而使用Niagara缓存功能可将粒子特效方便的缓存起来&#xff0c;并且还可以更改播放速度与正反播放方向&#xff0c;便于修改。 1.使用Niagara缓存需要先在插件里打开NiagaraSimCaching 2.创建一个常…

web前端之行为验证码、不同设备和屏幕尺寸呈现不同大小、元素宽度根据视口宽度进行调整、元素或图片裁剪、图片验证码

MENU 前言版本一(htmlJScss)版本二(htmlJScsscanvas) 前言 1、版本一的样式比较齐全&#xff1b; 2、版本二的JS逻辑和功能效果比较完善&#xff0c;且是别人的代码&#xff0c;后续会对样式进行完善。[Gitee | 哔哩哔哩]&#xff1b; 3、两个版本各有千秋&#xff0c;主要学习…

CRC计算流程详解和FPGA实现

一、概念 CRC校验&#xff0c;中文翻译过来是&#xff1a;循环冗余校验&#xff0c;英文全称是&#xff1a;Cyclic Redundancy Check。是一种通过对数据产生固定位数的校验码&#xff0c;以检验数据是否存在错误的技术。 其主要特点是检错能力强、开销小&#xff0c;易于电路实…

政安晨:【深度学习实践】【使用 TensorFlow 和 Keras 为结构化数据构建和训练神经网络】(二)—— 深度神经网络

政安晨的个人主页&#xff1a;政安晨 欢迎 &#x1f44d;点赞✍评论⭐收藏 收录专栏: TensorFlow与Keras实战演绎 希望政安晨的博客能够对您有所裨益&#xff0c;如有不足之处&#xff0c;欢迎在评论区提出指正&#xff01; 概述 深度神经网络&#xff08;Deep Neural Network…

SQLiteC/C++接口详细介绍sqlite3_stmt类(六)

返回&#xff1a;SQLite—系列文章目录 上一篇&#xff1a;SQLiteC/C接口详细介绍sqlite3_stmt类&#xff08;五&#xff09; 下一篇&#xff1a; SQLiteC/C接口详细介绍sqlite3_stmt类&#xff08;七&#xff09; 17. sqlite3_clear_bindings函数 sqlite3_clear_bindings函…

Day44:WEB攻防-PHP应用SQL盲注布尔回显延时判断报错处理增删改查方式

目录 PHP-MYSQL-SQL操作-增删改查 PHP-MYSQL-注入函数-布尔&报错&延迟 基于布尔的SQL盲注-逻辑判断(需要有回显,没回显搞不了)跟union需要的条件差不多 基于时间的SQL盲注-延时判断(不需要任何回显) 基于报错的SQL盲注-报错回显(需要报错回显&#xff0c;没报错回…

【LabVIEW FPGA入门】FPGA 存储器(Memory)

可以使用内存项将数据存储在FPGA块内存中。内存项以2kb为倍数引用FPGA目标上的块内存。每个内存项引用一个单独的地址或地址块&#xff0c;您可以使用内存项访问FPGA上的所有可用内存。如果需要随机访问存储的数据&#xff0c;请使用内存项。 内存项不消耗FPGA上的逻辑资源&…

leetcode 2671

leetcode 2671 题目 例子 思路1 使用哈希&#xff0c; unordered_map 是基于hash 实现的key,val 存储。 代码1 class FrequencyTracker {unordered_map<int, int>m;public:FrequencyTracker() { }void add(int number) {if(m.find(number) m.end()){m.insert({num…

备战蓝桥杯---牛客寒假算法基础集训6

1.并查集数学 分析&#xff1a; 首先我们知道算数基本定理&#xff0c;如果两个数有大于1的质因子&#xff0c;那么我们就需要把他们放在同一个集合&#xff0c;因此我们可以用欧拉刷出1e6范围内的素数&#xff0c;然后依次看输入的数。 拿202*2*5举例子&#xff0c;我们在求…

算法系列--链表刷题(二)

&#x1f495;"轻舟已过万重山"&#x1f495; 作者&#xff1a;Mylvzi 文章主要内容&#xff1a;算法系列–链表刷题(二) 今天为大家带来的是算法系列--链表刷题(二),带来了几道经典的有关链表的面试题(合并K个有序列表) 1.两数相加 https://leetcode.cn/problems/a…

测试ALPHA开发板CAN1的设备树文件

一. 简介 前面一篇文章学习了 ALPHA开发板上的 CAN接口的设备节点信息&#xff0c;文章如下&#xff1a; ALPHA开发板修改CAN的设备树节点信息-CSDN博客 本文对设备树文件进行测试&#xff0c;即开发板加载 .dtb设备树文件。 二. 加载测试 CAN的设备树文件 1. 拷贝设备树…

fiddler过滤器使用,隐藏图片、js、css请求

如果抓包过程中不想查看图片、js、css请求&#xff0c;或者只想抓某个ip或者某个网页下的请求&#xff0c;可以在过滤器中设置。 &#xff08;1&#xff09;没有开启过滤器 可以看出所有的请求都会抓取&#xff0c;cs、js、图片请求都有 &#xff08;2&#xff09;开启过滤器 …

dubbo 源码系列之-集群三板斧---负载均衡(二)

在上一课时我们了解了 LoadBalance 接口定义以及 AbstractLoadBalance 抽象类的内容&#xff0c;还详细介绍了 ConsistentHashLoadBalance 以及 RandomLoadBalance 这两个实现类的核心原理和大致实现。本课时我们将继续介绍 LoadBalance 的剩余三个实现。 LeastActiveLoadBala…

MySQL | 视图

视图是一个虚拟表&#xff0c;其内容由查询定义。同真实的表一样&#xff0c;视图包含一系列带有名称的列和行数据。视图的数据变化会影响到基表&#xff0c;基表的数据变化也会影响到视图。 1. 基本使用 1.1. 创建视图 create view 视图名 as select语句&#xff1b; 创建测…

hcip实验

一、实验拓扑 二、实验划分 AR1的Serial3/0/0接口&#xff1a;192.168.1.1/24&#xff1b; AR2的Serial3/0/0接口&#xff1a;192.168.1.2/24&#xff1b; AR2的Serial3/0/1和4/0/0的聚合接口&#xff1a;192.168.2.2/24&#xff1b; AR3的Serial3/0/0和3/0/1的聚合接口&am…

网络安全实训Day8

写在前面 网络工程终于讲完了。这星期到了网络安全技术部分。 网络安全实训-网络安全技术 网络安全概述 信息安全&#xff1a;所有保障计算机硬件、系统、软件、数据不因有意或无意的行为导致的服务中断、数据损坏或丢失等安全事件的保障技术 网络安全&#xff1a;基于计算机…

C/C++之内存旋律:星辰大海的指挥家

个人主页&#xff1a;日刷百题 系列专栏&#xff1a;〖C/C小游戏〗〖Linux〗〖数据结构〗 〖C语言〗 &#x1f30e;欢迎各位→点赞&#x1f44d;收藏⭐️留言&#x1f4dd; ​ ​ 一、C/C内存分布 我们先来了解一下C/C内存分配的几个区域&#xff0c;以下面的代码为例来看…

机器学习——决策树剪枝算法

机器学习——决策树剪枝算法 决策树是一种常用的机器学习模型&#xff0c;它能够根据数据特征的不同进行分类或回归。在决策树的构建过程中&#xff0c;剪枝算法是为了防止过拟合&#xff0c;提高模型的泛化能力而提出的重要技术。本篇博客将介绍剪枝处理的概念、预剪枝和后剪…

C语言内存函数(1)【memcpy函数的使用与模拟实现】【memmove函数的使用和模拟实现】

关于内存函数有四个函数需要我们学习。分别是memcpy&#xff0c;memmove&#xff0c;memset和memcmp。都在头文件string.h里面。 一.memcpy函数的使用 一提到这个函数&#xff0c;我们可能会联想到strcpy函数&#xff0c;但strcpy函数是针对字符串的拷贝。但是我们在写代码的…

百度文心一言(ERNIE bot)API接入Android应用

百度文心一言&#xff08;ERNIE bot&#xff09;API接入Android应用实践 - 拾一贰叁 - 博客园 (cnblogs.com) Preface: 现在生成式AI越来越强大了&#xff0c;想在android上实现一个对话助手的功能&#xff0c;大概摸索了一下接入百度文心一言API的方法。 与AI助手交换信息的…