Cocos Creator 屏幕适配脚本

挂载在Scene上,预制体需要添加 Widget 组件


/**
 * 画布适配策略
 * note:
 *  1. 只能挂载画布节点
 */

let StrategyEnum = cc.Enum({
    NONE: 0,
    AUTO: 1,
    FIT_WIDTH: 2,
    FIT_HEIGHT: 3,
    FIT_WIDTH_HEIGHT: 4,
});

cc.Class({
    extends: cc.Component,
    
    properties: {
        _onAdded: true,
        strategy: {
            type: StrategyEnum,
            default: StrategyEnum.NONE,
            tooltip: "适配策略: \n" + 
                "AUTO: 宽高比>4096/2160时选择等高,否则等宽\n" + 
                "FIT_WIDTH: 等宽\n" +
                "FIT_HEIGHT: 等高\n" +
                "FIT_WIDTH_HEIGHT: 等宽等高",
            notify () {
                let canvas = this.node.getComponent(cc.Canvas);
                if (canvas) {
                    switch (this.strategy) {
                        case StrategyEnum.AUTO:
                            canvas.fitWidth = false;
                            canvas.fitHeight = false;
                            break;
                        case StrategyEnum.FIT_HEIGHT:
                            canvas.fitWidth = false;
                            canvas.fitHeight = true;
                            break;
                        case StrategyEnum.FIT_WIDTH:
                            canvas.fitWidth = true;
                            canvas.fitHeight = false;
                            break;
                        case StrategyEnum.FIT_WIDTH_HEIGHT:
                            canvas.fitWidth = true;
                            canvas.fitHeight = true;
                            break;
                    }
                }
            }
        }
    },

    onLoad () {
        this.setFitMode();
    },

    isCanvasNode () {
        return this.node.getComponent(cc.Canvas) != null;
    },

    /**
     * 设置适配模式
     */
    setFitMode () {
        let winSize = cc.view.getFrameSize();
        let w = winSize.width,
            h = winSize.height;
        
        let canvas = this.getComponent(cc.Canvas);
        if (canvas) {
            switch (this.strategy) {
                case StrategyEnum.AUTO:
                    if (w / h > 4096 / 2160) {
                        canvas.fitWidth = false;
                        canvas.fitHeight = true;
                    } else {
                        canvas.fitWidth = true;
                        canvas.fitHeight = false;
                    }
                    break;
                case StrategyEnum.FIT_HEIGHT:
                    canvas.fitWidth = false;
                    canvas.fitHeight = true;
                    break;
                case StrategyEnum.FIT_WIDTH:
                    canvas.fitWidth = true;
                    canvas.fitHeight = false;
                    break;
                case StrategyEnum.FIT_WIDTH_HEIGHT:
                    canvas.fitWidth = true;
                    canvas.fitHeight = true;
                    break;
            }
        }
    }
});
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值