zoukankan      html  css  js  c++  java
  • 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]);
            }
        }
    });
    
  • 相关阅读:
    4组Beta冲刺1/5
    4组Beta冲刺总结
    4组Beta冲刺2/5
    4组Beta冲刺4/5
    4组Beta冲刺5/5
    4组Alpha冲刺6/6
    软工实践个人总结
    4组Alpha冲刺6/6
    4组Beta冲刺3/5
    4组Alpha冲刺总结
  • 原文地址:https://www.cnblogs.com/lyonwu/p/10369178.html
Copyright © 2011-2022 走看看