智慧城市美术效果Unity实现笔记流程:
参考 对标 效果图:
参考资料:
方案一:
方案二:
写实类-参考图:
(以上均为网络搜索效果,有落叶大师,以及其他优秀开发者效果图参考)
data:image/s3,"s3://crabby-images/4390c/4390ca744482f54d471fdb1aff4266334958e1cd" alt=""
data:image/s3,"s3://crabby-images/930e2/930e2d4b99247bf14c4118b99d0d6a36a7d399fc" alt=""
data:image/s3,"s3://crabby-images/0c224/0c224addb72166c2835e1c7d0e100851eeee4bdf" alt=""
data:image/s3,"s3://crabby-images/f61a6/f61a669bfcbc5dbf36eaf464fa939ab3e24cecb4" alt=""
data:image/s3,"s3://crabby-images/aab41/aab41da09e397e3b773a54396b0c5d98ff380deb" alt=""
data:image/s3,"s3://crabby-images/e778d/e778d56fc302e623136a3b9604183b170dcc4e91" alt=""
data:image/s3,"s3://crabby-images/baea0/baea0c34a5deade6b73fa641da099db7855587a2" alt=""
data:image/s3,"s3://crabby-images/132ca/132ca581a76ef211fc4e7262dc50f717f578e9f9" alt=""
data:image/s3,"s3://crabby-images/7b142/7b142f701096f8898bee4a2de87a7d8f02369e6c" alt=""
未来类-参考图:
data:image/s3,"s3://crabby-images/974f3/974f3f813bd5d2fc50f3d888bf2b6d0dc4ba810f" alt=""
data:image/s3,"s3://crabby-images/f2313/f2313e13e5b1eac5e451b080573480efd9f066b3" alt=""
data:image/s3,"s3://crabby-images/83269/83269be4664105d7dca7665742b152a33970f0c7" alt=""
data:image/s3,"s3://crabby-images/c82c4/c82c488a66bbe1212b99b4ad0d977c61a40edaef" alt=""
data:image/s3,"s3://crabby-images/a2a4e/a2a4ed8921e0f0750697e4424f4b927206d20e6b" alt=""
data:image/s3,"s3://crabby-images/a15d1/a15d116ae51f67e55fd231e4a9d74fca2107f71e" alt=""
data:image/s3,"s3://crabby-images/17a44/17a441b9f0246a46ad09a8a6f5f7bd83c4ddf64a" alt=""
data:image/s3,"s3://crabby-images/6548c/6548ce817221739ec33206af5e12ecba5fa2cbda" alt=""
如上图所示,智慧城市基本分为 这两个大类,偏写实风,偏未来风,也有互相结合的效果。
一、实现思路大纲:
data:image/s3,"s3://crabby-images/7f028/7f0286581d802a6457b057c5877b376e59dfd91a" alt=""
二、实操环节(方案1):
1、软件准备/环境配置:
1)、Blender软件安装:
软件官方下载地址/使用文档教程: Blender 3.5 参考手册 --- Blender Manual
2)、为Blender安装GIS插件:
Blender-GIS插件下载地址:
https://github.com/domlysz/BlenderGIS
Blender-GIS的安装参考视频:
iBlender中文版插件GIS 教程Blender GIS 插件Blender_哔哩哔哩_bilibili
这里我在安装过程中遇到了,缺少imageIO模组的问题 : "No imageIO module" 。也就是点击BaseMap之后,打印窗口提示错误信息,所以翻阅了Domlysz 为这个工具开启的**BlenderGIS问题反馈页** ,发现是安装插件后,因缺少.dll的文件引起的。
data:image/s3,"s3://crabby-images/601cd/601cd75bf55524369c3421e5d06a9b5d972bdfd4" alt=""
缺少的.dll文件,可以在这里下载。
data:image/s3,"s3://crabby-images/56f83/56f8349952a47768a29b2195ec488f9c24b09ea2" alt=""
data:image/s3,"s3://crabby-images/df4c3/df4c3988247492e1bd90257a5c90e71123d5d176" alt=""
(我是吧所有文件夹都下载下来了,防止因为缺少内容继续报错)。
.
下载后,需要复制到指定位置下,通常在这个位置下:
替换位置:
C:\Users\你的用户名 \AppData\Roaming\BlenderFoundation\Blender\ 3.5\scripts\addons\BlenderGIS-master \core\lib\imageio\resources\freeimage。
将压缩包解压后,找到freeimage的文件夹,整体复制后,替换掉原有文件夹即可。
data:image/s3,"s3://crabby-images/b623d/b623d9da0278fc0d4284680ac490e64e9816f93b" alt=""
如果中间没有 某个文件夹结构的话,自己新建一个即可。
2、获取GIS城市数据:
1)、注册OpenTopographyAPIKey:
进入网站后根据提示,进行注册即可,注意, 这个网站在注册过程中,需要注意IP地址 ,开始的时候我在电脑的IP下进行注册,区域 应是大陆IP, 邮箱收不到验证码, 后来换成在手机上选择非大陆地区 的科学入网后**,收到了验证码。**
data:image/s3,"s3://crabby-images/f4261/f4261d785f1189de15a5a574444ae5485401f47b" alt=""
复制API Key 到 下图 API key 文本框 中。
data:image/s3,"s3://crabby-images/1a130/1a13070b3fa7ab0cf7f3a9b9897c3dd978343d04" alt=""
2)、选择GIS下载区域:
在上述内容配置好后,重启Blender,并开启科学入网后,点击Basemap按钮,进行地图获取。
data:image/s3,"s3://crabby-images/552c7/552c7f8f5a591e376a06116d771139b184996814" alt=""
单机后,会出现以下窗口,红框框选部分OSM ,Bing ,Esri 经测试,是可用状态,Google选项,不知为何,始终是加载不出来任何数据的。
data:image/s3,"s3://crabby-images/80edf/80edfc5c53ad64b6635c7da4e26bc5ed4c32a377" alt=""
这里我们确定,选择Esri的地图数据,会出现下图界面。
data:image/s3,"s3://crabby-images/13151/131515ee80a274a2baabd92a3d73f5a1bbcd18f6" alt=""
快捷键G 获取地图位置,用拼音即可搜索,这里精度小一些设为12。
data:image/s3,"s3://crabby-images/4fbab/4fbaba96f0dc872c997faa159e69f4220c7c7a99" alt=""
定位到指定位置后,需要注意窗口范围不要过大,否则是无法工作的,会报数据太大的错,所以尽量控制城市区域范围。
快捷键E 裁切可视区域 ,裁切后,会发现GIS按钮重新出现了,开始进行下一步,生成,建筑,河流,公路等提供数据的内容。
data:image/s3,"s3://crabby-images/c3b1f/c3b1f903650bea616e1e97979d2efb0c211a9f53" alt=""
点击Get OMS按钮,开始下载载入上述数据。
data:image/s3,"s3://crabby-images/b55d2/b55d232539817cfbce02af426bb6e041ed136da0" alt=""
按住Shift + 鼠标左键,进行 填入数据加选。
data:image/s3,"s3://crabby-images/2ba54/2ba546ae484175f2cb5ae620c3261f9ae1be3fbb" alt=""
单击确定后,开始载入 数据,数据量根据每个地区所选不同,完整度也所不同,加载速度也不一样。
这里以北京城区数据为例,数据相对丰富。
data:image/s3,"s3://crabby-images/d3c6f/d3c6f94302dcfd79cadeab3f1879e198ef71eaea" alt=""
3)、设置地形高度:
点击选择地形对象,Get elevation获取地形高度。
data:image/s3,"s3://crabby-images/e0240/e02407e7880cab493b7294156eafdb20417fa01b" alt=""
这里选择第三个选项,其他选项经测试,没有明显效果。
data:image/s3,"s3://crabby-images/71bd3/71bd324dad15faf3bd1ca60b6c11e793586351cf" alt=""
确定后,根据真实地理情况,会生成地面的高度。
data:image/s3,"s3://crabby-images/bae0b/bae0b61b3f104c8164f8a4de306a0dbfe6124256" alt=""
3、非主区域/道路建筑贴图:
1)、建筑贴图指定:
1、环境天空贴图:
data:image/s3,"s3://crabby-images/62bb7/62bb7ec12ff46bbe52676326b8c888d3b38efe18" alt=""
选择一个全景图。
data:image/s3,"s3://crabby-images/7a665/7a6652d786eeb3922d4d9fd2ec1d1235890c0255" alt=""
选择全景图之后,在切换渲染模式为 **视图着色模式,**就可以看到 天空盒了。
data:image/s3,"s3://crabby-images/b924e/b924e3fa98878eb53ec69035b6f914c202030696" alt=""
2、白膜建筑贴图:
选择面:
1、编辑模式下,选择建筑白膜,并在 选择 >>选择相似 >>法向按钮,点击后会全选所有白模 建筑。
data:image/s3,"s3://crabby-images/d0397/d0397e2b05199a55ef170318971bcb171d1cba64" alt=""
data:image/s3,"s3://crabby-images/688ec/688ec4f6bead044587c720bfc002570bffe9cc97" alt=""
这个时候 Ctrl + i 进行反选,因为选中白模中墙面的面,才是主要目的,因为我们要对墙面 添加材质和贴图。
data:image/s3,"s3://crabby-images/cf074/cf07497b7b8f75f8f78844f3530b804dd061e93c" alt=""
创建材质,并赋贴图:
1、打开 材质编辑窗口:并新建一个材质球,为材质球命名。
data:image/s3,"s3://crabby-images/391bc/391bc8efb4913719d569462709e460bda8146020" alt=""
打开材质编辑窗口,为材质添加一个贴图。
data:image/s3,"s3://crabby-images/5653d/5653dfddd2153da866532a2e47be561de658bc43" alt=""
选择一张 建筑外立面的无缝贴图。
data:image/s3,"s3://crabby-images/be652/be6528aadd613cf781b950ac87798c163c198673" alt=""
选择UV分布方式:为 块面投影 并设置 UV 大小,这里设为15的精度。
(数小UV越大,数大UV越小) 这里实际可以小一些,因为要进unity中可以修改Telline的参数修改。
data:image/s3,"s3://crabby-images/61e47/61e473d7aec53d1ff6d4d43ea95891ed8b201e33" alt=""
但是这个时候我们发现,全部的楼都是一个贴图,看起来很别扭,那么Blender中可以通过面来随机选择一些对象,分别指定材质,进行不同楼不同材质的区分。
再次创建一个材质,并赋予其他楼层外立面贴图。
data:image/s3,"s3://crabby-images/fb2f8/fb2f8ef5e6f1aa0edcbca0f6726a54fd42408b5c" alt=""
data:image/s3,"s3://crabby-images/bc90d/bc90d02a2aa705cee2ba9b4f44adcb2e19a78191" alt=""
新建好几个不同建筑外立面材质后,按上面操作,指定不同贴图。
选择 >>随机选择 建筑外立面:随机选中个数,这里设为0.002.
data:image/s3,"s3://crabby-images/b8fce/b8fce9168986c79092c5963fc9d281d66d9c19da" alt=""
为选中部分模型,指定不同 外立面贴图。
data:image/s3,"s3://crabby-images/4d013/4d013eda4c9e32cf2677ec8cdaec68810561f7c5" alt=""
Shift+H可以孤立显示,配合材质替换多种建筑贴图。
2)、道路生成+贴图指定:
因道路数据原本就是线段,并不是模型,所以,需要先根据线,生成道路。
注意先切换为对象模式 ,快捷键 TAB.
data:image/s3,"s3://crabby-images/a112d/a112db218414fd4c9db62a8523586c80235a3fc9" alt=""
创建道路横截面:
Shift + A : 创建 曲线 >> Nurbs 曲线。
data:image/s3,"s3://crabby-images/3cea6/3cea68b5527e39c81cfe483af588fae5d5cc1702" alt=""
查看所选(快速定位) 快捷键 `
data:image/s3,"s3://crabby-images/e9f46/e9f46129fae8653348e67328524bb4e0e3fded39" alt=""
编辑模式下 ,快捷键V(设置控制柄类型) 切换为>>矢量.
data:image/s3,"s3://crabby-images/45c1e/45c1ef1805fcb00e024efc3354e28a36a447669f" alt=""
选中大纲视图中,选择heightway,然后 快捷键 鼠标右键 ,转换到>>曲线。
data:image/s3,"s3://crabby-images/e0e52/e0e52acc1bd33b707bdce95f311413814c39f4c7" alt=""
这时,工具栏会出现这个图标,选中highway,后,为几何数据 下,对象中,指定曲线。
这样的话,就有了宽度。
data:image/s3,"s3://crabby-images/5ba95/5ba95ff3b8491c6d2460d4fa27800f2b2ebad7cf" alt=""
选中曲线在物体属性 面板中,找到缩放X ,并调节参数,会发现 道路变宽了。
data:image/s3,"s3://crabby-images/3d78c/3d78c0b7455d73d7848d0ded93826a8d91451057" alt=""
为道路添加贴图:
选择曲线,新建一个材质球,并命名,为道路寻找一张 如下图类似的公路贴图。
data:image/s3,"s3://crabby-images/dc2a4/dc2a4249b3d90c5477c20675917c942820c7a70e" alt=""
指定后,选择highway,为路面添加材质贴图。
data:image/s3,"s3://crabby-images/10523/10523e15c904203669dab46d60cf08ccd5ae147b" alt=""
为路面指定材质。
data:image/s3,"s3://crabby-images/491ee/491eed9c5095d344fe4fb159cdd6b1c2bc192722" alt=""
这个时候就可以看到路面被赋予了公路的贴图。
data:image/s3,"s3://crabby-images/e796c/e796c08908e1ca9a2aaa068928433d9a63a9ac78" alt=""
当然这里可以看到 贴图有拉伸,可以在这个窗口来修改UV拉伸状况。
data:image/s3,"s3://crabby-images/8d529/8d52911af1ec586853224ff5156198c411cee5bd" alt=""
data:image/s3,"s3://crabby-images/65ec8/65ec8987aee32088184810df7389a4d63315e3a3" alt=""
可以明显看到中间的差别。
那么以上,就是Blender中全部的处理内容,结下来,选中需要导出的网格模型,导出FBX即可导入到Unity中,开始在Unity中处理效果。