You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
273 lines
7.7 KiB
273 lines
7.7 KiB
1 week ago
|
import { ryw_Event } from "../../../FrameWork/Event/EventEnum";
|
||
|
import EventMgr from "../../../FrameWork/Event/EventMgr";
|
||
|
|
||
|
import Common5 from "../../../Platform/th/Common5";
|
||
|
|
||
|
const { ccclass, property } = cc._decorator;
|
||
|
|
||
|
@ccclass
|
||
|
export default class NodeCollisionCheck2 extends cc.Component {
|
||
|
|
||
|
@property(cc.Node)
|
||
|
emitTarget: cc.Node = null
|
||
|
|
||
|
@property(cc.Node)
|
||
|
checkNodeArray: cc.Node[] = [];
|
||
|
|
||
|
@property(cc.Node)
|
||
|
tiggerNodeArray: cc.Node[] = []
|
||
|
|
||
|
@property(cc.Node)
|
||
|
hideTirNodeArray: cc.Node[] = []
|
||
|
|
||
|
@property(cc.Node)
|
||
|
allowEmitNode: cc.Node = null
|
||
|
|
||
|
@property(cc.Boolean)
|
||
|
isSpineAnim: boolean = false
|
||
|
|
||
|
@property(cc.String)
|
||
|
spineAnim: string = ''
|
||
|
|
||
|
@property(cc.Node)
|
||
|
spineNode: cc.Node = null
|
||
|
|
||
|
@property(cc.Node)
|
||
|
maskNode: cc.Node = null
|
||
|
|
||
|
@property(cc.Boolean)
|
||
|
isSpineNodeHide: boolean = false
|
||
|
|
||
|
@property(cc.AudioSource)
|
||
|
effectUrl: cc.AudioSource = null
|
||
|
|
||
|
@property(cc.Node)
|
||
|
moveNode: cc.Node = null
|
||
|
|
||
|
@property(cc.Node)
|
||
|
attrNodeArray: cc.Node[] = []
|
||
|
|
||
|
@property(cc.Boolean)
|
||
|
isToRecovery: boolean = true
|
||
|
|
||
|
@property(cc.Integer) //Z序列
|
||
|
zIndexNum: number = 0;
|
||
|
|
||
|
@property(cc.Node) //Z序列的节点有可能不是自己
|
||
|
parenrChangeZindexNode: cc.Node = null
|
||
|
|
||
|
@property(cc.Node) //覆盖的节点Nodes
|
||
|
coverZindexNodes: cc.Node[] = []
|
||
|
|
||
|
|
||
|
@property(cc.Boolean)
|
||
|
isNodeArrayShow: boolean = false
|
||
|
|
||
|
@property(cc.Boolean)
|
||
|
needChangeOpacity: boolean = false
|
||
|
|
||
|
@property(cc.Node)
|
||
|
relatedOpacityShowNodes: cc.Node[] = []
|
||
|
@property(cc.Node)
|
||
|
relatedOpacityHideNodes: cc.Node[] = []
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
// LIFE-CYCLE CALLBACKS:
|
||
|
touchStartPosi = null
|
||
|
onLoad() {
|
||
|
if (!this.emitTarget) {
|
||
|
this.emitTarget = this.node
|
||
|
}
|
||
|
this.initTouchEvent(this.emitTarget, this.checkNodeArray)
|
||
|
this.node['cancelTouchEvent'] = () => {
|
||
|
this.closeTouchEvent(this.emitTarget);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
start() {
|
||
|
|
||
|
}
|
||
|
|
||
|
|
||
|
openTouchEvent(node) {
|
||
|
node.on(cc.Node.EventType.TOUCH_START, this.touchStartNode, this)
|
||
|
node.on(cc.Node.EventType.TOUCH_MOVE, this.touchMoveNode, this)
|
||
|
node.on(cc.Node.EventType.TOUCH_CANCEL, this.touchEndNode, this)
|
||
|
node.on(cc.Node.EventType.TOUCH_END, this.touchEndNode, this)
|
||
|
}
|
||
|
|
||
|
closeTouchEvent(node: cc.Node) {
|
||
|
node.off(cc.Node.EventType.TOUCH_START, this.touchStartNode, this)
|
||
|
node.off(cc.Node.EventType.TOUCH_MOVE, this.touchMoveNode, this)
|
||
|
node.off(cc.Node.EventType.TOUCH_CANCEL, this.touchEndNode, this)
|
||
|
node.off(cc.Node.EventType.TOUCH_END, this.touchEndNode, this)
|
||
|
}
|
||
|
|
||
|
touchStartNode(event) {
|
||
|
let target:cc.Node = event.target;
|
||
|
target.pauseAllActions();
|
||
|
// Common5.playEffect("点击音效");
|
||
|
|
||
|
target['saveWorldPos'] = target.convertToWorldSpaceAR(cc.Vec2.ZERO);
|
||
|
if(this.parenrChangeZindexNode){
|
||
|
this.parenrChangeZindexNode.zIndex = 999
|
||
|
}
|
||
|
|
||
|
if( this.needChangeOpacity ){
|
||
|
target.opacity = 255
|
||
|
for (const iterator of this.relatedOpacityShowNodes) {
|
||
|
iterator.active = true;
|
||
|
}
|
||
|
for (const iterator of this.relatedOpacityHideNodes) {
|
||
|
iterator.active = false;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
}
|
||
|
|
||
|
initTouchEvent(node, checkNodeArray) {
|
||
|
var attrs = {
|
||
|
checkNodeArray: checkNodeArray,
|
||
|
recoveposi: node.getPosition(),//初始位置
|
||
|
recoveparent: node.parent,
|
||
|
scr: this //脚本
|
||
|
};
|
||
|
node.attr(attrs);
|
||
|
this.openTouchEvent(node)
|
||
|
}
|
||
|
|
||
|
cancelTouchEvent() {
|
||
|
this.closeTouchEvent(this.emitTarget);
|
||
|
}
|
||
|
|
||
|
touchMoveNode(event) {
|
||
|
let target = event.target
|
||
|
if (this.moveNode) {
|
||
|
target.parent = this.moveNode;
|
||
|
}
|
||
|
let posi = event.getLocation()//世界坐标
|
||
|
posi = target.parent.convertToNodeSpaceAR(posi)
|
||
|
target.setPosition(posi)
|
||
|
}
|
||
|
|
||
|
touchEndNode(event) {
|
||
|
let target = event.target;
|
||
|
|
||
|
let checkNodeArray = target.checkNodeArray as cc.Node[];
|
||
|
let jihuoNode = null;
|
||
|
if (!this.allowEmitNode || this.allowEmitNode.active) {
|
||
|
if(this.isNodeArrayShow){
|
||
|
for (let iterator of checkNodeArray) {
|
||
|
if(iterator.active){
|
||
|
if (Common5.checkIntersectsBox(target, iterator)) {
|
||
|
jihuoNode = iterator;
|
||
|
break;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}else{
|
||
|
for (let iterator of checkNodeArray) {
|
||
|
if (Common5.checkIntersectsBox(target, iterator)) {
|
||
|
jihuoNode = iterator;
|
||
|
break;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
if (jihuoNode) {
|
||
|
target.active = false
|
||
|
if (this.effectUrl) {
|
||
|
this.effectUrl.play();
|
||
|
}
|
||
|
|
||
|
let callbacks = () => {
|
||
|
jihuoNode.active = false;
|
||
|
|
||
|
for (const iterator of this.tiggerNodeArray) {
|
||
|
iterator.active = true;
|
||
|
}
|
||
|
|
||
|
for (const iterator of this.hideTirNodeArray) {
|
||
|
iterator.active = false;
|
||
|
}
|
||
|
|
||
|
if (this.maskNode) {
|
||
|
this.maskNode.active = false;
|
||
|
}
|
||
|
|
||
|
if (this.isSpineNodeHide && this.spineNode) {
|
||
|
this.spineNode.active = false
|
||
|
}
|
||
|
|
||
|
target.attrNodeArray = this.attrNodeArray;
|
||
|
|
||
|
console.log("[GameReport]++++++++++++++++++++++>" + target.name);
|
||
|
EventMgr.emitEvent_custom(ryw_Event.NormalTouchMoveCheck, { targetNode: target, jihuoNode: jihuoNode })
|
||
|
}
|
||
|
|
||
|
if (this.isSpineAnim) {
|
||
|
if (this.maskNode) {
|
||
|
this.maskNode.active = true;
|
||
|
}
|
||
|
this.spineNode.active = true
|
||
|
this.spineNode.getComponent(sp.Skeleton).setAnimation(0, this.spineAnim, false)
|
||
|
this.spineNode.getComponent(sp.Skeleton).setCompleteListener(callbacks);
|
||
|
} else {
|
||
|
callbacks();
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
if (target["recoveposi"]) {
|
||
|
this.nodeMoveToRecovery(target, target["recoveposi"], ()=>{
|
||
|
|
||
|
|
||
|
})
|
||
|
}
|
||
|
|
||
|
target.resumeAllActions();
|
||
|
|
||
|
if(jihuoNode){
|
||
|
|
||
|
}else{
|
||
|
if( this.needChangeOpacity ){
|
||
|
target.opacity = 0
|
||
|
for (const iterator of this.relatedOpacityShowNodes) {
|
||
|
iterator.active = false;
|
||
|
}
|
||
|
for (const iterator of this.relatedOpacityHideNodes) {
|
||
|
iterator.active = true;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
if(this.parenrChangeZindexNode){
|
||
|
this.parenrChangeZindexNode.zIndex = this.zIndexNum
|
||
|
if(this.coverZindexNodes){
|
||
|
for (const iterator of this.coverZindexNodes) {
|
||
|
iterator.zIndex = this.zIndexNum+1
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
nodeMoveToRecovery(node, oldPosi: cc.Vec2, func?: Function) {
|
||
|
if (this.isToRecovery) {
|
||
|
cc.tween(node)
|
||
|
.to(0.1, { position: node.parent.convertToNodeSpaceAR(node['saveWorldPos']) })
|
||
|
.set({ position: oldPosi })
|
||
|
.call(() => {
|
||
|
if (func) {
|
||
|
func()
|
||
|
}
|
||
|
})
|
||
|
.start()
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// update (dt) {}
|
||
|
}
|