Unity教程 | 手把手教你拼一个3D“魔方”

2024-08-29 13:38
文章标签 教程 手把手 3d unity 魔方

本文主要是介绍Unity教程 | 手把手教你拼一个3D“魔方”,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

本教程将为刚接触unity的初学者讲解如何在Unity中实现3D立方体的堆叠,利用一个或多个预制件动态创建立方体进行拼接,为这些立方体赋予不同的颜色。

 下载本文的示例工程,示例工程使用Unity 5.3.1f1。

http://pan.baidu.com/s/1pLnYdVd

 

第一步:创建UI

打开Unity编辑器新建3D工程命名为“Cubes Galore”,如下:

 

124626x5wv9vdocbbjzesx

 

然后新建三个文件夹,分别命名为Prefabs, Scripts和 Materials :


124626azw9tdi20gz0hw2d


新建5种不同颜色的材质,用于为立方体添加颜色。大家可以使用示例工程中的材质,也可以自己创建:

 

124626kij7442i17bbkux1

 

材质创建完成后,在场景中添加立方体,依次点击菜单项GameObject – 3D Object – Cube新建立方体:

 

124627nl1dvd7gpy17laag

 

在层级视图中选中新建的Cube,按Ctrl/Cmd + D复制4个立方体:

 

124627znn292y9znu4k82a

 

为这5个立方体分别使用对应的5个不同颜色的材质,然后将它们从层级视图拖拽至项目视图的Prefabs文件夹下,保存为预制件后,从层级视图删除它们:

 

124627hb46mhcib2gg4ime

 

新建空Game Object命名为“Controller”:

 

124628xp0vr5a4a1wpa6g3

 

在Scripts文件夹下新建C#脚本命名为“CubeController”,将CubeController脚本绑定到Controller对象上:

 

124628kgkicevcj7yia10v


到此第一步最基础的部分就完成了。

 

第二步:算法1

这个步骤将介绍利用单个预制件生成多个立方体对象,并形成一个方块。这里需要计算新生成的各个立方体的位置,会用到一点几何知识。

124628q11q5m5vqev4egf1

将方块的Y坐标设为0,暂时不改变各个立方体的高度。X坐标范围设为从-3到2,长度为5,深度值也一样,所以Z坐标范围设为0到5,在CubeController脚本中加入下面的代码:

 

124629md1pyt1nz1wnqvas

 

代码变量命名直接使用x、z,以便于理解。然后在Controller对象下加入一个立方体预制件:

 

124629p8bm80bb8p8fl9pw

 

效果如下:

 

124629v3h9vgozf93i9i76

 

改变相机视角以看到完整的方块,将相机的Y坐标值改为6,将旋转的X值设为30:

 

124630fpzocmmwc0ssmo0n

 

调整代码如下,让立方体之间有些间隙:

 

124630smw39ov9ywvxmw95

 

将循环的增量从1改为1.08,为立方体之间留出空隙,效果如下:

 

124630rmf7ebyfuugzekfy

 

这下可以清晰地看到各个小方块了。

 

第三步:使用多个预制件

利用步骤一中新建的5个立方体预制件,使用不同颜色的立方体来生成方块,修改脚本代码如下:

 

124631f04hfrce4mrrcdr0

 

注意,这里使用Random随机算法从立方体列表中随机选择,以生成不同颜色的小方块:

 

124631spplj2naffdklnxq

 

还有很多种办法来实现上述的随机效果,但这种方式非常简单而直观。

 

第四步:制作3D魔方

该步骤使用现有代码来创建一个3D立方,只需在当前基础上再添加Y轴上的循环,Y值范围从0到5,这样就能生成一个5x5x5的立方体。代码如下:

 

124631rl18lllhlnjchh19

 

最终效果如下:

 

124632b67kj6h7kukupjtt

 

这里只是再次添加了一层循环,利用3次嵌套循环来生成立方体,没有其它变化。

 

第五步:随机立方体变量

该步骤将新建Controller脚本,来实现一些与CubeController脚本不同的功能。这里不再使用固定的x、y、z值来生成固定数量的立方体,而是可以在编辑器中修改这些值。这样无需更改代码,就可以在编辑器运行模式下查看不同的结果。先声明两个变量:

 

124632yk521z121t9ie05c

 

第一个CubePrefab变量就是CubeController脚本中的预制件,仅使用一个预制件动态改变颜色。GridSize是生成立方体在三个维度上的数量,可以在编辑器中指定不同的值。

 

124632q9wtvssxicsfnuui

124632bopo9bs888mqma89

 

CreateCubeGrid方法用于创建立方体,三次循环的次数取决于编辑器中GridSize的值,每次增量为1。在循环中,创建临时变量cube用于生成立方体,利用Quaterion.Identity保证所有立方体的旋转与预制件保持一致。临时变量renderer用于为立方体随机赋予材质以显示不同的颜色,然后创建三个颜色分量,使用随机数生成不同的颜色。最终效果如下:

 

124633a2pukyellx5edkyw

 

到这里本篇教程就结束了,是不是很简单呢?赶紧动手做起来吧!大家还可以发挥想象力,利用一些几何变换,将小立方体玩成虚拟乐高积木,拼出楼梯或城堡等建筑。

VR开发, Unity, VR社区, Unity

这篇关于Unity教程 | 手把手教你拼一个3D“魔方”的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1118012

相关文章

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

无人叉车3d激光slam多房间建图定位异常处理方案-墙体画线地图切分方案

墙体画线地图切分方案 针对问题:墙体两侧特征混淆误匹配,导致建图和定位偏差,表现为过门跳变、外月台走歪等 ·解决思路:预期的根治方案IGICP需要较长时间完成上线,先使用切分地图的工程化方案,即墙体两侧切分为不同地图,在某一侧只使用该侧地图进行定位 方案思路 切分原理:切分地图基于关键帧位置,而非点云。 理论基础:光照是直线的,一帧点云必定只能照射到墙的一侧,无法同时照到两侧实践考虑:关

Makefile简明使用教程

文章目录 规则makefile文件的基本语法:加在命令前的特殊符号:.PHONY伪目标: Makefilev1 直观写法v2 加上中间过程v3 伪目标v4 变量 make 选项-f-n-C Make 是一种流行的构建工具,常用于将源代码转换成可执行文件或者其他形式的输出文件(如库文件、文档等)。Make 可以自动化地执行编译、链接等一系列操作。 规则 makefile文件

SWAP作物生长模型安装教程、数据制备、敏感性分析、气候变化影响、R模型敏感性分析与贝叶斯优化、Fortran源代码分析、气候数据降尺度与变化影响分析

查看原文>>>全流程SWAP农业模型数据制备、敏感性分析及气候变化影响实践技术应用 SWAP模型是由荷兰瓦赫宁根大学开发的先进农作物模型,它综合考虑了土壤-水分-大气以及植被间的相互作用;是一种描述作物生长过程的一种机理性作物生长模型。它不但运用Richard方程,使其能够精确的模拟土壤中水分的运动,而且耦合了WOFOST作物模型使作物的生长描述更为科学。 本文让更多的科研人员和农业工作者

沁恒CH32在MounRiver Studio上环境配置以及使用详细教程

目录 1.  RISC-V简介 2.  CPU架构现状 3.  MounRiver Studio软件下载 4.  MounRiver Studio软件安装 5.  MounRiver Studio软件介绍 6.  创建工程 7.  编译代码 1.  RISC-V简介         RISC就是精简指令集计算机(Reduced Instruction SetCom

MiniGPT-3D, 首个高效的3D点云大语言模型,仅需一张RTX3090显卡,训练一天时间,已开源

项目主页:https://tangyuan96.github.io/minigpt_3d_project_page/ 代码:https://github.com/TangYuan96/MiniGPT-3D 论文:https://arxiv.org/pdf/2405.01413 MiniGPT-3D在多个任务上取得了SoTA,被ACM MM2024接收,只拥有47.8M的可训练参数,在一张RTX

前端技术(七)——less 教程

一、less简介 1. less是什么? less是一种动态样式语言,属于css预处理器的范畴,它扩展了CSS语言,增加了变量、Mixin、函数等特性,使CSS 更易维护和扩展LESS 既可以在 客户端 上运行 ,也可以借助Node.js在服务端运行。 less的中文官网:https://lesscss.cn/ 2. less编译工具 koala 官网 http://koala-app.

【Shiro】Shiro 的学习教程(三)之 SpringBoot 集成 Shiro

目录 1、环境准备2、引入 Shiro3、实现认证、退出3.1、使用死数据实现3.2、引入数据库,添加注册功能后端代码前端代码 3.3、MD5、Salt 的认证流程 4.、实现授权4.1、基于角色授权4.2、基于资源授权 5、引入缓存5.1、EhCache 实现缓存5.2、集成 Redis 实现 Shiro 缓存 1、环境准备 新建一个 SpringBoot 工程,引入依赖:

SAM2POINT:以zero-shot且快速的方式将任何 3D 视频分割为视频

摘要 我们介绍 SAM2POINT,这是一种采用 Segment Anything Model 2 (SAM 2) 进行零样本和快速 3D 分割的初步探索。 SAM2POINT 将任何 3D 数据解释为一系列多向视频,并利用 SAM 2 进行 3D 空间分割,无需进一步训练或 2D-3D 投影。 我们的框架支持各种提示类型,包括 3D 点、框和掩模,并且可以泛化到不同的场景,例如 3D 对象、室

Windows环境利用VS2022编译 libvpx 源码教程

libvpx libvpx 是一个开源的视频编码库,由 WebM 项目开发和维护,专门用于 VP8 和 VP9 视频编码格式的编解码处理。它支持高质量的视频压缩,广泛应用于视频会议、在线教育、视频直播服务等多种场景中。libvpx 的特点包括跨平台兼容性、硬件加速支持以及灵活的接口设计,使其可以轻松集成到各种应用程序中。 libvpx 的安装和配置过程相对简单,用户可以从官方网站下载源代码