Cocos Creator 组件-动作ActionFadeTo

嵌套暂时没法做,先做些常用的单独使用的动作组件

ActionFadeTo.js (拖到需要做该动作的节点上,不同类型的动作互不影响)

var ActionDurationFade = cc.Class({
    name: "ActionDurationFade",
    properties: {
        delayTime: {
            default: 0,
            displayName: "延时",
            min: 0
        },
        duration: {
            default: 1,
            displayName: "时长",
            min: 0
        },
        opacity: {
            default: 0,
            displayName: "透明值",
            min: 0,
            max: 255,
        },
        callback: {
            default: null,
            type: cc.Component.EventHandler,
            displayName: "完成回调",
        }
    }
});

cc.Class({
    extends: cc.Component,

    properties: {
        auto: {
            default: false,
            displayName: "自动执行",
            tooltip: "如果false,则需要回调执行该脚本组件的begin方法"
        },

        delayTime: {
            default: 0,
            displayName: "自动延迟执行时长",
            tooltip: "只有在自动执行模式下,这个延迟才会有效",
            min: 0
        },

        target: {
            default: null,
            type: cc.Node,
            displayName: "执行的节点",
            tooltip: "如果没有设置就默认 挂载该脚本的节点"
        },

        startFromCurrent: {
            default: false,
            displayName: "从当前状态执行",
            tooltip: "勾上:从当前状态开始执行动作  不勾:从编辑的初始状态开始执行"
        },

        times: {
            default: 1,
            type: cc.Integer,
            displayName: "执行次数",
            tooltip: "一套动作数组 执行的次数",
            min: 1
        },

        actionFades: {
            default: [],
            type: ActionDurationFade,
            displayName: "动作数组",
            tooltip: "暂时只支持到10个,超过了,自己进来扩写代码"
        },

        allOverCallback: {
            default: true,
            displayName: "全部完成/每完成一次回调",
            tooltip: "勾上:全部完成才回调  不勾:每完成一次都回调,执行几次就调几遍回调"
        },

        overCallbacks: {
            default: [],
            type: cc.Component.EventHandler,
            displayName: "完成回调数组",
            tooltip: "全部完成时回调的事件数组"
        }
    },

    // LIFE-CYCLE CALLBACKS:

    // onLoad () {},

    start () {
        this.actionNode = this.target;
        if (this.actionNode == undefined || this.actionNode == null) {
            this.actionNode = this.node;
        }

        this.actionNode.srcOpacity = this.actionNode.opacity;

        if (this.auto) {
            this.scheduleOnce(function() {
                this.begin();
            }, this.delayTime);
        }
    },

    begin () {
        this.reset();
        this.currentTime = this.times;
        this.action();
    },

    reset () {
        this.currentTime = 0;
        this.actionNode.stopActionByTag(111001);
        if (this.startFromCurrent) {
            
        } else {
            this.actionNode.opacity = this.actionNode.srcOpacity;
        }
    },

    // update (dt) {},

    action () {
        if (this.currentTime > 0) {
            this.currentTime--;
        } else {
            return;
        }

        if (this.actionFades.length == 1) {
            this.actionNode.runAction(this.actionID = cc.sequence(
                cc.delayTime(this.actionFades[0].delayTime), cc.fadeTo(this.actionFades[0].duration, this.actionFades[0].opacity), cc.callFunc(function() { this.callEventHandler(this.actionFades[0].callback); }.bind(this)),
                cc.callFunc(function() { this.action(); this.overCallback(); }.bind(this))));
        } else if (this.actionFades.length == 2) {
            this.actionNode.runAction(this.actionID = cc.sequence(
                cc.delayTime(this.actionFades[0].delayTime), cc.fadeTo(this.actionFades[0].duration, this.actionFades[0].opacity), cc.callFunc(function() { this.callEventHandler(this.actionFades[0].callback); }.bind(this)),
                cc.delayTime(this.actionFades[1].delayTime), cc.fadeTo(this.actionFades[1].duration, this.actionFades[1].opacity), cc.callFunc(function() { this.callEventHandler(this.actionFades[1].callback); }.bind(this)),
                cc.callFunc(function() { this.action(); this.overCallback(); }.bind(this))));
        } else if (this.actionFades.length == 3) {
            this.actionNode.runAction(this.actionID = cc.sequence(
                cc.delayTime(this.actionFades[0].delayTime), cc.fadeTo(this.actionFades[0].duration, this.actionFades[0].opacity), cc.callFunc(function() { this.callEventHandler(this.actionFades[0].callback); }.bind(this)),
                cc.delayTime(this.actionFades[1].delayTime), cc.fadeTo(this.actionFades[1].duration, this.actionFades[1].opacity), cc.callFunc(function() { this.callEventHandler(this.actionFades[1].callback); }.bind(this)),
                cc.delayTime(this.actionFades[2].delayTime), cc.fadeTo(this.actionFades[2].duration, this.actionFades[2].opacity), cc.callFunc(function() { this.callEventHandler(this.actionFades[2].callback); }.bind(this)),
                cc.callFunc(function() { this.action(); this.overCallback(); }.bind(this))));
        } else if (this.actionFades.length == 4) {
            this.actionNode.runAction(this.actionID = cc.sequence(
                cc.delayTime(this.actionFades[0].delayTime), cc.fadeTo(this.actionFades[0].duration, this.actionFades[0].opacity), cc.callFunc(function() { this.callEventHandler(this.actionFades[0].callback); }.bind(this)),
                cc.delayTime(this.actionFades[1].delayTime), cc.fadeTo(this.actionFades[1].duration, this.actionFades[1].opacity), cc.callFunc(function() { this.callEventHandler(this.actionFades[1].callback); }.bind(this)),
                cc.delayTime(this.actionFades[2].delayTime), cc.fadeTo(this.actionFades[2].duration, this.actionFades[2].opacity), cc.callFunc(function() { this.callEventHandler(this.actionFades[2].callback); }.bind(this)),
                cc.delayTime(this.actionFades[3].delayTime), cc.fadeTo(this.actionFades[3].duration, this.actionFades[3].opacity), cc.callFunc(function() { this.callEventHandler(this.actionFades[3].callback); }.bind(this)),
                cc.callFunc(function() { this.action(); this.overCallback(); }.bind(this))));
        } else if (this.actionFades.length == 5) {
            this.actionNode.runAction(this.actionID = cc.sequence(
                cc.delayTime(this.actionFades[0].delayTime), cc.fadeTo(this.actionFades[0].duration, this.actionFades[0].opacity), cc.callFunc(function() { this.callEventHandler(this.actionFades[0].callback); }.bind(this)),
                cc.delayTime(this.actionFades[1].delayTime), cc.fadeTo(this.actionFades[1].duration, this.actionFades[1].opacity), cc.callFunc(function() { this.callEventHandler(this.actionFades[1].callback); }.bind(this)),
                cc.delayTime(this.actionFades[2].delayTime), cc.fadeTo(this.actionFades[2].duration, this.actionFades[2].opacity), cc.callFunc(function() { this.callEventHandler(this.actionFades[2].callback); }.bind(this)),
                cc.delayTime(this.actionFades[3].delayTime), cc.fadeTo(this.actionFades[3].duration, this.actionFades[3].opacity), cc.callFunc(function() { this.callEventHandler(this.actionFades[3].callback); }.bind(this)),
                cc.delayTime(this.actionFades[4].delayTime), cc.fadeTo(this.actionFades[4].duration, this.actionFades[4].opacity), cc.callFunc(function() { this.callEventHandler(this.actionFades[4].callback); }.bind(this)),
                cc.callFunc(function() { this.action(); this.overCallback(); }.bind(this))));
        } else if (this.actionFades.length == 6) {
            this.actionNode.runAction(this.actionID = cc.sequence(
                cc.delayTime(this.actionFades[0].delayTime), cc.fadeTo(this.actionFades[0].duration, this.actionFades[0].opacity), cc.callFunc(function() { this.callEventHandler(this.actionFades[0].callback); }.bind(this)),
                cc.delayTime(this.actionFades[1].delayTime), cc.fadeTo(this.actionFades[1].duration, this.actionFades[1].opacity), cc.callFunc(function() { this.callEventHandler(this.actionFades[1].callback); }.bind(this)),
                cc.delayTime(this.actionFades[2].delayTime), cc.fadeTo(this.actionFades[2].duration, this.actionFades[2].opacity), cc.callFunc(function() { this.callEventHandler(this.actionFades[2].callback); }.bind(this)),
                cc.delayTime(this.actionFades[3].delayTime), cc.fadeTo(this.actionFades[3].duration, this.actionFades[3].opacity), cc.callFunc(function() { this.callEventHandler(this.actionFades[3].callback); }.bind(this)),
                cc.delayTime(this.actionFades[4].delayTime), cc.fadeTo(this.actionFades[4].duration, this.actionFades[4].opacity), cc.callFunc(function() { this.callEventHandler(this.actionFades[4].callback); }.bind(this)),
                cc.delayTime(this.actionFades[5].delayTime), cc.fadeTo(this.actionFades[5].duration, this.actionFades[5].opacity), cc.callFunc(function() { this.callEventHandler(this.actionFades[5].callback); }.bind(this)),
                cc.callFunc(function() { this.action(); this.overCallback(); }.bind(this))));
        } else if (this.actionFades.length == 7) {
            this.actionNode.runAction(this.actionID = cc.sequence(
                cc.delayTime(this.actionFades[0].delayTime), cc.fadeTo(this.actionFades[0].duration, this.actionFades[0].opacity), cc.callFunc(function() { this.callEventHandler(this.actionFades[0].callback); }.bind(this)),
                cc.delayTime(this.actionFades[1].delayTime), cc.fadeTo(this.actionFades[1].duration, this.actionFades[1].opacity), cc.callFunc(function() { this.callEventHandler(this.actionFades[1].callback); }.bind(this)),
                cc.delayTime(this.actionFades[2].delayTime), cc.fadeTo(this.actionFades[2].duration, this.actionFades[2].opacity), cc.callFunc(function() { this.callEventHandler(this.actionFades[2].callback); }.bind(this)),
                cc.delayTime(this.actionFades[3].delayTime), cc.fadeTo(this.actionFades[3].duration, this.actionFades[3].opacity), cc.callFunc(function() { this.callEventHandler(this.actionFades[3].callback); }.bind(this)),
                cc.delayTime(this.actionFades[4].delayTime), cc.fadeTo(this.actionFades[4].duration, this.actionFades[4].opacity), cc.callFunc(function() { this.callEventHandler(this.actionFades[4].callback); }.bind(this)),
                cc.delayTime(this.actionFades[5].delayTime), cc.fadeTo(this.actionFades[5].duration, this.actionFades[5].opacity), cc.callFunc(function() { this.callEventHandler(this.actionFades[5].callback); }.bind(this)),
                cc.delayTime(this.actionFades[6].delayTime), cc.fadeTo(this.actionFades[6].duration, this.actionFades[6].opacity), cc.callFunc(function() { this.callEventHandler(this.actionFades[6].callback); }.bind(this)),
                cc.callFunc(function() { this.action(); this.overCallback(); }.bind(this))));
        } else if (this.actionFades.length == 8) {
            this.actionNode.runAction(this.actionID = cc.sequence(
                cc.delayTime(this.actionFades[0].delayTime), cc.fadeTo(this.actionFades[0].duration, this.actionFades[0].opacity), cc.callFunc(function() { this.callEventHandler(this.actionFades[0].callback); }.bind(this)),
                cc.delayTime(this.actionFades[1].delayTime), cc.fadeTo(this.actionFades[1].duration, this.actionFades[1].opacity), cc.callFunc(function() { this.callEventHandler(this.actionFades[1].callback); }.bind(this)),
                cc.delayTime(this.actionFades[2].delayTime), cc.fadeTo(this.actionFades[2].duration, this.actionFades[2].opacity), cc.callFunc(function() { this.callEventHandler(this.actionFades[2].callback); }.bind(this)),
                cc.delayTime(this.actionFades[3].delayTime), cc.fadeTo(this.actionFades[3].duration, this.actionFades[3].opacity), cc.callFunc(function() { this.callEventHandler(this.actionFades[3].callback); }.bind(this)),
                cc.delayTime(this.actionFades[4].delayTime), cc.fadeTo(this.actionFades[4].duration, this.actionFades[4].opacity), cc.callFunc(function() { this.callEventHandler(this.actionFades[4].callback); }.bind(this)),
                cc.delayTime(this.actionFades[5].delayTime), cc.fadeTo(this.actionFades[5].duration, this.actionFades[5].opacity), cc.callFunc(function() { this.callEventHandler(this.actionFades[5].callback); }.bind(this)),
                cc.delayTime(this.actionFades[6].delayTime), cc.fadeTo(this.actionFades[6].duration, this.actionFades[6].opacity), cc.callFunc(function() { this.callEventHandler(this.actionFades[6].callback); }.bind(this)),
                cc.delayTime(this.actionFades[7].delayTime), cc.fadeTo(this.actionFades[7].duration, this.actionFades[7].opacity), cc.callFunc(function() { this.callEventHandler(this.actionFades[7].callback); }.bind(this)),
                cc.callFunc(function() { this.action(); this.overCallback(); }.bind(this))));
        } else if (this.actionFades.length == 9) {
            this.actionNode.runAction(this.actionID = cc.sequence(
                cc.delayTime(this.actionFades[0].delayTime), cc.fadeTo(this.actionFades[0].duration, this.actionFades[0].opacity), cc.callFunc(function() { this.callEventHandler(this.actionFades[0].callback); }.bind(this)),
                cc.delayTime(this.actionFades[1].delayTime), cc.fadeTo(this.actionFades[1].duration, this.actionFades[1].opacity), cc.callFunc(function() { this.callEventHandler(this.actionFades[1].callback); }.bind(this)),
                cc.delayTime(this.actionFades[2].delayTime), cc.fadeTo(this.actionFades[2].duration, this.actionFades[2].opacity), cc.callFunc(function() { this.callEventHandler(this.actionFades[2].callback); }.bind(this)),
                cc.delayTime(this.actionFades[3].delayTime), cc.fadeTo(this.actionFades[3].duration, this.actionFades[3].opacity), cc.callFunc(function() { this.callEventHandler(this.actionFades[3].callback); }.bind(this)),
                cc.delayTime(this.actionFades[4].delayTime), cc.fadeTo(this.actionFades[4].duration, this.actionFades[4].opacity), cc.callFunc(function() { this.callEventHandler(this.actionFades[4].callback); }.bind(this)),
                cc.delayTime(this.actionFades[5].delayTime), cc.fadeTo(this.actionFades[5].duration, this.actionFades[5].opacity), cc.callFunc(function() { this.callEventHandler(this.actionFades[5].callback); }.bind(this)),
                cc.delayTime(this.actionFades[6].delayTime), cc.fadeTo(this.actionFades[6].duration, this.actionFades[6].opacity), cc.callFunc(function() { this.callEventHandler(this.actionFades[6].callback); }.bind(this)),
                cc.delayTime(this.actionFades[7].delayTime), cc.fadeTo(this.actionFades[7].duration, this.actionFades[7].opacity), cc.callFunc(function() { this.callEventHandler(this.actionFades[7].callback); }.bind(this)),
                cc.delayTime(this.actionFades[8].delayTime), cc.fadeTo(this.actionFades[8].duration, this.actionFades[8].opacity), cc.callFunc(function() { this.callEventHandler(this.actionFades[8].callback); }.bind(this)),
                cc.callFunc(function() { this.action(); this.overCallback(); }.bind(this))));
        } else if (this.actionFades.length == 10) {
            this.actionNode.runAction(this.actionID = cc.sequence(
                cc.delayTime(this.actionFades[0].delayTime), cc.fadeTo(this.actionFades[0].duration, this.actionFades[0].opacity), cc.callFunc(function() { this.callEventHandler(this.actionFades[0].callback); }.bind(this)),
                cc.delayTime(this.actionFades[1].delayTime), cc.fadeTo(this.actionFades[1].duration, this.actionFades[1].opacity), cc.callFunc(function() { this.callEventHandler(this.actionFades[1].callback); }.bind(this)),
                cc.delayTime(this.actionFades[2].delayTime), cc.fadeTo(this.actionFades[2].duration, this.actionFades[2].opacity), cc.callFunc(function() { this.callEventHandler(this.actionFades[2].callback); }.bind(this)),
                cc.delayTime(this.actionFades[3].delayTime), cc.fadeTo(this.actionFades[3].duration, this.actionFades[3].opacity), cc.callFunc(function() { this.callEventHandler(this.actionFades[3].callback); }.bind(this)),
                cc.delayTime(this.actionFades[4].delayTime), cc.fadeTo(this.actionFades[4].duration, this.actionFades[4].opacity), cc.callFunc(function() { this.callEventHandler(this.actionFades[4].callback); }.bind(this)),
                cc.delayTime(this.actionFades[5].delayTime), cc.fadeTo(this.actionFades[5].duration, this.actionFades[5].opacity), cc.callFunc(function() { this.callEventHandler(this.actionFades[5].callback); }.bind(this)),
                cc.delayTime(this.actionFades[6].delayTime), cc.fadeTo(this.actionFades[6].duration, this.actionFades[6].opacity), cc.callFunc(function() { this.callEventHandler(this.actionFades[6].callback); }.bind(this)),
                cc.delayTime(this.actionFades[7].delayTime), cc.fadeTo(this.actionFades[7].duration, this.actionFades[7].opacity), cc.callFunc(function() { this.callEventHandler(this.actionFades[7].callback); }.bind(this)),
                cc.delayTime(this.actionFades[8].delayTime), cc.fadeTo(this.actionFades[8].duration, this.actionFades[8].opacity), cc.callFunc(function() { this.callEventHandler(this.actionFades[8].callback); }.bind(this)),
                cc.delayTime(this.actionFades[9].delayTime), cc.fadeTo(this.actionFades[9].duration, this.actionFades[9].opacity), cc.callFunc(function() { this.callEventHandler(this.actionFades[9].callback); }.bind(this)),
                cc.callFunc(function() { this.action(); this.overCallback(); }.bind(this))));
        }

        this.actionID.setTag(111001);
    },

    overCallback() {
        if (this.currentTime > 1) {
            if (this.allOverCallback) {
                for (let i = 0; i < this.overCallbacks.length; i++) {
                    if (this.overCallbacks[i] != null && this.overCallbacks[i].target != null) {
                        this.overCallbacks[i].emit([this]);
                    }
                }
            }
        } else {
            for (let i = 0; i < this.overCallbacks.length; i++) {
                if (this.overCallbacks[i] != null && this.overCallbacks[i].target != null) {
                    this.overCallbacks[i].emit([this]);
                }
            }
        }
    },

    callEventHandler(eventHandler) {
        if (eventHandler && eventHandler.target) {
            eventHandler.emit([this]);
        }
    }
});
原文地址:https://www.cnblogs.com/lyonwu/p/10369178.html