58 lines
2.1 KiB
TypeScript
Raw Normal View History

2022-08-26 16:48:17 +08:00
const { ccclass, property } = cc._decorator;
/** 物品拖動 */
@ccclass
export default class DragItem extends cc.Component {
//#region Lifecycle
protected onLoad(): void {
// 獲取小節點
let carNode: cc.Node = this.node;
// 新增變數判斷使用者當前滑鼠是不是處於按下狀態
let mouseDown: boolean = false;
// 當使用者點選的時候記錄滑鼠點選狀態
carNode.on(cc.Node.EventType.MOUSE_DOWN, (event) => {
mouseDown = true;
});
// 只有當使用者滑鼠按下才能拖拽
carNode.on(cc.Node.EventType.MOUSE_MOVE, (event) => {
if (!mouseDown) { return; }
// 獲取滑鼠距離上一次點的資訊
let delta: any = event.getDelta();
let canvasNode: cc.Node = cc.Canvas.instance.node;
// 增加限定條件
let minX: number = -canvasNode.width / 2 + carNode.width / 2;
let maxX: number = canvasNode.width / 2 - carNode.width / 2;
let minY: number = -canvasNode.height / 2 + carNode.height / 2;
let maxY: number = canvasNode.height / 2 - carNode.height / 2;
let moveX: number = carNode.x + delta.x;
let moveY: number = carNode.y + delta.y;
// 控制移動範圍
if (moveX < minX) {
moveX = minX;
} else if (moveX > maxX) {
moveX = maxX;
}
if (moveY < minY) {
moveY = minY;
} else if (moveY > maxY) {
moveY = maxY;
}
// 移動小車節點
carNode.x = moveX;
carNode.y = moveY;
});
// 當滑鼠抬起的時候恢復狀態
carNode.on(cc.Node.EventType.MOUSE_UP, (event) => {
mouseDown = false;
});
carNode.on(cc.Node.EventType.TOUCH_END, (event) => {
mouseDown = false;
});
carNode.on(cc.Node.EventType.TOUCH_CANCEL, (event) => {
mouseDown = false;
});
}
//#endregion
}