BlueprintCallable,使C++中的函数在蓝图中能被调用,新建C++类CustomActor继承AActor,并分别声明public、protected、private方法:
data:image/s3,"s3://crabby-images/ee46f/ee46fe01c81cfa35f1fe5b152018a48d44d0b0e4" alt=""
拖拽一个CustomActor到Map中,打开关卡蓝图,可以到无法在蓝图中调出C++中的方法:
data:image/s3,"s3://crabby-images/da037/da03719f43987e236b44de33e52c13d7e055578e" alt=""
data:image/s3,"s3://crabby-images/b23df/b23dfaa43f3468381e5d8ddf200c96e35d6b1431" alt=""
data:image/s3,"s3://crabby-images/0c6df/0c6df6e46dd8133849e9e67f4a2f559fcf2ed9d7" alt=""
我们为这三个方法添加BlueprintCallable标记:
data:image/s3,"s3://crabby-images/14770/1477074bb291a55f7f4f52ad27805da456083b1d" alt=""
然后在蓝图中调用:
data:image/s3,"s3://crabby-images/f86b7/f86b77fcd8a337f7d2a858a96ac5422a16d7630b" alt=""
可以发现,只要添加了BlueprintCallable标记,不管是private、protected还是public的函数,统统能在蓝图中调用!
静态成员函数在蓝图中不需要通过实例对象就能调用。在C++中声明Custom的静态函数CustomActorStaticMethod,并添加BlueprintCallable标记:
data:image/s3,"s3://crabby-images/08e4f/08e4f018fa9707b0b729fb168a707d2a0f6bfd78" alt=""
data:image/s3,"s3://crabby-images/73369/73369aa3d5afe75156cc476f949ee507c58ee233" alt=""
data:image/s3,"s3://crabby-images/58b51/58b516867484e9b544d9e3860f89db39ba8edd1f" alt=""
data:image/s3,"s3://crabby-images/ef8a1/ef8a1f230251f049381f0c64d2a45c0a797ee0b2" alt=""
可以看到,不需要CustomActor的实例就能在蓝图中调用它的静态函数。
函数的普通参数、引用参数、常量引用参数、指针参数在蓝图表现形式。给CustomActorMethod方法添加int、int&、const int&、AActor*参数,并在蓝图中调用:
data:image/s3,"s3://crabby-images/21467/214677c3aeec28d40d20f8843d191c4c9de821dc" alt=""
data:image/s3,"s3://crabby-images/8538a/8538a94c29c4e76b80d859ea896a8c2fd8a66b6f" alt=""
可以看到,普通参数作为输入引脚,可以在引脚中自定义参数值;引用参数会变成返回值引脚;常引用参数也是输入引脚,不过必须通过另一个变量传入:
data:image/s3,"s3://crabby-images/fef39/fef3994b6a9de18e898678963de75548410d776d" alt=""
指针参数也是一个输入引脚。
Category,可以给函数添加在蓝图中的分类。给CustomActorMethod添加标记:Catagory="One|Two|Three":
data:image/s3,"s3://crabby-images/62d2e/62d2ecd25d7482728a59cad48fe023c478978199" alt=""
data:image/s3,"s3://crabby-images/96f5e/96f5e52d785ad9328272618ff319f22e1262f68f" alt=""
可以看到,通过"|"来划分层级结构,实现给函数分类。
BlueprintImplementableEvent,使函数仅在蓝图中定义。给CustomActorMethod添加BlueprintImplementableEvent标记:
data:image/s3,"s3://crabby-images/d662c/d662c342cb6c3cfdcb04cb845a85c194fa59e0ce" alt=""
新建一个蓝图类继承CustomActor:
data:image/s3,"s3://crabby-images/aa4ab/aa4abf08a89a3cae4aa59ce1bef8e20750abb848" alt=""
在蓝图中查找CustomActorMethod:
data:image/s3,"s3://crabby-images/b6061/b6061b63e6d74da49c5f4507be28f448b4832a5c" alt=""
data:image/s3,"s3://crabby-images/af317/af317186dc0fbbc19f09360a69ee1938f565ac4c" alt=""
可以发现通过这个标记,能以事件的形式在蓝图中定义函数要执行的逻辑。当函数有返回值时,蓝图中可override重写这个函数:
data:image/s3,"s3://crabby-images/bbd7c/bbd7c964a7fe3d125753cbb811e8ee6ae4377e7d" alt=""
data:image/s3,"s3://crabby-images/3bfed/3bfed6786f6f6dd3294650b48270dcf963c407fb" alt=""
而且BlueprintImplementableEvent标记的函数不能在C++中定义,否则编译会报错。
BlueprintNativeEvent,这个标记功能和BlueprintImplementableEvent基本上一样,不过它的函数需要在C++中定义,蓝图类可以选择不重写:
data:image/s3,"s3://crabby-images/d2c96/d2c969baeaeb95a8f0a30a2cc470a9ecb7a8bdd8" alt=""
data:image/s3,"s3://crabby-images/539fb/539fbc772d6ee110a0c999ceb4ff52a870a975b4" alt=""
需要注意的是,C++中定义函数时,需要额外声明并定义"函数名_Implementation"函数,这个函数的实现就是调用原函数时执行的逻辑。
BlueprintPure,函数作为纯函数使用,不需要流程引脚,一定要有返回值:
data:image/s3,"s3://crabby-images/aa292/aa292723619b69c1be56e60e9db4538f48dcd68b" alt=""
data:image/s3,"s3://crabby-images/3737a/3737a4518bc72a4d6f870851d196de60e67b8027" alt=""
data:image/s3,"s3://crabby-images/c11d0/c11d0e0a262113619f4b687b9f0a14509d077e5f" alt=""
data:image/s3,"s3://crabby-images/da24e/da24e71de3de51e0c383195fb9ba050b42ccfbfb" alt=""
const函数拥有返回值时在蓝图中的形式和纯函数相似:
data:image/s3,"s3://crabby-images/9cf37/9cf3757b1c354c85bffa764696b39efd4548a12d" alt=""
data:image/s3,"s3://crabby-images/b4490/b4490d8803832f195e9804d78e4082444cc6b8e3" alt=""
没有返回值的时候还是需要连接流程引脚的:
data:image/s3,"s3://crabby-images/290d3/290d3b8c648ed26929eb23a7779dab2a7408a5ac" alt=""
data:image/s3,"s3://crabby-images/33f55/33f550ed683fa9e0b9669f2f9ecda46500fba986" alt=""