我智商爆棚
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.
wozhishangbaopeng/assets/WordGame/gameComScript/touch/ANodeLineCheckScript.ts

240 lines
7.0 KiB

4 weeks ago
import { ryw_Event } from "../../../FrameWork/Event/EventEnum";
import EventMgr from "../../../FrameWork/Event/EventMgr";
import GameReport from "../../../FrameWork/Report/ZyZyReport";
import Common5 from "../../../Platform/th/Common5";
const { ccclass, property } = cc._decorator;
@ccclass
export default class ANodeReplaceCheckScript2 extends cc.Component {
@property(cc.Node)
emitTarget: cc.Node = null
@property(cc.Graphics)
lineGraphics: cc.Graphics = null
@property(cc.Node)
checkNode: cc.Node = null
@property(cc.Node)
startTouchNode: cc.Node = null
@property(cc.Node)
moveTouchNode: cc.Node = null
@property(cc.Node)
endTouchNode: cc.Node = null
@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[] = []
// LIFE-CYCLE CALLBACKS:
touchStartPosi = null
onLoad() {
if (!this.emitTarget) {
this.emitTarget = this.node
}
this.emitTarget.opacity = 0;
this.initTouchEvent(this.emitTarget, this.checkNode)
}
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 = event.target;
let posi = event.getLocation()//世界坐标
target.opacity = 255;
target.pauseAllActions();
Common5.playEffect("点击音效");
EventMgr.emitEvent_custom(ryw_Event.openBGMove, { open: false });
target['saveWorldPos'] = target.convertToWorldSpaceAR(cc.Vec2.ZERO);
if (this.startTouchNode) {
this.startTouchNode.active = false;
}
if (this.moveTouchNode) {
this.moveTouchNode.active = true;
}
}
initTouchEvent(node, checkNode) {
var attrs = {
checkNode: checkNode,
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()//世界坐标
let posi1 = target.parent.convertToNodeSpaceAR(posi)
target.setPosition(posi1)
let posi2 = this.lineGraphics.node.convertToNodeSpaceAR(posi);
this.lineGraphics.clear();
this.lineGraphics.moveTo(0, 0);
this.lineGraphics.lineTo(posi2.x, posi2.y);
this.lineGraphics.stroke();
}
touchEndNode(event) {
let target = event.target;
let checkNode = target.checkNode;
this.lineGraphics.clear();
if (!this.allowEmitNode || this.allowEmitNode.active) {
if (Common5.checkIntersectsBox(target, checkNode)) {
target.active = false
if (this.effectUrl) {
this.effectUrl.play();
}
let callbacks = () => {
target.checkNode.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;
EventMgr.emitEvent_custom(ryw_Event.NormalTouchMoveCheck, { targetNode: target });
GameReport.BtnsReport(target.name, Common5.selectGameInfo.titleUrl);
console.log("[GameReport]++++++++++++++++++++++>" + target.name);
if (this.endTouchNode) {
if (this.moveTouchNode) {
this.moveTouchNode.active = false;
}
this.endTouchNode.active = true;
}
}
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();
}
this['hasEndSpine'] = true;
}
}
if (target["recoveposi"]) {
if (target["recoveparent"]) {
this.nodeMoveToRecovery(target, target["recoveposi"], target["recoveparent"])
} else {
this.nodeMoveToRecovery(target, target["recoveposi"])
}
}
EventMgr.emitEvent_custom(ryw_Event.openBGMove, { open: true });
}
nodeMoveToRecovery(node, oldPosi: cc.Vec2, recoveparent?: cc.Node, func?: Function) {
cc.tween(node)
.to(0.1, { position: node.parent.convertToNodeSpaceAR(node['saveWorldPos']) })
.set({ parent: recoveparent, position: oldPosi })
.call(() => {
node.opacity = 0;
if (!this['hasEndSpine']) {
if (this.startTouchNode) {
this.startTouchNode.active = true;
}
if (this.moveTouchNode) {
this.moveTouchNode.active = false;
}
}
if (func) {
func()
}
})
.start()
}
// update (dt) {}
}