游戏地形

在游戏的世界中,必然会有非常多丰富多彩的游戏元素融合当中。

它们种类繁多。作用也不大同样。一般对于游戏元素可分为两种:经经常使用。不经经常使用。经常使用的元素是游戏中比較重要的元素。一般须要使用脚本来实现某些特殊功能。比方:玩家控制的主角对象,须要攻击的敌人等。

因此经常使用的元素直接影响游戏的执行,而不常有的元素。比方说游戏里的天空,云朵等。不影响游戏的主线。只提升游戏的总体效果。

创建地形

在3D游戏里,常常会出现起伏的地形。

本文变总结回想下怎样在游戏里创建游戏地形。

首先在导航菜单条里选择Terrain----Create Terrain创建一个游戏地形。出现入选图:

(经过我旋转拉近后的,方便更加直观的观看)

地形參数

地形參数包含地形的宽度,高度,长度,分辨率,高度图等。创建完地形后。便能够随意的改动它们。在导航菜单里选择Terrain----Set Resolution后,弹出Heightmap resoluton窗体。直接输入改动就可以。

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvdTAxMzI4OTE4OA==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">

简单的介绍下Heightmap resoluton窗体中的參数:

Terrain Width:地形总宽度

Terrain Height:地形总高度

Terrain Length:地形总长度

Heightmap resoluton:地形高度图的分辨率

Detail Resolution:细节分辨率,主要用于地形上的草或者其它模型。其数值越高,显示效果越好。当然同一时候也须要越高的机器配置。

Detail Resolution per patch:细节分辨率补丁

Control Texture Resolution :控制贴图分辨率

Base Texture Resolution :相对贴图分辨率

编辑地形

到如今为止,我们的地形还仅仅是一个巨大的平面。

要实现起伏的效果,首先在hierarchy视图中,选择Terrain 。此时会在右側的inspector视图中来编辑地形。

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvdTAxMzI4OTE4OA==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" width="262" height="600" alt="">

在地形菜单中有起个button:

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvdTAxMzI4OTE4OA==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">

他们的含义分别为:编辑地形高度。编辑地形特定高度,平滑过度地形。地形贴图,加入树模型,加入草与网格模型,其它设置。

接着以下便是地形画笔:

brush size:画笔宽度取值范围

Opacity:画笔高度的取值范围

选择地形菜单和画笔后,便能够编辑地形的起伏了。

只是由于地形贴图默认是灰色,故会很的难看。

在地形菜单中点击第二个button(编辑地形特定高度),此时打开设置地形特定高度页面。与先前的页面一样,仅仅是多了一个Height:

在编辑地形高度页面中,Opacity:是最大高度。而在编辑特定高度页面,Height才是最大高度。比方在编辑特定高度页面,Opacity的值是100。而Height的值是80,那么地形最高为80

例如以下图。在地形菜单中点击第三个button(平滑过渡地形),然后选择一个适合的画笔,接着就能够平滑过度地形了。

平滑后的地形图:

每当创建完地形后,系统都会自己主动的将Terrain  Collider(地形碰撞)组件加入到地形中。该组件能够让地形感应与其它物体之间的碰撞。

给地形表皮一个物理材质后。地形上的物体将依据设置的碰撞參数而发生碰撞,比方说:弹力,动力。摩擦力等。

Material:物理材质,设置模型与地形碰撞后的物理摩擦效果

is trigger:是否开启地形碰撞

Terrain  data:地形资源。连接project视图中的地形文件

create tree colliders:是否创建树木碰撞

地形贴图

系统默认的灰色地形实在是不可恭维。

在实际中。为了让地形看起来更加美观。unity提供了地形标准资源包。首先我们须要将地形资源包导入当前的工程中。在project视图中点击鼠标右键,选择import-----Terrain  Assets。

导入后。学习怎么给地形加入新的贴图。首先在地形菜单条中点击第四个button(地形贴图),可发现眼下在Textures列表中没有不论什么地形贴图。点击右下角edit---textures(编辑贴图)。将弹出一个选择列表。

在选择列表中。选择add Textures选项。将会出现下图左边窗体。

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvdTAxMzI4OTE4OA==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">

先简要说明下各參数意义:

texture:在资源目录中选择一张地形贴图

normal map:在资源目录中选择一张正常地形贴图

size x:贴图x轴宽度

size y:贴图y轴宽度

offset x:贴图x轴偏移量

offset y:贴图y轴偏移量

点击texture中的select,将弹出select texture2D窗体,该页面全部的贴图文件都源于project视图中的目录。

然后在select texture2D窗体中选择随意贴图双击,然后在add terrain Textures窗体中右下角点击add就可以.

在加入地形贴图后,就能够渲染贴图了。首先选择一个渲染的贴图目录。然后选择一个渲染笔。最后直接在scene视图中渲染即可了。

【Unity 3D】学习笔记三十:游戏元素——游戏地形的更多相关文章

  1. 【Unity 3D】学习笔记三十五:游戏实例——摄像机切换镜头

    摄像机切换镜头 在游戏中常常会切换摄像机来观察某一个游戏对象,能够说.在3D游戏开发中,摄像头的切换是不可或缺的. 这次我们学习总结下摄像机怎么切换镜头. 代码: private var Camera ...

  2. angular学习笔记(三十)-指令(10)-require和controller

    本篇介绍指令的最后两个属性,require和controller 当一个指令需要和父元素指令进行通信的时候,它们就会用到这两个属性,什么意思还是要看栗子: html: <outer‐direct ...

  3. angular学习笔记(三十)-指令(7)-compile和link(2)

    继续上一篇:angular学习笔记(三十)-指令(7)-compile和link(1) 上一篇讲了compile函数的基本概念,接下来详细讲解compile和link的执行顺序. 看一段三个指令嵌套的 ...

  4. angular学习笔记(三十)-指令(7)-compile和link(1)

    这篇主要讲解指令中的compile,以及它和link的微妙的关系. link函数在之前已经讲过了,而compile函数,它和link函数是不能共存的,如果定义了compile属性又定义link属性,那 ...

  5. angular学习笔记(三十)-指令(6)-transclude()方法(又称linker()方法)-模拟ng-repeat指令

    在angular学习笔记(三十)-指令(4)-transclude文章的末尾提到了,如果在指令中需要反复使用被嵌套的那一坨,需要使用transclude()方法. 在angular学习笔记(三十)-指 ...

  6. angular学习笔记(三十)-指令(5)-link

    这篇主要介绍angular指令中的link属性: link:function(scope,iEle,iAttrs,ctrl,linker){ .... } link属性值为一个函数,这个函数有五个参数 ...

  7. angular学习笔记(三十)-指令(2)-restrice,replace,template

    本篇主要讲解指令中的 restrict属性, replace属性, template属性 这三个属性 一. restrict: 字符串.定义指令在视图中的使用方式,一共有四种使用方式: 1. 元素: ...

  8. angular学习笔记(三十)-指令(1)-概述

    之前在 angular学习笔记(十九)-指令修改dom 里面已经简单的提到了angular中的指令,现在来详细的介绍 '指令' 一.指令的创建: dirAppModule.directive('dir ...

  9. 【Unity 3D】学习笔记三十八:角色控制器

    角色控制器 在unity中,已经帮我们实现的上下左右跳等动作,并将他们封装成了角色控制器.角色控制器保存在unity标准资源包中,能够说是很的强大.能够模拟第一或者第三人称视角.不受刚体的限制,很适用 ...

随机推荐

  1. Spring Boot学习——Controller的使用

    本文主要记录几个注释的使用方法. 1. @Controller : 处理http请求 2. @RequestMapping : 配置URL映射 3. @RestController : 组合注解,sp ...

  2. OSX 系统无法直接用 Chrome 双击点击打开本地 html 文件

    在 Mac OS X 下,文件经常会被附加上 OS X 特有的扩展属性 ( extend attributes ),具体表现是用 ls -l 查看时会有 @ 的标记,譬如: $ ls -l index ...

  3. nodejs编写实例基础操作

    学习视频地址 https://cnodejs.org/topic/5a72c66ace45d440451465c3   初始化项目 首先查看项目中是否有package.json 文件,如果有可执行np ...

  4. iOS使用MD5 - 字符串加密至MD5&获取文件MD5

    iOS 字符串加密至MD5 + (NSString *) md5:(NSString *)str { unsigned ]; CC_MD5( cStr, strlen(cStr), result ); ...

  5. 【ecplise】快捷键 集合

    1.查看本方法在哪里被调用过 光标放在本方法名上 快捷键: Ctrl+Shift+G

  6. js 日期计算星座 根据生日的月份和日期,一行代码计算星座的js小函数(转)

    本博客根据 开源中国作者清风徐不来 的文章 根据生日的月份和日期,一行代码计算星座的js小函数(转) 原文出自CSDN 无心的专栏 的文章,知识产权归原文作者所有! 点击查看原文:js 日期计算星座

  7. selenium用法 (python)

    滑动到指定元素位置 browser.find_element_by_xpath("//font[text()='资产管理部经办人'][1]").location_once_scro ...

  8. CentOS7.0修改主机名(hostname)

    Linux中的hostname在大多数应用中至为重要,例如有些应用强制使用主机名称而不能使用IP地址,如果默认主机名称都为localhost.localdomain 的话那一定会出现问题,而且看起来也 ...

  9. mysql数据库查看各实例磁盘占用情况

    1.总体查看: use information_schema; select TABLE_SCHEMA, concat(truncate(sum(data_length)/1024/1024,2),' ...

  10. Linux学习之十六-Linux用户管理

    Linux用户管理 Linux系统跟Windows系统一样,可以创建不同的用户,不同的用户组.在不同用户下使用系统具有相应的权限 创建一个普通用户时,会修改几个文件,拷贝一些初始文件到用户家目录中 修 ...