zl程序教程

您现在的位置是:首页 >  后端

当前栏目

《Unity开发实战》——3.9节鼠标悬停时高亮显示材质

开发 实战 显示 Unity 材质 3.9
2023-09-11 14:19:09 时间

本节书摘来自华章社区《Unity开发实战》一书中的第3章,第3.9节鼠标悬停时高亮显示材质,作者 (爱尔兰)Matt Smith (巴西)Chico Queiroz,更多章节内容可以访问云栖社区“华章社区”公众号查看

3.9 鼠标悬停时高亮显示材质
高亮对象是让玩家知道这个对象可以交互的最有效的方式。在拼图游戏和点击式冒险游戏中很有用,3D用户界面中也可以用。

3.9.1 准备工作
本节中需要一个 3D 模型和一个 2D 纹理贴图,也可以直接导入0423_03_08文件夹中名为highlight的包。

3.9.2 操作步骤
请按照下面的步骤实现鼠标悬停时高亮材质:
1)导入包,并打开highlightScene 场景。
2)在Hierarchy 视图中,选择 3D 对象让其高亮(名为highlightCube)。
3)在 Inspector 视图中,应该会显示这个对象的材质,使用Shader的下拉菜单把值从Diffuse修改成VertexLit。
4)把baseBox 纹理应用到材质的Base纹理。
5)注意 VertexLit 着色器有一个属性叫做Emissive Color,默认是black。如果想预览其变化,可以修改成green(但要记得改回来)。
6)在Project视图中,通过下拉菜单创建一个C#脚本,命名为HighlightObject 然后打开。
7)替换成下面的代码:


7322c1f45cf4c9175efd08226f32bf26ab5adbc8

20cd837646226858a0f1834ec5d6ed0e18bca1ab

10)通过Component | Physics | Box Collider 添加一个盒子碰撞器(box collider )到 highlightCube对象上。
11)测试场景。盒子应该会在鼠标悬停时高亮(点击时更亮)。

3.9.3 实现原理
box collider 通过盒子探测鼠标指针,像改变发光色值的触发器一样工作。mouseon 布尔变量用于探测鼠标按钮在box collider上是否松开,并相应地修改其颜色。

3.9.4 更多内容
可以用其他shaders实现更多有意思的东西,但是一定要修改特定的材质属性。

高亮自发光着色器
如果在脚本中把_Emission 替换成 _Color自发光着色器就会工作了。 使用透明着色器
透明着色器(Transparent shaders)也是一个有意思的东西。可以通过修改main color的Alpha值而达到修改透明度的目的(应该在脚本中的_Color相关的代码中)。
创意代码之图片悬停效果 自己也想写一个类似这种的特效,就是鼠标放图片上时图片会悬停,就是那种戳一下动一下的效果,本文会先分解实现的步骤,使用到知识点都会有案例,那么我们开始吧。
【Unity3D 灵巧小知识点】☀️ | Unity通过 射线 获取 鼠标的世界坐标 和 鼠标点击的物体信息 Unity 小科普 老规矩,先介绍一下 Unity 的科普小知识: Unity是 实时3D互动内容创作和运营平台 。 包括游戏开发、美术、建筑、汽车设计、影视在内的所有创作者,借助 Unity 将创意变成现实。 Unity 平台提供一整套完善的软件解决方案,可用于创作、运营和变现任何实时互动的2D和3D内容,支持平台包括手机、平板电脑、PC、游戏主机、增强现实和虚拟现实设备。