项目中lua(基础)
关于项目中lua任务(某些没弄懂,但lua上耗费时间有点长了不看了) 这段时间看了lua语法和项目中lua应用 1.在lua中注册c库,在lua5.2中好像都是注册c库,相当于在lua中定义一个table,key是函数名字,value是函数指针 m_spLuaState->RegLib("game", funcs); 2.加载项目中所有lua并执行 刚开始不知道那个dofile具有执行lua的功能,结果是返回0表示成功,执行lua就是执行其中定义的一些函数和全局变量(普通变量,表等) 这个过程后就可以使用lua中的变量了 3.然后上线发送玩家人物信息,这个地方不得不提任务存储方法,跟天龙差不多 //有一些技巧 /** * @brief 任务项 * @note * 自定义参数 m_uParam可保存当前任务的执行条件的进度: * e.g. 怪物A的杀敌数 * 怪物B的杀敌数... * 物品A的收集量 * 物品B的收集量... * */ struct RcvMissonItem { short m_nIsOccupy; ///< 此数组位是否已被占用 返回 0 -- 表示为空 可以用 ,1 -- 表示 已被占用 short m_nIsOnTrack; ///< 是否正在追踪 int m_nMissionID; ///< 任务Id( 0 ~ MAX_MISSION_COUNT) int m_ScriptId; ///< 脚本Id short m_nMissionType; ///< 任务类型 short m_nMissionState; ///< 任务执行状态 //这个主要是根据id去决定uParam的具体含义,在脚本中定义,如杀怪的个数和杀怪的bodyid unsigned int m_uParam[MAX_MISSION_PARAM_NUM]; ///< 自定义参数 /* m_SriptId用处: 1、比如本任务是杀怪任务,当怪物被杀后,判断本任务类型是否是杀怪任务 如果是,并且此怪物携带的被杀任务标记中任务Id是当前任务Id,则需执行奖励脚本; 2、可有由脚本Id去决定m_uParam的具体参数实意; */ bool IsInvaild() { return m_nIsOccupy == 0; } }; struct MissionInfo_New { int m_nMissionCount; ///< 已接受的任务数量 int m_nCurMainThreadId; ///< 正在执行的主线任务Id int m_nCurBtanchThreadId; ///< 正在执行的支线任务Id RcvMissonItem m_aMissionItem[MAX_MISSION_RCV_NUM]; ///< 任务背包中的任务项 unsigned int m_aMissionDoneFlag[MAX_MISSION_TYPE_NUM]; ///< 某项任务是否执行的标记 //这个自定义数据没搞懂什么意思 int m_aMissionData[MAX_MISSION_DATA_NUM]; ///< 玩家自定义任务数据 /* m_aMissionDoneFlag用法: nMissionId 取值范围(0 ~ MAX_MISSION_COUNT) 0xFFF 1111111 11111 type count (0~127) (0~31) ==> 128 * 32 = 4096 */ //主要理解这个其实和脏标记差不多,只是脏标记拿char存,而这个拿int存 inline bool IsMissionDone(int nMissionId) { int nMissionIndex = nMissionId >> 5; return !!(m_aMissionDoneFlag[nMissionIndex] & (1 << (nMissionId & 0x1F))); } inline void SetMissionDoneFlag(int nMissionId, bool bDone) { int nMissionIndex = nMissionId >> 5; if (bDone) m_aMissionDoneFlag[nMissionIndex] |= (1 << (nMissionId & 0x1F)); else m_aMissionDoneFlag[nMissionIndex] &= ~(1 << (nMissionId & 0x1F)); } /* m_aMissionData的用法:[索引值由任务配置表决定] 玩家自定义任务数据,可常用于一些频繁的直线任务 e.g. 某种任务 ①需判断一共执行多少次 ②上次执行时间 ③当天执行了多少次 至于主线任务往往有前置任务需执行完方可领取的条件(就需前置任务标记/Id),这可由 任务配表中指定完成,用时只需按配表前置任务标记查询IsMissionDone判断是否Done过即可作判断。 配表应该指定的都是任务固有条件,如:完成和接收需要条件指标。 */ }; 4.接下来就是lua执行和c库函数互调的过程,因lua要获得实时信息所有要调c函数 至于为什么用lua,对于那些比较复杂的逻辑比如任务,活动记录的东西较多,用c++实现起来可以,但容易出错每次修改代码需要编译 用lua不用编译写代码大大提高效率 还有那个lua虚拟机到底是什么,我知道一个lua_state就可以是一个虚拟机,可以通过和lua传参交互,解释器又是什么意思