Похоже, что элементы управления имеют функции activate
и deactivate
, которые добавляют и удаляют все события, что походит на то, что вы ищете:
// create drag controls once and activate or deactivate
const dragControls = new THREE.DragControls(meshes, camera, renderer.domElement);
function dragAndDropActivate() {
let checkBox = document.getElementById("dragAndDropCheckbox");
if (checkBox.checked == true) {
dragControls.activate();
}
else if (checkBox.checked == false) {
dragControls.deactivate();
}
}
Еще одна вещь, которую следует отметить в вашем коде, это то, что способ добавления и удаления событий не будет работать в Javascript, потому что вы создаете новые дескрипторы функций каждый раз, когда вызываете эти функции. Вместо этого вы хотите создать функцию один раз и использовать ту же ссылку при добавлении или удалении слушателей.
function dragEndCallback(event) {
// ...
}
dragControls.addEventListener('dragEnd', dragEndCallback);
dragControls.removeEventListener('dragEnd', dragEndCallback);
Надеюсь, это поможет!