mirror of
https://github.com/barsdeveloper/ueblueprint.git
synced 2026-03-04 14:27:29 +08:00
Various improvements
This commit is contained in:
@@ -1,3 +1,4 @@
|
||||
import Configuration from "../../Configuration"
|
||||
import Pointing from "./Pointing"
|
||||
|
||||
/**
|
||||
@@ -54,6 +55,12 @@ export default class MouseClickDrag extends Pointing {
|
||||
// Do actual actions
|
||||
self.startDrag()
|
||||
self.started = true
|
||||
const dragEvent = new CustomEvent(Configuration.trackingMouseEventName.begin, {
|
||||
bubbles: true,
|
||||
cancelable: true
|
||||
})
|
||||
this.target.dispatchEvent(dragEvent)
|
||||
return true
|
||||
}
|
||||
|
||||
this.mouseMoveHandler = e => {
|
||||
@@ -62,6 +69,8 @@ export default class MouseClickDrag extends Pointing {
|
||||
const location = self.locationFromEvent(e)
|
||||
const movement = [e.movementX, e.movementY]
|
||||
self.dragTo(location, movement)
|
||||
self.blueprint.entity.mousePosition = self.locationFromEvent(e)
|
||||
return true
|
||||
}
|
||||
|
||||
this.mouseUpHandler = e => {
|
||||
@@ -71,7 +80,14 @@ export default class MouseClickDrag extends Pointing {
|
||||
movementListenedElement.removeEventListener("mousemove", self.mouseMoveHandler)
|
||||
document.removeEventListener("mouseup", self.mouseUpHandler)
|
||||
self.endDrag()
|
||||
const dragEvent = new CustomEvent(Configuration.trackingMouseEventName.end, {
|
||||
bubbles: true,
|
||||
cancelable: true
|
||||
})
|
||||
this.target.dispatchEvent(dragEvent)
|
||||
return true
|
||||
}
|
||||
return false
|
||||
}
|
||||
|
||||
this.target.addEventListener("mousedown", this.mouseDownHandler)
|
||||
|
||||
@@ -1,3 +1,4 @@
|
||||
import Configuration from "../../Configuration"
|
||||
import Pointing from "./Pointing"
|
||||
|
||||
export default class MouseTracking extends Pointing {
|
||||
@@ -6,18 +7,43 @@ export default class MouseTracking extends Pointing {
|
||||
options.wantsFocusCallback = true
|
||||
super(target, blueprint, options)
|
||||
|
||||
this.trackingStolen = null
|
||||
let self = this
|
||||
this.mousemoveHandler = e => {
|
||||
self.blueprint.entity.mousePosition = self.locationFromEvent(e)
|
||||
return true
|
||||
}
|
||||
this.trackingMouseStolenHandler = e => {
|
||||
this.trackingStolen = e.target
|
||||
self.unlistenMouseMove()
|
||||
return true
|
||||
}
|
||||
this.trackingMouseGaveBackHandler = e => {
|
||||
if (!this.trackingStolen == e.target) {
|
||||
return false
|
||||
}
|
||||
self.listenMouseMove()
|
||||
return true
|
||||
}
|
||||
}
|
||||
|
||||
blueprintFocused() {
|
||||
listenMouseMove() {
|
||||
this.target.addEventListener("mousemove", this.mousemoveHandler)
|
||||
}
|
||||
|
||||
blueprintUnfocused() {
|
||||
unlistenMouseMove() {
|
||||
this.target.removeEventListener("mousemove", this.mousemoveHandler)
|
||||
}
|
||||
|
||||
listenEvents() {
|
||||
this.listenMouseMove()
|
||||
this.blueprint.addEventListener(Configuration.trackingMouseEventName.begin, this.trackingMouseStolenHandler)
|
||||
this.blueprint.addEventListener(Configuration.trackingMouseEventName.end, this.trackingMouseGaveBackHandler)
|
||||
}
|
||||
|
||||
unlistenEvents() {
|
||||
this.unlistenMouseMove()
|
||||
this.blueprint.removeEventListener(Configuration.trackingMouseEventName.begin, this.trackingMouseStolenHandler)
|
||||
this.blueprint.removeEventListener(Configuration.trackingMouseEventName.end, this.trackingMouseGaveBackHandler)
|
||||
}
|
||||
}
|
||||
|
||||
@@ -27,12 +27,12 @@ export default class MouseWheel extends Pointing {
|
||||
}
|
||||
}
|
||||
|
||||
blueprintFocused() {
|
||||
listenEvents() {
|
||||
this.movementSpace.addEventListener("wheel", this.mouseWheelHandler, false)
|
||||
this.movementSpace.parentElement?.addEventListener("wheel", this.mouseParentWheelHandler)
|
||||
}
|
||||
|
||||
blueprintUnfocused() {
|
||||
unlistenEvents() {
|
||||
this.movementSpace.removeEventListener("wheel", this.mouseWheelHandler, false)
|
||||
this.movementSpace.parentElement?.removeEventListener("wheel", this.mouseParentWheelHandler)
|
||||
}
|
||||
|
||||
@@ -25,11 +25,11 @@ export default class Unfocus extends Context {
|
||||
this.blueprint.setFocused(false)
|
||||
}
|
||||
|
||||
blueprintFocused() {
|
||||
listenEvents() {
|
||||
document.addEventListener("click", this.clickHandler)
|
||||
}
|
||||
|
||||
blueprintUnfocused() {
|
||||
unlistenEvents() {
|
||||
document.removeEventListener("click", this.clickHandler)
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user