根据NormalImage设置DisabledImage

本文介绍了一种在Cocos2dx中为未设置禁用状态图像的菜单项自动生成灰色替代图像的方法,通过Lua脚本实现,适用于使用CocosBuilder创建UI的情况。

出于美术资源包大小的考虑,我们认为单独提供DisabledImage是不划算的。

 

如果你是直接create CCMenuItemSprite的话,这个就比较简单了。

Cocos2dx现已提供CCGraySprite

    menuItem->setDisabledImage(CCGraySprite::create(fileName));

 

然而,如果你跟我一样,是使用CocosBuilder来创建UI的话,有没有统一的方法来处理DisabledImage呢?

答案是肯定的。

以下为Lua代码:

function createDisabledImageIfNot(node)
    if type(node.getDisabledImage) ~= 'function' then return end

    local disabledImage = node:getDisabledImage()
    -- 如果没有设置 disabled image
    if not disabledImage then
        -- 取得normal image
        local normalSprite = tolua.cast(node:getNormalImage(), 'CCSprite')
        if normalSprite then
            -- 将normal image 整体变灰
            local graySprite = CCGraySprite:createWithTexture(normalSprite:getTexture(), normalSprite:getTextureRect())
            node:setDisabledImage(graySprite)
        end
    end
end

 

只要在初始化方法中调用上述方法即可。

    createDisabledImageIfNot(ccbLayer.menuItem1)
    createDisabledImageIfNot(ccbLayer.menuItem2)
…………

 

<Default name="VScrollBar" value="button1normalimage="file='scroll.png' source='0,0,16,16'" button1hotimage="file='scroll.png' source='0,0,16,16' mask='#FFFF00FF'" button1pushedimage="file='scroll.png' source='0,16,16,32' mask='#FFFF00FF'" button1disabledimage="file='scroll.png' source='0,0,16,16' mask='#FFFF00FF'" button2normalimage="file='scroll.png' source='0,32,16,48' mask='#FFFF00FF'" button2hotimage="file='scroll.png' source='0,32,16,48' mask='#FFFF00FF'" button2pushedimage="file='scroll.png' source='0,48,16,64' mask='#FFFF00FF'" button2disabledimage="file='scroll.png' source='0,32,16,48' mask='#FFFF00FF'" thumbnormalimage="file='scroll.png' source='0,64,16,80' corner='2,2,2,2' mask='#FFFF00FF'" thumbhotimage="file='scroll.png' source='0,64,16,80' corner='2,2,2,2' mask='#FFFF00FF'" thumbpushedimage="ffile='scroll.png' source='0,64,16,80' corner='2,2,2,2' mask='#FFFF00FF'" thumbdisabledimage="file='scroll.png' source='0,64,16,80' corner='2,2,2,2' mask='#FFFF00FF'" railnormalimage="file='scroll.png' source='0,80,16,96' corner='2,2,2,2' mask='#FFFF00FF'" railhotimage="file='scroll.png' source='0,80,16,96' corner='2,2,2,2' mask='#FFFF00FF'" railpushedimage="file='scroll.png' source='0,96,16,112' corner='2,2,2,2' mask='#FFFF00FF'" raildisabledimage="file='scroll.png' source='0,80,16,96' corner='2,2,2,2' mask='#FFFF00FF'" bknormalimage="file='scroll.png' source='0,128,16,146' corner='2,2,2,2' mask='#FFFF00FF'" bkhotimage="file='scroll.png' source='0,128,16,146' corner='2,2,2,2' mask='#FFFF00FF'" bkpushedimage="file='scroll.png' source='0,128,16,146' corner='2,2,2,2' mask='#FFFF00FF'" bkdisabledimage="file='scroll.png' source='0,128,16,146' corner='2,2,2,2' mask='#FFFF00FF'" " /> 官方有个这样定义的,必须要图片吗?
08-07
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值