data:image/s3,"s3://crabby-images/ff789/ff789db2561e3566638f833502dade2f33cc34fd" alt="ad372f0ad9175d1d73912194cb8ff98d.png"
在上一次的分享中我们介绍unreal中的python使用,此处应该有链接Python | Unreal中的python开发,今天我们来实际操作在引擎里面试用一下。
首先我们来实现一个简单的小功能,用python将外部的文件导入到引擎。虽然在实际操作中这一步骤很简单,但是我们可以由此熟悉一下unreal中的Python API。
首先在unreal中打开之前安装的python Editor,然后新建一个PythonScript文件.
首先输入import unreal可调用unreal中的函数,然后是import os指输入输出文件。
data:image/s3,"s3://crabby-images/e59fb/e59fbc6313bc580d0bcf776507966aa1ed943dbf" alt="6c438b8de67db2d9094b663a927066f6.png"
然后定义一张我们需要导入的图片文件,最好使用绝对路径,因为相对路径的话unreal python默认加载的是引擎安装目录的位置,而不是项目的位置,所以大可不必用相对路径。注意路径的斜杠是反的。
texture = 'D:/test/python_unreal.tga'
接着我们需要创建一个函数ImportTask来定义我们的导入task。这样我们就可以在后面的程序中直接调用函数ImportTask来为我们的texture创建一个导入task。
def importTask(filename,destination_path):
task = unreal.AssetImportTask()
task.set_editor_property('automated', True)
task.set_editor_property('destination_name', '')
task.set_editor_property('destination_path', destination_path)
task.set_editor_property('filename',filename)
task.set_editor_property('replace_existing', True)
task.set_editor_property('save', True)
return task
首先以上代码中,我们给importTask两个参数,filename只要执行导入任务的文件名字,destination_path指导入进去以后的文件放在哪里。接着用unreal python的一个函数AssetImportTask来赋值task,这样就可以在后面直接调用task来给任务设置属性。对于AssetImportTask这个unreal python内部的函数
下面的set_editor_property都是在设置任务属性,比如atomated就是是否要在导入的时候发生一些已存在的覆盖等状况要不要弹出来对话框,Ture就表示avoid dialog不弹出对话框。destination_name导入进去的文件名字,后面引号为空表示默认为文件原本的名字,即导入进去不重命名;destination_path指导入进去放的位置,在调用importTask的时候可以进行设置;filename,导入之前的文件名;replace_existing,导入进去的时候要不要覆盖原有的文件;save指的是导入进去以后要不要直接保存。
属性设置完成以后将task输出以方便其他函数的调用。
data:image/s3,"s3://crabby-images/3d0fe/3d0fe87f8b12d20dcef4017907459c1a848f20f8" alt="32116a7901bf44e13e8e0057f1d7cf1d.png"
Task的属性设置好了以后,我们需要一个函数来执行这个task,所以就有了接下来的执行函数executeImportTask
def executeImportTasks(tasks):
unreal.AssetToolsHelpers.get_asset_tools().import_asset_tasks(tasks)
tasks表示可以有多个任务,在调用的时候可以用中括号[,]将任务都当做列表括起来,这样在调用的时候就可以挨个调用。
大致就是使用了AssetToolsHelpers这个类下面的函数get_asset_tools,就得到了unreal里面的asset工具AssetTools,
data:image/s3,"s3://crabby-images/73df7/73df761ee185f5b49b00d7f94e633bc36285f6c6" alt="5d551d0f2db2336cee50516ca0c57dc6.png"
然后再用asset工具调用了里面的函数import_asset_tasks.
按照import_asset_tasks的说明,需要把一个tasks列表传入进来,所以如果有多个导入任务的话就可以一起导入。
data:image/s3,"s3://crabby-images/83165/83165c81ae0c9b51639a600058e9f523107711ef" alt="437cc25ce59974fc4eb9fb8ebffc6676.png"
最后,我们需要有一个函数来同时调用importTask和executeImportTasks函数,定义函数importMyAssets,然后把importTask的返回值给texture_task,作为executeImportTasks的输入参数。
def importMyAssets():
texture_task = ImportTask(texture, '/Game/Textures')
executeImportTasks([texture_task])
导入进去以后的路径/Game/Textures表示将导入进来的图片放在Content文件夹下面新创建的textures文件夹下。
最后调用函数importMyAssets()
完整代码如下:
data:image/s3,"s3://crabby-images/2ff7d/2ff7d9c0478968cbb8c018c808480b7e1fef29cf" alt="75d08d933a8be55685f34e51054a9a0f.png"
然后点击运行,就可以在我们的内容浏览器上面看到多出的叫做Textures的文件夹以及里面的贴图文件python_unreal.tga
data:image/s3,"s3://crabby-images/2b321/2b321e219d46809f7c504ab586cf6116ff94cba9" alt="3f2f70b6b39cde2025b285530f741c0a.png"
后续我们还可以按照这种格式导入批量的mesh或者其他音频文件等。
- End -