Update StarRenderingLuaBindings.cpp
This commit is contained in:
parent
1a0bf768f0
commit
f7dc97965d
@ -1,6 +1,8 @@
|
||||
#include "StarRenderingLuaBindings.hpp"
|
||||
#include "StarJsonExtra.hpp"
|
||||
#include "StarLuaConverters.hpp"
|
||||
#include "StarClientApplication.hpp"
|
||||
#include "StarRenderer.hpp"
|
||||
|
||||
namespace Star {
|
||||
|
||||
@ -11,9 +13,31 @@ LuaCallbacks LuaBindings::makeRenderingCallbacks(ClientApplication* app) {
|
||||
callbacks.registerCallbackWithSignature<void, String, bool, Maybe<bool>>("setPostProcessGroupEnabled", bind(mem_fn(&ClientApplication::setPostProcessGroupEnabled), app, _1, _2, _3));
|
||||
callbacks.registerCallbackWithSignature<bool, String>("postProcessGroupEnabled", bind(mem_fn(&ClientApplication::postProcessGroupEnabled), app, _1));
|
||||
|
||||
|
||||
// not entirely necessary (root.assetJson can achieve the same purpose) but may as well
|
||||
callbacks.registerCallbackWithSignature<Json>("postProcessGroups", bind(mem_fn(&ClientApplication::postProcessGroups), app));
|
||||
|
||||
// typedef Variant<float, int, Vec2F, Vec3F, Vec4F, bool> RenderEffectParameter;
|
||||
// feel free to change this if there's a better way to do this
|
||||
// specifically checks if the effect parameter is an int since Lua prefers converting the values to floats
|
||||
callbacks.registerCallback("setEffectParameter", [app](String const& effectName, String const& effectParameter, RenderEffectParameter const& value) {
|
||||
auto renderer = app->renderer();
|
||||
auto mtype = renderer->getEffectScriptableParameterType(effectName, effectParameter);
|
||||
if (mtype) {
|
||||
auto type = mtype.value();
|
||||
if (type == 1 && value.is<float>()) {
|
||||
renderer->setEffectScriptableParameter(effectName, effectParameter, (int)value.get<float>());
|
||||
} else {
|
||||
renderer->setEffectScriptableParameter(effectName, effectParameter, value);
|
||||
}
|
||||
}
|
||||
});
|
||||
|
||||
callbacks.registerCallback("getEffectParameter", [app](String const& effectName, String const& effectParameter) {
|
||||
auto renderer = app->renderer();
|
||||
return renderer->getEffectScriptableParameter(effectName, effectParameter);
|
||||
});
|
||||
|
||||
return callbacks;
|
||||
}
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user