环境: cocos2dx版本为2.1.4 目标: 游戏中一般有玩家和怪物,他们都有相同的动作状态,如:idle、walk、attack、defense等,我们需要抽象出玩家和怪物的代码实现中中相同的部分 方法: cocos2dx中其实已经提供了类继承的一下工具函数,在sdk中的samples/Lua
环境:
cocos2dx版本为2.1.4
目标:
游戏中一般有玩家和怪物,他们都有相同的动作状态,如:idle、walk、attack、defense等,我们需要抽象出玩家和怪物的代码实现中中相同的部分
方法:
cocos2dx中其实已经提供了类继承的一下工具函数,在sdk中的samples/Lua/TestLua/Resources/luaScript目录下有一个名为“extern.lua”,其中有段代码如下:
--Create an class. function class(classname, super) local superType = type(super) local cls if superType ~= "function" and superType ~= "table" then superType = nil super = nil end if superType == "function" or (super and super.__ctype == 1) then -- inherited from native C++ Object cls = {} if superType == "table" then -- copy fields from super for k,v in pairs(super) do cls[k] = v end cls.__create = super.__create cls.super = super else cls.__create = super end cls.ctor = function() end cls.__cname = classname cls.__ctype = 1 function cls.new(...) local instance = cls.__create(...) -- copy fields from class to native object for k,v in pairs(cls) do instance[k] = v end instance.class = cls instance:ctor(...) return instance end else -- inherited from Lua Object if super then cls = clone(super) cls.super = super else cls = {ctor = function() end} end cls.__cname = classname cls.__ctype = 2 -- lua cls.__index = cls function cls.new(...) local instance = setmetatable({}, cls) instance.class = cls instance:ctor(...) return instance end end return cls end
函数class的第一个参数就是我们要实现的类的名称,可以不传第二个参数或者给第二参数传一个function或者table。
我们从cocos2dx中的CCSprite继承,根据不同的状态播放不同的动画
实现:
玩家和怪物的基类可如下实现:
require "extern" Actor = class("Actor", function() return CCSprite:create() end) Actor.__index = Actor -- 常量 kActorStateUnkown = 0 kActorStateIdle = 1 kActorStateAttack = 2 kActorStateDefense = 3 kActorStateWalk = 4 -- 属性 Actor._state = kActorStateUnkown Actor._idle_action = nil Actor._attack_action = nil Actor._defense_action = nil Actor._walk_action = nil -- 方法 function Actor:idle() if self._state ~= kActorStateIdle then self:stopAllActions() pcall(self:runAction(self._idle_action)) self._state = kActorStateIdle end end function Actor:attack() if self._state ~= kActorStateAttack then self:stopAllActions() pcall(self:runAction(self._attack_action)) self._state = kActorStateAttack end end function Actor:defense() if self._state ~= kActorStateDefense then self:stopAllActions() pcall(self:runAction(self._defense_action)) self._state = kActorStateDefense end end function Actor:walk() if self._state ~= kActorStateWalk then self:stopAllActions() pcall(self:runAction(self._walk_action)) self._state = kActorStateWalk end end function Actor:create() local actor = Actor.new() return actor end
有了基类后,玩家的的实现可以如下:
1、玩家的数据单例
require "extern" PlayerData = class("PlayerData") PlayerData.__index = PlayerData PlayerData._inited = 0 PlayerData._idle_action = nil PlayerData._attack_action = nil PlayerData._defense_action = nil PlayerData._walk_action = nil function PlayerData:lazyInit() if (self._inited ~= 0) then return end local cache = CCSpriteFrameCache:sharedSpriteFrameCache() cache:addSpriteFramesWithFile("pd_sprites.plist") local frames = nil local frame = nil local anim = nil -- idle frames = CCArray:createWithCapacity(6) for i = 0, 5 do frame = cache:spriteFrameByName( string.format("hero_idle_%02d.png", i)) frames:addObject(frame) end anim = CCAnimation:createWithSpriteFrames(frames, 1.0 / 12.0) self._idle_action = CCRepeatForever:create(CCAnimate:create(anim)) -- attack frames = CCArray:createWithCapacity(3) for i = 0, 2 do frame = cache:spriteFrameByName( string.format("hero_attack_00_%02d.png", i)) frames:addObject(frame) end anim = CCAnimation:createWithSpriteFrames(frames, 1.0 / 12.0) self._attack_action = CCRepeatForever:create(CCAnimate:create(anim)) -- defense self._defense_action = self._idle_action -- walk frames = CCArray:createWithCapacity(8) for i = 0, 7 do frame = cache:spriteFrameByName( string.format("hero_walk_%02d.png", i)) frames:addObject(frame) end anim = CCAnimation:createWithSpriteFrames(frames, 1.0 / 12.0) self._walk_action = CCRepeatForever:create(CCAnimate:create(anim)) self._inited = 1 end function PlayerData:getAllAction() self:lazyInit() return self._idle_action, self._attack_action, self._defense_action, self._walk_action end
2、玩家类
require "actor" require "playerdata" Player = class("Player", function() return Actor:create() end) Player.__index = Player function Player:init() self._idle_action, self._attack_action, self._defense_action, self._walk_action = PlayerData:getAllAction() end function Player:create() local player = Player.new() player:init() return player end

Nginx安装配置Lua支持默认情况下Nginx不支持Lua模块,需要安装LuaJIT解释器,并且重新编译Nginx,或者可使用国人开发的openrestry需要的模块:LuaJIT,Ngx_devel和lua-nginx-module1.环境准备[root@nginx_lua~]#yuminstall-ygccgcc-c++makepcre-develzlib-developenssl-devel2.下载最新的luajit和ngx_devel_kit以及lua-nginx-module解压[r

实现思路直接在nginx做配置黑名单,通过编写逻辑块实现;在服务端(Java)中编写过滤器,在过滤器中统一拦截;在服务端(Java)中编写拦截器,在拦截器中统一拦截;这里列举了3种实现的思路,至于实现方案,可能还有更多,但是我们想想,在nginx中编写逻辑块貌似不是很多人擅长的;在代码层面做不是不可以,而是这样一来,在涉及到高并发的业务高峰期,这必然会对后端服务造成较大的压力,那么还有没有其他更好的处理办法呢?这就是要说的lua,即nginx作为网关仍然作为代理服务器,由于nginx可以集成lu

Vue.js与Lua语言的融合,编写轻量级的嵌入式应用在现代开发中,前端框架Vue.js和脚本语言Lua都各自有着广泛的应用。Vue.js是一款用于构建用户界面的渐进式框架,而Lua则是一种轻量级的脚本语言,经常用于嵌入式应用和游戏开发。本文将介绍如何将Vue.js与Lua语言进行融合,用于编写轻量级的嵌入式应用,并提供代码示例。首先,我们需要安装Vue.j

【实现过程】一、问题分析如果set命令设置上,但是在设置失效时间时由于网络抖动等原因导致没有设置成功,这时就会出现死计数器(类似死锁);二、解决方案Redis+Lua是一个很好的解决方案,使用脚本使得set命令和expire命令一同达到Redis被执行且不会被干扰,在很大程度上保证了原子操作;为什么说是很大程度上保证原子操作而不是完全保证?因为在Redis内部执行的时候出问题也有可能出现问题不过概率非常小;即使针对小概率事件也有相应的解决方案,比如解决死锁一个思路值得参考:防止死锁会将锁的值存成

一、安装LUAMac上安装LUA很简单,直接使用brew相关命令;brewinstalllua使用lua-v命令可以看到lua已经安装完毕。1)简单使用创建一个test.lua文件,内容为:执行命令:luatest.lua输出为:二、lua语法简介Lua提供了交互式编程和脚本式编程:交互式编程:直接在命令行中输入语法,可以立即执行并查看到执行效果。脚本是编程:编写脚本文件,然后再执行。1、注释lua提供两种注释方式:单行注释和多行注释1)单行注释使用两个减号;--2)多行注释--[[多行注释多行

通过前面idaPro调试或hook,我们可以获取到xxtea解密key,对于sign我们可以直接打开原文件:可以看到sign值:byds。所以,我们可以同过xxtea解密工具(可从GitHub上下源码自己编译)试着解密:以index.luac为例,我们看index.luac解密前后变化:我们看到经过xxtea解密后的lua脚本仍然不是明文!我们之前根据cocos2d框架源码及大神apk反编结果确定就是用的xxtea加密,而且app的lua脚本也有签名值,这也印证了就是xxtea加密方式,但是我们

前言为了在我的一个基本库中降低与Redis的通讯成本,我将一系列操作封装到LUA脚本中,借助Redis提供的EVAL命令来简化操作。EVAL能够提供的特性:可以在LUA脚本中封装若干操作,如果有多条Redis指令,封装好之后只需向Redis一次性发送所有参数即可获得结果Redis可以保证Lua脚本运行期间不会有其他命令插入执行,提供像数据库事务一样的原子性Redis会根据脚本的SHA值缓存脚本,已经缓存过的脚本不需要再次传输Lua代码,减少了通信成本,此外在自己代码中改变Lua脚本,执行时Red

各网站站长和运营人员经常使用网站数据分析工具,谷歌分析、百度统计、腾讯分析等被广泛使用,要想统计数据先要收集数据,下面和大家分析数据收集的原理,并搭建一个数据收集系统。数据收集原理分析简单来说,网站统计分析工具需要收集到用户浏览目标网站的行为(如打开某网页、点击某按钮、将商品加入购物车等)及行为附加数据(如某下单行为产生的订单金额等)。早期的网站统计往往只收集一种用户行为:页面的打开。而后用户在页面中的行为均无法收集。这种收集策略能满足基本的流量分析、来源分析、内容分析及访客属性等常用分析视角,


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

Dreamweaver CS6
视觉化网页开发工具

禅工作室 13.0.1
功能强大的PHP集成开发环境

EditPlus 中文破解版
体积小,语法高亮,不支持代码提示功能

SublimeText3 英文版
推荐:为Win版本,支持代码提示!

ZendStudio 13.5.1 Mac
功能强大的PHP集成开发环境