本文主要是介绍【UE4 RTS游戏】10-建筑跟随鼠标移动,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
效果
步骤
将“CameraPawnController”的事件图表中的如下节点进行剪切
data:image/s3,"s3://crabby-images/a8eea/a8eea598375ca4fa52a8ddd0a6eebdecf18778c2" alt=""
粘贴到“GhostBuilding_BP”中
data:image/s3,"s3://crabby-images/5a5aa/5a5aaa65cb3144daeb5b1a1d498dd210c06e41ed" alt=""
添加“I_HUD”接口
data:image/s3,"s3://crabby-images/f0b1e/f0b1e562aa4b3d35412be5a55f05aeab11149313" alt=""
重新添加如下标注的节点
data:image/s3,"s3://crabby-images/d30fd/d30fdd7421dc66aa5197578b7650f0ebe815ee8d" alt=""
打开“MainUI_HUD”,添加一个变量,命名为“GhostBuildingRef”
data:image/s3,"s3://crabby-images/54fb6/54fb6af98757de636240d400bd411e9904cfc90d" alt=""
细节如下:
data:image/s3,"s3://crabby-images/21a4d/21a4db5b6a0864beec21e5339f24f2c0c36dfbfe" alt=""
将事件图表中的“ControllerRef”替换为“GhostBuildingRef”
data:image/s3,"s3://crabby-images/38fd6/38fd6394de5956c4183e10b1169c1a1454f29580" alt=""
打开“CameraPawnController”的宏“CreateHUDs”,由于在“MainUI_HUD”添加了一个公开的变量,因此在使用“MainUI_HUD”时将“GhostBuildingRef”传入。
data:image/s3,"s3://crabby-images/bbb20/bbb20a809e334bf83d76b2ca7bb58ad2bd93df37" alt=""
在“CameraPawnController”的事件图表中将序列引脚“Then 1”后的所有节点移至引脚“Then3”,之前“Then 2”、“Then 3”引脚后的节点移至“Then 1”、“Then 2”
data:image/s3,"s3://crabby-images/e0f52/e0f526ba2ec53225ce5c3793d3d2c7a035e0baf0" alt=""
data:image/s3,"s3://crabby-images/5461a/5461adbf0424da2eea8e4d864e661fce9a216640" alt=""
此时运行游戏点击按钮查看是否能成功生成建筑:
data:image/s3,"s3://crabby-images/fb1a3/fb1a3be368b0f9082c085a67315b9f7920f04ab4" alt=""
接下来我们希望实现在鼠标点击的位置来生成建筑的功能
在“CameraPawnController”的事件图表中添加一个布尔型变量,命名为“BuildModeActive”
data:image/s3,"s3://crabby-images/f8a32/f8a32974e1a9f19523df0bfeede24c7ebd3f3ed6" alt=""
先创建如下节点:
data:image/s3,"s3://crabby-images/b219d/b219d2e2f4a3f91bfc6f000a92a01c0303e41bac" alt=""
新建一个文件夹命名为“Library”
data:image/s3,"s3://crabby-images/927fe/927fe1fc535c486cf35f69a290c60eec47643671" alt=""
新建一个蓝图函数库
data:image/s3,"s3://crabby-images/f5d80/f5d80146f6c388cfbdb683487ecb1d47367e0198" alt=""
命名为“FunctionLibrary”
data:image/s3,"s3://crabby-images/a8d71/a8d71c236ba5fea1f3e6b1344c4b964bd36d9647" alt=""
打开“FunctionLibrary”,将默认函数命名为“SetCursorWorldPosition”,该函数的功能就是计算出建筑生成的位置坐标
data:image/s3,"s3://crabby-images/6c5c5/6c5c52ed6b10ae939a5c59b8ff9795ee92fc6a03" alt=""
添加两个输入,一个命名为“Controller”,是CameraPawnController的对象引用;另一个是浮点类型,命名为“SightDistance”
data:image/s3,"s3://crabby-images/6d483/6d483163a2ad544576d082c1009159c586ebe28d" alt=""
再添加一个输出,命名为“Location”,类型为向量
data:image/s3,"s3://crabby-images/652f7/652f764a63f521add9bb160e188e5b0b04a87be4" alt=""
添加如下节点:
data:image/s3,"s3://crabby-images/4aa79/4aa79648151ef1bfea8db904ff9c90da7d57712e" alt=""
打开项目设置,点击新建追踪通道
data:image/s3,"s3://crabby-images/a8c43/a8c43bbadd17cea19a3ed69c361337f3abbef302" alt=""
新通道命名为“Landscape”,默认响应为Ignore
data:image/s3,"s3://crabby-images/eb032/eb0329d37e625a6bb20d6b4f153efe4e7b52ef38" alt=""
在世界大纲中选中“Landscape”,碰撞预设改为“Custom”
data:image/s3,"s3://crabby-images/efc64/efc64a4aec360852c8cc4c1f99898371c8e2aa9a" alt=""
再次打开“FunctionLibrary”,由通道追踪线条节点的 Trace Channel选择“Landscape”
data:image/s3,"s3://crabby-images/8ac0f/8ac0fac654657152b0b3302851a7585bd0062d6e" alt=""
继续完善:
data:image/s3,"s3://crabby-images/cf2df/cf2df48173f5edceac459efd75f6ae076d264809" alt=""
设置为纯函数
data:image/s3,"s3://crabby-images/db19e/db19eedd7394e3e99e23b3c98d1b11258da2f798" alt=""
再次打开“CameraPawnController”,添加一个新函数“SetSightDistance”
data:image/s3,"s3://crabby-images/fedb8/fedb80bb2deec5fa4ea047c0302292c77726ce5f" alt=""
添加一个浮点型变量,命名为“SightDistance”,默认值设为1000
data:image/s3,"s3://crabby-images/08575/08575821f4947069a45e5b6ebc9a3594e6d0d42c" alt=""
添加如下节点
data:image/s3,"s3://crabby-images/ea5f3/ea5f36f16d293a5421fb9862a9b9d6ffb474dd66" alt=""
打开“GhostBuilding_BP”,添加一个可编辑的变量,命名为“CursorWorldPosition”
data:image/s3,"s3://crabby-images/f20be/f20bed2923a9939234020bb70736a63adc27f843" alt=""
在“CameraPawnController”中添加如下节点
data:image/s3,"s3://crabby-images/ea134/ea134760d311933666d950451c2e2a4f69372188" alt=""
将如下选中的节点重叠到节点
data:image/s3,"s3://crabby-images/3e0d7/3e0d76d45e70cc16cd45cad360d0df5d1497cb7f" alt=""
命名为“SetCursorWorldPosition”
data:image/s3,"s3://crabby-images/10ac9/10ac9f73f15413732d005bf07f8a3c0faadeae35" alt=""
打开该重叠的节点,将结果连接至输出的节点
data:image/s3,"s3://crabby-images/39674/39674c8a7f54a5fa4bed78c05db0407552977d04" alt=""
打开“GhostBuilding_BP”,在事件图表中添加一个 事件tick 节点和两个自定义事件节点,两个自定义事件分别命名为“OpenTickGate”和“CloseTickGate”
data:image/s3,"s3://crabby-images/49aa6/49aa69c67512c9a32b0ddb8432c10c9a971cc96d" alt=""
创建如下节点:
data:image/s3,"s3://crabby-images/5539c/5539cf12e287eb56db5139f8f6bc08584f27b5d4" alt=""
打开“FunctionLibrary”,新添加一个函数,命名为“GridSnap”
data:image/s3,"s3://crabby-images/2e022/2e02205a82ebe9551247f9cf75c1d6684c762b53" alt=""
在该函数内部添加如下节点
data:image/s3,"s3://crabby-images/d4751/d4751a80183ec2c839c249d035018981e7391f4a" alt=""
设置为纯函数:
data:image/s3,"s3://crabby-images/807dc/807dcd1dbf7cc2308d1381a709b3a122f2d3c61d" alt=""
回到“GhostBuilding_BP”添加一个新函数,命名为“SetGridSnapVector”
data:image/s3,"s3://crabby-images/f7913/f7913e1fef32d9be1aa5f7ebce383fe29e90aa28" alt=""
创建一个浮点型变量,命名为“GridSize”,默认值为50
data:image/s3,"s3://crabby-images/2986b/2986b6c9ce3bbe439796b5c1b082785c63b3ee86" alt=""
在函数内部做如下操作:
data:image/s3,"s3://crabby-images/decca/decca4a34df2a0d9d7655a13dd8b6ad3ce2932bf" alt=""
data:image/s3,"s3://crabby-images/9d2bd/9d2bdb9d339c5e1653ec82b90bf0341aeb82a5bd" alt=""
设置为纯函数
data:image/s3,"s3://crabby-images/3c550/3c550de25a55d854b9065c60a80d397b97c5fdab" alt=""
在事件图表中继续完善如下节点
data:image/s3,"s3://crabby-images/bf5f8/bf5f855ad9651c7b05d6e392d2ec196d23cca0a5" alt=""
当执行“OnSpawn”事件时,执行“OpenTickGate”
data:image/s3,"s3://crabby-images/7c9a1/7c9a16d763544402d3f30182345179aa657163b6" alt=""
data:image/s3,"s3://crabby-images/f0af2/f0af241c9e2d85056f5b812b72921374dcf1f5ee" alt=""
设置“BuildModeActive”为True
data:image/s3,"s3://crabby-images/1ebeb/1ebeb957d77810d47b5daafe1e4a9cb16faa592d" alt=""
当执行“KillGhost”事件时,执行“CloseTickGate”
data:image/s3,"s3://crabby-images/0faf3/0faf396e99630d9530d791aed657b83196e21fbf" alt=""
设置“BuildModeActive”为False
data:image/s3,"s3://crabby-images/d6f40/d6f406031fd8527245fe64ca601efe65a8b8f1a3" alt=""
在事件“ConstructBuilding”的相关逻辑中添加如下节点:
data:image/s3,"s3://crabby-images/f7e8d/f7e8dcaaf1b12b5025a9902064bb555e86c7824b" alt=""
此时可以看到如下效果:
创建一个“CommercialMaster_BP”的子蓝图类,命名为“ConstructionOffice_BP”
data:image/s3,"s3://crabby-images/cbc51/cbc51dfc58b660a49b33b72c569a612dc146e6ab" alt=""
打开“ConstructionOffice_BP”,在类默认值中的DisplayMesh一项选择一个网格体
data:image/s3,"s3://crabby-images/a6b19/a6b19427bbbdacdc41c9033f67758b99159734ac" alt=""
打开“MainUI_HUD”,在事件图表中MainBuilding选择“ConstructionOffice_BP”
data:image/s3,"s3://crabby-images/858ea/858ead8a3736bab2bb5b4f1d8411bbe4960e67f7" alt=""
在“GhostBuilding_BP”中选中“GhostBuilding_Mesh”,碰撞预设一项选择为“OverlapAll”
data:image/s3,"s3://crabby-images/e254d/e254de207ebfd12d855bdaeea7254931a54a9f34" alt=""
此时运行游戏效果如下:
data:image/s3,"s3://crabby-images/d3d1b/d3d1b314ff98e5109e592248f4d62d99d53acbf0" alt=""
在项目设置中,添加一个操作映射
data:image/s3,"s3://crabby-images/af6f1/af6f1a7ee44405058255939d6a921b90a118cebd" alt=""
在“CameraPawnController”的事件图表中添加如下节点:
data:image/s3,"s3://crabby-images/377e6/377e64530c3d10f630472ebe92382f64730b6447" alt=""
在“GhostBuilding_BP”中添加如下节点
data:image/s3,"s3://crabby-images/a76a1/a76a1743b7e3b53b6c20bc46035181d88b169589" alt=""
运行游戏,效果如文章开头所示。
这篇关于【UE4 RTS游戏】10-建筑跟随鼠标移动的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!