Cocos2dx-lua制作遮罩

前端之家收集整理的这篇文章主要介绍了Cocos2dx-lua制作遮罩前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

cocos2dx的资源文件有两种存在方式(只代表我在实战项目中用到的):单个图片文件和plist文件

因项目原因一个项目中两种资源形式并存,所以在生成CCSprite时,涉及两种构建的方式,构建ccsprite的方式不同,对应生成遮罩的方法也不同。Cocos2dx-lua 中提供了生成遮罩的方法,但是在具体的项目中,未必能满足项目的需求。我所参于的项目是模拟经营类的,需要根据不同图片,动态生成遮罩,所以使用display.newMaskedSprite(__mask,__pic)时就无法满足项目需求。接下来我把display.newMaskedSprite改进方法简单介绍下。

首先生成遮罩的Texture,这个核心代码不变,使用display.newMaskedSprite提供的代码

local __mb = ccBlendFunc()
__mb.src = GL_ONE
__mb.dst = GL_ZERO

local __pb = ccBlendFunc()
__pb.src = GL_DST_ALPHA
__pb.dst = GL_ZERO

local __maskSprite = display.newSprite(__mask):align(display.LEFT_BOTTOM,0)
__maskSprite:setBlendFunc(__mb)

local __picSprite = display.newSprite(__pic):align(display.LEFT_BOTTOM,0)
__picSprite:setBlendFunc(__pb)

local __maskSize = __maskSprite:getContentSize()
local __canva = CCRenderTexture:create(__maskSize.width,__maskSize.height)
__canva:begin()
__maskSprite:visit()
__picSprite:visit()
__canva:endToLua()

接下来就是如何将生成的Texture应用在原有的CCSprite中:

1、display.newSprite(单个图片的绝对径)

wallSprite:setTexture(__canva:getSprite():getTexture())

2、display.newSprite(plist中定义的图片key值)

local frame = CCSpriteFrame:createWithTexture(__canva:getSprite():getTexture(),CCRectMake(0,__maskSize.width,__maskSize.height)) wallSprite:setDisplayFrame(frame)

原文链接:https://www.f2er.com/cocos2dx/343750.html

猜你在找的Cocos2d-x相关文章