在线体验链接:
http://example.creator-star.cn/block3d/

上面图中是打砖块游戏的主要 3D 节点元素,Shawn 这两天在学习 Unity 与 Creator3D 感受到制作 3D 游戏与 2D 游戏最大的不同是 3D 游戏是在模拟一个真实世界,下面我对打砖块游戏场景中的主要 3D 节点做个简要说明。

主灯光

当我们创建场景时,引擎为会我们默认创建两个节点:灯光、摄像机。
Main Light它是一只平行灯光,模拟真实世界中的太阳,你将它放在任何位置场景效果的变化都不大,调整角度会影响3D物体的表面的光泽。

3D摄像机

Camera 摄像机所照摄的界面就是我们运行时所看到的画面。

我们这里使用的是透视视角,它像一个锥体,通过锥体能可视化地控制摄像机的参数表现:

  1. 控制锥体底部的四个点可以调节摄像机的视野;
  2. 控制底部的中心点调节摄像机的远近;
  3. 控制摄像机的position、rotation调整摄像机的位置与角度;

在【主菜单】 > 【Develop】> 【Camera Privew】可以观察到实时的摄像机画面,请看下图:

地面

ground 是用 Plane 3D 节点模拟的地面,可以通过下面菜单创建:

Plane 像一张纸,只有x、y,可以设置 Plane 的大小,不论怎么设置它的 Scale y 他在场景中的高度都不会变。

我们重点看一下地块节点和它的组件:

可以看到在 Creator 3D 中节点属性已经被精简了,只有基本的Postion、Rotation、Scale三个基本的属性(Layer属性还没了解作用)。

温馨提示:2D 节点同样如此,2D节点中的锚点、Size属性被移到名为 cc.UITransformComponent 的组件上了,color 被移到 cc.SpriteComponent 组件上,而且没有Opacity属性,由 color 属性统一接管。

3D 物理最为重要的是它的 cc.ModelComponent 组件,其中Mesh属性是控制 3D 物体的形状,比如:立方体、球体、胶囊体等,引擎内置了如下 Mesh 资源:

像"#"井号一样的图标就是 Mesh 资源了,它主要保存的是模型的顶点数据。除了 Mesh 属性,还有一个与 3D 物体表现有关的就是材质了,看下图:

这里为了实验地面不同的贴图,我这里自定一个材质资源,在资源管理器中,鼠标右键创建 Material:

从 2D 游戏开发过渡到 3D 有一个关键的点就是理解材质系统,当创建一个材质资源,看到密密麻麻的属性时,心都麻了半截:

经过 Shawn 的连蒙带猜,将 ground 地块的材质设置如下:

需要注意,这样设置的材质颜色比较暗,还要把材质属性面板拉到底部,将 Emissive 颜色属性设置为白色,地板看起来就亮了。

我之前还有一种做材质的做法,使用的是无光照的材质,比使用标准材质要简单一些:

尝试了这么多,总算是把地面材质给弄的像点样子了,下面是为地块添加碰撞组件:

在 Creator 3D 中物理引擎不需要使用代码激活,直接将 cc.BoxColliderComponent 组件挂在节点上即可,需要注意地面只需要挂上碰撞组件就行了,如果添加了物理刚体组件,地面会向下掉落,这不是我们想要的。

砖块

砖块是使用的 Cube 3D节点创建,它的 cc.ModelComponent 默认为 box.mesh 看下图:

砖块的材质需要重新定制一个,方法与前面的地面材质相同,只要我们一修改这个材质资源,场景中的所有砖块都会发生变化,这里就不在唠叨了。

下面我们为砖块添加 cc.RigidbodyComponent 组件,在节点属性面板下方点击 Add Component 按钮,看下图:

Creator 3D 目前还是预览版本,组件没分类,看起来显的有点乱,RigidBody 组件在倒数第3个,还需要再添加上 BoxCollider 在倒数第5个,节点组件属性如下:

在 RigidBody 组件上,将 Mass 设置小一点,它表示物理的质量。BoxCollider组件默认就好,IsTrigger 属性不能勾上,勾上之后物理碰撞效果就没有了,但可以用代码接收到碰撞事件。

在空中的砖块,当你运行起来发现他会自然掉落,与地面接触会产生碰撞,而这一切我们都不用编写代码哦!

小结

将砖块节点多复制一些在场景中,制作成一堵墙我们的游戏场景就差不多了,我们下次继续子弹球体的制作与创建,以及使用键盘控制摄像机移动。

感谢你的关注与阅读,欢迎你来「Creator星球游戏开发社区」公众号分享你的技术与经验,愿我们在前进的道路上砥砺前行,共同成长!

本文由博客一文多发平台 OpenWrite 发布!

Cocos Creator 3D 打砖块图文教程(一)的更多相关文章

  1. Cocos Creator 3D 打砖块教程(二) | 子弹发射与摄像机平滑移动

    在线体验链接: http://example.creator-star.cn/block3d/ 前面一篇文章,我们讲了[打砖块]游戏中的3D物体的场景布局.材质资源.物理刚体与碰撞组件,接下来本篇文章 ...

  2. cocos creator 3D | 蚂蚁庄园运动会星星球

    上一篇文章写了一个简易版的蚂蚁庄园登山赛,有小伙伴留言说想要看星星球的,那么就写起来吧! 效果预览 配置环境 cocos creator 3d 1.0.0 小球点击 3d里节点无法用 cc.Node. ...

  3. cocos creator 3D | 拇指射箭

    拇指射箭!你能射中靶心么? 效果预览 配置环境: cocos creator 3d v1.0.0 玩法介绍: 长按屏幕,拖动瞄准,放手发射.风向.重力和距离影响最终结果!越靠近中心得分越高!最高分10 ...

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

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

  5. cocos creator 3D | 拇指投篮 | 3D项目入门实战

    你的命中率是多少呢?文章底部试玩! 效果预览 配置环境: Cocos Creator 3D v1.0.1 玩法说明: 触摸屏幕,向上滑动投篮!注意篮板是会移动的哦!看看你的命中率是多少! 实现原理 为 ...

  6. Cocos Creator - 入门教程项目 - 博客频道 - CSDN.NET

    3457 教程司令部 [20160418] | Cocos Creator - CocoaChina CocoaChina_让移动开发更简单cocoachina.com 2033 Cocos Crea ...

  7. Qt Creator中的3D绘图及动画教程(参照NeHe)

    Qt Creator中的3D绘图及动画教程(参照NeHe) http://blog.csdn.net/cly116/article/details/47184729 刚刚学习了Qt Creator,发 ...

  8. 欢乐水杯(happy glass)中流体的一种实现!图文视频讲解 ! Cocos Creator!

    使用cocos creator v2.2.2 实现流体效果 ! 图文+视频讲解! 效果预览 实现原理 整体思路是参考论坛中的一个帖子 这款游戏中水的粘连效果在Construct3中利用图层很容易实现, ...

  9. cocos creator主程入门教程(七)—— MVC架构

    五邑隐侠,本名关健昌,10年游戏生涯,现隐居五邑.本系列文章以TypeScript为介绍语言. 这一篇将介绍在游戏客户端常用的架构MVC架构.一个游戏的MVC如下划分: M:1)单例全局的数据中心Wo ...

随机推荐

  1. EDU 50 E. Covered Points 利用克莱姆法则计算线段交点

    E. Covered Points 利用克莱姆法则计算线段交点.n^2枚举,最后把个数开方,从ans中减去. ans加上每个线段的定点数, 定点数用gcs(△x , △y)+1计算. #include ...

  2. 洛谷p2015二叉苹果树&yzoj1856多叉苹果树题解

    二叉 多叉 有一棵苹果树,如果树枝有分叉,可以是分多叉,分叉数k>=0(就是说儿子的结点数大于等于0)这棵树共有N个结点(叶子点或者树枝分叉点),编号为1~N,树根编号一定是1.我们用一根树枝两 ...

  3. 如何在GitHub上上传自己的项目

    此文为转载,地址:https://blog.csdn.net/m0_37725003/article/details/80904824 本文链接:https://blog.csdn.net/m0_37 ...

  4. Spring的事件监听机制

    最近公司在重构广告系统,其中核心的打包功能由广告系统调用,即对apk打包的调用和打包完成之后的回调,需要提供相应的接口给广告系统.因此,为了将apk打包的核心流程和对接广告系统的业务解耦,利用了spr ...

  5. 【Offer】[56-1] 【数组中只出现一次的两个数字】

    题目描述 思路分析 测试用例 Java代码 代码链接 题目描述 一个整型数组里除两个数字之外,其他数字都出现了两次.请写程序找出这两个只出现一次的数字.要求时间复杂度是O(n),空间复杂度是0(1). ...

  6. Salesforce LWC学习(七) Navigation & Toast

    上一篇我们介绍了针对LWC中常用的LDS的适配的wire service以及@salesforce模块提供的相关的service,其实LWC中还提供其他的好用的service,比如针对导航相关的lig ...

  7. SpringCloud入门[转]

    原文链接 一.  网站的架构演变    网络架构由最开始的三层mvc渐渐演变.传统的三层架构后来在互联网公司让几百人几千人同时开发一个项目已经变得不可行,并且会产生代码冲突的问题.基于SOA面向服务开 ...

  8. Mybatis打印SQL

    配置mybatis日志级别,打印SQL 1.方案一:配置日志级别 logging.level.org.springboot.demo.mapper=debug 其中org.springboot.dem ...

  9. Winform中怎样根据Name获取同窗体的控件

    场景 在同一个Winform窗体中,点击一个Button按钮时, 获取同窗体的其他控件的属性. 首先需要对要获取的控件赋予Name属性,然后就可以通过Name进行获取. 实现 在Button的点击事件 ...

  10. All Of ACM

    数据结构和算法专栏,我会什么写什么  = = 不定时更新 一.数据结构 树状数组详解 线段树详解 二.算法 KMP算法 三.板子 我的代码模板 大整数模板 四.题解报告 几道STL题目(FJUT - ...