cocos2d-x 3.0 在C++中调用lua函数

代码用的是<cocos2d-x 3.0
在lua中调用自定义类
>中的代码.

在上篇的基础上进行扩充.

写lua函数

local function process_packet(user_data)
if user_data then
user_data = tolua.cast(user_data, "user_data");
print (user_data:uid());
print (user_data:uname());
end
end

local ghall = hall:get_singleton_ptr();
ScriptHandlerMgr:getInstance():registerScriptHandler(tolua.cast(ghall, "cc.Ref"), process_packet, cc.Handler.CALLFUNC);

在C++添加对此函数的调用

void hall::process_packet()
{
auto engine = cocos2d::LuaEngine::getInstance();

user_data ud("kukudi", 10001);
cocos2d::BasicScriptData scriptdata(this, &ud);
cocos2d::ScriptEvent eve(cocos2d::ScriptEventType::kCallFuncEvent, &scriptdata);
engine->sendEvent(&eve);
}

执行结果, 输出1001 kukudi

我遇到一些问题在此记录一下
1. user_data, 这个要传到lua函数中的数据对象必须继续自cocos2d::Ref类, (当然了,
继续自Ref的子类也可以的), 否则程序会崩溃, 因为在int LuaEngine::handleCallFuncActionEvent(void*
data)里面有这样一句话:Ref* target =
static_cast<Ref*>(basicScriptData->value);可以看出来, 它的父类必须是Ref类.
2.
user_data, 想要直接使用成员对象是不行的, 我之前将成员对象设置成public, 想在脚本中直接对成员对象直接操作,
后来发现lua_hall_auto.cpp文件中根本没有对这些成员对象进行转换, 所以得把它封装起来, 用成员函数对其成员对象进行操作.
3.
如果要调用多个脚本函数怎么办呢? 我发现cc.Handler.CALLFUNC只能指定一个脚本函数, 再指定其它的脚本函数必须得用另一个handletype值,
还有就是这个cc.Handler.CALLFUNC这个对象的脚本函数只能使用一个参数或者不使用参数, 关于这方面的应用我还没有研究很深, 就目前看来,
只能调用一个函数, 并且函数只能有一个参数, 这就够用了, 在此lua函数中做分支来分派给其它的脚本函数来处理数据,
至于传入到lua函数中的数据只要继承自Ref这个类, 多写几个不同的对象也是可以的, 这个没有什么大的问题;
4. 有一个比较困惑, int
ScriptHandlerMgr::getObjectHandler(void* object,ScriptHandlerMgr::HandlerType
handlerType)在这个函数, 每个lua_function对应一个唯一的handletype,
那为什么这个里面还要使用for循环来遍历呢? 为什么不将handletype & lua_function作map映射呢?

5. 在lua中调用tolua.cast(obj, "hall"); 转换成自定义的类型时会出现Cast name user_data doesn‘t
include modular name which it belongs to,please add the modular name这样的信息, 不用理它;
如果你跟踪源代码会发现像Ref这样的类是这样对应的Ref:cc.Ref, 我自己定义的类没有这些模块, 所以不用理它, 它也就是一个提示信息,
而已

时间: 2024-10-07 15:59:56

cocos2d-x 3.0 在C++中调用lua函数的相关文章

cocos2d-x 3.0 在C++中调用lua函数(2)

个人觉得3.0里面, 在C++下面调用lua函数很不方便, 所以就扩展了一个类, 继承自LuaStack, 代码和使用方式如下: #ifndef __CC_LUA_STACKEX_H_ #define __CC_LUA_STACKEX_H_ #include "CCLuaStack.h" NS_CC_BEGIN class LuaStackEx : public LuaStack { public: void call_script_fun(const char* fun) { exe

C中调用Lua函数

我们先来看一个简单的例子: lua_State* L = NULL; // 内部调用lua函数 double f(double x, double y) { double z; lua_getglobal(L, "f"); // 获取lua函数f lua_pushnumber(L, x); // 压入参数x和y lua_pushnumber(L, y); if(lua_pcall(L, 2, 1, 0) != 0) error(L, "error running functi

在C\C++中调用Lua

1.C\C++程序中调用Lua函数 方法一: #include "stdafx.h" #include <stdio.h> #include <string.h> #include <stdlib.h> #include "lua.hpp" const char* lua_function_code = "function dealStr(str) \   return string.gsub(str,\"Wo

在printf语句中调用day_name函数并把i值传送给形参n

本例中定义了一个指针型函数day_name,它的返回值指向一个字符串.该函数中定义了一个静态指针数组name.name数组初始化赋值为八个字符串,分别表示各个星期名及出错提示.形参n表示与星期名所对应的整数.在主函数中,把输入的整数i作为实参,在printf语句中调用day_name函数并把i值传送给形参n.day_name函数中的return语句包含一个条件表达式,n值若大于7或小于1则把name[0]指针返回主函数输出出错提示字符串"Illegal day".否则返回主函数输出对应

Lua中调用C函数

Lua利用一个虚拟的堆栈来给C传递值或从C获取值.每当Lua调用C函数,都会获得一个新的堆栈,该堆栈初始包含所有的调用C函数所需要的参数值(Lua传给C函数的调用实参),并且C函数执行完毕后,会把返回值压入这个栈(Lua从中拿到C函数调用结果). 于此相关的C API有几个比较重要的定义如下: (1)typedef struct lua_State lua_State; lua虚拟机(或叫解释器),可以理解为一个thread,和一个完整的Lua虚拟环境的执行状态. (2)typedef int

C语言中调用Lua

C语言和Lua天生有两大隔阂: 一.C语言是静态数据类型,Lua是动态数据类型 二.C语言需要程序员管理内存,Lua自动管理内存 为了跨越世俗走到一起,肯定需要解决方案. 解决第一点看上去比较容易,C语言中有union. 可是第二点呢?万一C语言正引用着Lua的一个值,Lua自动释放了怎么办? 所以就有了一种比union更好的解决方案:栈. 这是一个虚拟的栈,是沟通两者的桥梁,两者的数据交换全都通过这个栈进行,这样只要不pop,Lua就不会自动释放,而什么时候pop由C语言说了算. 下面是一段喜

Lua中调用C函数(lua-5.2.3)

Lua可以调用C函数的能力将极大的提高Lua的可扩展性和可用性. 对于有些和操作系统相关的功能,或者是对效率要求较高的模块,我们完全可以通过C函数来实现,之后再通过Lua调用指定的C函数. 对于那些可被Lua调用的C函数而言,其接口必须遵循Lua要求的形式,即typedef int (*lua_CFunction)(lua_State* L). 简单说明一下,该函数类型仅仅包含一个表示Lua环境的指针作为其唯一的参数,实现者可以通过该指针进一步获取Lua代码中实际传入的参数.返回值是整型,表示该

EC笔记,第二部分:9.不在构造、析构函数中调用虚函数

9.不在构造.析构函数中调用虚函数 1.在构造函数和析构函数中调用虚函数会产生什么结果呢? #include <iostream> using namespace std; class cls1{ public: cls1(){ newMake(); }; ~cls1(){ deleteIt(); }; virtual void newMake(){ cout<<"cls1 make"<<endl; } virtual void deleteIt()

在COM组件中调用JS函数

要求是很简单的,即有COM组件A在IE中运行,使用JavaScript(JS)调用A的方法longCalc(),该方法是一个耗时的操作,要求通知IE当前的进度.这就要求使用回调函数,设其名称为scriptCallbackFunc.实现这个技术很简单: 1 .组件方(C++) 组件A 的方法在IDL中定义: [id(2)] HRESULT longCalc([in] DOUBLE v1, [in] DOUBLE v2, [in, optional] VARIANT scriptCallback);