Unity 学习笔记5

摘要:
4: 鼠标光线1.RayclickRay//ray表示RaycastHitclickHit//RaycastHit存储一系列光线碰撞信息,对象单击ray=相机。主屏幕指向光线;//指定发射光线的摄影机作为主摄影机,获取当前鼠标屏幕坐标并将其转换为光线。相关API:1.RayCamera.main。ScreenPointToRay返回光线。光线指定从摄影机到屏幕的点。2.射线照相机。主视口PointToRay返回光线ray指定从摄影机到视口的点3.光线类4.光线投射命中光线投射碰撞信息5.布尔物理。当光线投射与任何对撞机相交时,光线投射为真,否则为假。布尔物理学。当光线投射穿过任何对撞机时,光线投射为真,否则为假。可以获取碰撞对象的变换、刚体、点和其他信息。

一:绘制线段:
为物体添加linerendenerer组件,在脚本中获得该组件的引用后,增加position数组大小,设置position数组数值即可绘制折线。
在脚本中获取了Linerenderer组件后,可以使用
linerenderer.SetVertexCount (int numberOfPosition);
方法动态的为position的size赋值,
然后使用
linerenderer.SetPosition (int index, vector3 newPosition));
方法为第index个position赋值 ,达到扩展线条的效果。

二:脚本拷贝物体(prefab与instantiate)
1.获得要拷贝prefab的引用
GameObject wuti = GameObject.Find("要拷贝的预组件");
2.用instantiate拷贝
Instantiate(wuti, position, rotation);//将wuti拷贝到position位置,角度为rotation
3.使用局部坐标实现对较为规则的物体的描边

三:unity3d调用windows的资源管理器:
1.项目Assets文件夹新建Plugins文件夹,放入System.Windows.Forms.dll文件
2.脚本中using System.Windows.Forms;
3.代码如下:
public voidLoadMap()
{
WWWwww_map;

OpenFileDialogchoiceWindow = new OpenFileDialog ();
choiceWindow.Title = "请选择载入地图";
choiceWindow.Filter = "图片文件(*.jpg,*.png,*.bmp)|*.jpg;*.png;*.bmp";
choiceWindow.InitialDirectory= UnityEngine.Application.dataPath + @"/map";
choiceWindow.RestoreDirectory= true;

if(choiceWindow.ShowDialog()== DialogResult.OK)
{
www_map= new WWW("file://" + choiceWindow.FileName);
gameObject.renderer.materials[0].SetTexture(0,www_map.texture);
}
}
代码功能:打开资源管理器窗口,选中一副图片,并将图片作为gameobject的材质贴图。

四:鼠标射线
1.Ray clickRay;//Ray代表发出的射线
RaycastHitclickHit;//RaycastHit储存一系列射线与物体碰撞的信息
clickRay =Camera.main.ScreenPointToRay(Input.mousePosition);
//指定发射射线的摄像机为主摄像机,获取当前鼠标屏幕坐标并将其转换成射线。
Physics.Raycast(clickRay, out clickHit);
//将clickRay的信息储存到clickHit中。
//也可当做判断条件是否发生碰撞如:if(Physics.Raycast(clickRay,out clickHit)){…}

以下是当时在网上淘的鼠标射线的知识,很有用处,先贴在这里让大家分享~


射线:射线是3D世界中一个点向一个方向发射的一条无终点的线,在发射轨迹中与其他物体发生碰撞时,它将停止发射 。
用途:射线应用范围比较广, 多用于碰撞检测(如:子弹飞行是否击中目标)、角色移动等 等。

相关API:

1、Ray Camera.main.ScreenPointToRay(Vector3 pos) 返回一条射线Ray从摄像机到屏幕指定一个点
2、Ray Camera.main.ViewportPointToRay(Vector3 pos) 返回一条射线Ray从摄像机到视口(视口之外无效)指定一个点
3、Ray 射线类 
4、RaycastHit 光线投射碰撞信息
5、bool Physics.Raycast(Vector3 origin, Vector3 direction, float distance, int layerMask)
当光线投射与任何碰撞器交叉时为真,否则为假。
bool Physics.Raycast(Ray ray, Vector3 direction, RaycastHit out hit, float distance, int layerMask)
在场景中投下可与所有碰撞器碰撞的一条光线,并返回碰撞的细节信息()。
bool Physics.Raycast(Ray ray, float distance, int layerMask)
当光线投射与任何碰撞器交叉时为真,否则为假。
bool Physics.Raycast(Vector3 origin, Vector3 direction, RaycastHit out hit,float distance, int layerMask)
当光线投射与任何碰撞器交叉时为真,否则为假。

注意:如果从一个球型体的内部到外部用光线投射,返回为假。
参数理解:
origin : 在世界坐标中射线的起始点
direction: 射线的方向
distance: 射线的长度
hit: 使用c#中out关键字传入一个空的碰撞信息类,然后碰撞后赋值。可以得到碰撞物体的transform,rigidbody,point等信息。 
layerMask: 只选定Layermask层内的碰撞器,其它层内碰撞器忽略。 选择性的碰撞
6、RaycastHit[] RaycastAll(Ray ray, float distance, int layerMask)
投射一条光线并返回所有碰撞,也就是投射光线并返回一个RaycastHit[]结构体。

免责声明:文章转载自《Unity 学习笔记5》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇设计模式之---适配器设计模式WIN8 Metro UI 风格下的微软报表开发与设计 Metro UI SSRS下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

3D画廊

3D画廊 之前我都是写的学习的内容,我在写这些教程时遇到有趣的炫酷的小例子也会专门拿出来写一篇文章,今天就写一个酷炫的小例子,叫3D画廊,它是属于ViewPage的进阶版。 此项目下载地点:https://github.com/qySvip/3D-gallery 下面的指示器是使用的一大神的第三方库,会在文章下方简单讲述一下。 效果图 3D画廊的实现 首...

神奇的position:sticky

sticky定义 position:sticky定义, eg:CSS中position属性介绍(新增sticky) 设置了sticky的元素,在屏幕范围(viewport)时该元素的位置并不受到定位影响(设置是top、left等属性无效),当该元素的位置将要移出偏移范围时,定位又会变成fixed,根据设置的left、top等属性成固定位置的效果。 sti...

在HTML5中,用getCurrentPosition()获取用户的当前位置

转:https://blog.csdn.net/xiaoxia188/article/details/84703576 getCurrentPosition(successCallback, errorCallback,PositionOptions);successCallback: 表示获取到的用户数据位置。该对象包含三个属性:coords、addre...

浅析射线检测 raycast 的使用 !Cocos Creator 3D !

哎呀?为什么我设置了节点点击回调没反应呀? 记得在写小鸡拍拍的时候遇到一个问题,想要捕捉排球的点击事件,按照 2d 的写法,给3d 节点添加 node 事件,结果点了没反应。代码大概是以下的样子。 this.node_volleyball.on(Node.EventType.TOUCH_START, () => { console.log('...

Web前端-按钮点击效果(水波纹)

这种效果可以由元素内嵌套canves实现,也可以由css3实现。 Canves实现 网上摘了一份canves实现的代码,略微去掉了些重复定义的样式并且给出js注释,代码如下 第一种方法: html骨架代码 <a class="btn color-1 material-design"data-color="#2f5398">Press me!&...

前端开发中常遇到的浏览器兼容问题小结

1. 默认的内外边距不同 问题:各个浏览器默认的内外边距不同 解决:*{margin:0;padding:0;} 2. 水平居中的问题 问题:设置 text-align: center;  ie6-7文本居中,嵌套的块元素也会居中,ff /opera /safari /ie8文本会居中,嵌套块不会居中 解决:块元素设置 1、margin-left:auto...