mirror of
https://github.com/JulianGro/overte.git
synced 2025-04-29 22:43:03 +02:00
Merge pull request #10914 from sethalves/dont-think-during-mouse-move
Dont think during mouse move
This commit is contained in:
commit
121cf76ee3
2 changed files with 55 additions and 9 deletions
scripts/system
|
@ -14,7 +14,8 @@
|
|||
// See the accompanying file LICENSE or http://www.apache.org/licenses/LICENSE-2.0.html
|
||||
//
|
||||
|
||||
/* global MyAvatar, Entities, Script, Camera, Vec3, Reticle, Overlays, getEntityCustomData, Messages, Quat, Controller */
|
||||
/* global MyAvatar, Entities, Script, Camera, Vec3, Reticle, Overlays, getEntityCustomData, Messages, Quat, Controller,
|
||||
isInEditMode, HMD */
|
||||
|
||||
|
||||
(function() { // BEGIN LOCAL_SCOPE
|
||||
|
@ -22,6 +23,8 @@
|
|||
Script.include("/~/system/libraries/utils.js");
|
||||
var MAX_SOLID_ANGLE = 0.01; // objects that appear smaller than this can't be grabbed
|
||||
|
||||
var DELAY_FOR_30HZ = 33; // milliseconds
|
||||
|
||||
var ZERO_VEC3 = {
|
||||
x: 0,
|
||||
y: 0,
|
||||
|
@ -46,7 +49,7 @@ var ACTION_TTL = 10; // seconds
|
|||
function getTag() {
|
||||
return "grab-" + MyAvatar.sessionUUID;
|
||||
}
|
||||
|
||||
|
||||
var DISTANCE_HOLDING_ACTION_TIMEFRAME = 0.1; // how quickly objects move to their new position
|
||||
var DISTANCE_HOLDING_UNITY_MASS = 1200; // The mass at which the distance holding action timeframe is unmodified
|
||||
var DISTANCE_HOLDING_UNITY_DISTANCE = 6; // The distance at which the distance holding action timeframe is unmodified
|
||||
|
@ -411,10 +414,15 @@ Grabber.prototype.pressEvent = function(event) {
|
|||
};
|
||||
|
||||
Grabber.prototype.releaseEvent = function(event) {
|
||||
if (event.isLeftButton!==true ||event.isRightButton===true || event.isMiddleButton===true) {
|
||||
if (event.isLeftButton!==true || event.isRightButton===true || event.isMiddleButton===true) {
|
||||
return;
|
||||
}
|
||||
|
||||
if (this.moveEventTimer) {
|
||||
Script.clearTimeout(this.moveEventTimer);
|
||||
this.moveEventTimer = null;
|
||||
}
|
||||
|
||||
if (this.isGrabbing) {
|
||||
// this.deactivateEntity(this.entityID);
|
||||
this.isGrabbing = false;
|
||||
|
@ -439,12 +447,28 @@ Grabber.prototype.releaseEvent = function(event) {
|
|||
}
|
||||
};
|
||||
|
||||
Grabber.prototype.scheduleMouseMoveProcessor = function(event) {
|
||||
var _this = this;
|
||||
if (!this.moveEventTimer) {
|
||||
this.moveEventTimer = Script.setTimeout(function() {
|
||||
_this.moveEventProcess();
|
||||
}, DELAY_FOR_30HZ);
|
||||
}
|
||||
};
|
||||
|
||||
Grabber.prototype.moveEvent = function(event) {
|
||||
// during the handling of the event, do as little as possible. We save the updated mouse position,
|
||||
// and start a timer to react to the change. If more changes arrive before the timer fires, only
|
||||
// the last update will be considered. This is done to avoid backing-up Qt's event queue.
|
||||
if (!this.isGrabbing) {
|
||||
return;
|
||||
}
|
||||
mouse.updateDrag(event);
|
||||
this.scheduleMouseMoveProcessor();
|
||||
};
|
||||
|
||||
Grabber.prototype.moveEventProcess = function() {
|
||||
this.moveEventTimer = null;
|
||||
// see if something added/restored gravity
|
||||
var entityProperties = Entities.getEntityProperties(this.entityID);
|
||||
if (!entityProperties || !entityProperties.gravity) {
|
||||
|
@ -489,7 +513,7 @@ Grabber.prototype.moveEvent = function(event) {
|
|||
|
||||
} else {
|
||||
var newPointOnPlane;
|
||||
|
||||
|
||||
if (this.mode === "verticalCylinder") {
|
||||
// for this mode we recompute the plane based on current Camera
|
||||
var planeNormal = Quat.getForward(Camera.getOrientation());
|
||||
|
@ -505,7 +529,7 @@ Grabber.prototype.moveEvent = function(event) {
|
|||
};
|
||||
|
||||
} else {
|
||||
|
||||
|
||||
newPointOnPlane = mouseIntersectionWithPlane(
|
||||
this.pointOnPlane, this.planeNormal, mouse.current, this.maxDistance);
|
||||
var relativePosition = Vec3.subtract(newPointOnPlane, cameraPosition);
|
||||
|
@ -538,6 +562,8 @@ Grabber.prototype.moveEvent = function(event) {
|
|||
} else {
|
||||
Entities.updateAction(this.entityID, this.actionID, actionArgs);
|
||||
}
|
||||
|
||||
this.scheduleMouseMoveProcessor();
|
||||
};
|
||||
|
||||
Grabber.prototype.keyReleaseEvent = function(event) {
|
||||
|
|
|
@ -14,8 +14,6 @@ Script.include(Script.resolvePath("../libraries/utils.js"));
|
|||
Script.include(Script.resolvePath("../libraries/controllers.js"));
|
||||
Script.include(Script.resolvePath("../libraries/Xform.js"));
|
||||
|
||||
var VEC3_ZERO = {x: 0, y: 0, z: 0};
|
||||
var X_AXIS = {x: 1, y: 0, z: 0};
|
||||
var Y_AXIS = {x: 0, y: 1, z: 0};
|
||||
var DEFAULT_DPI = 34;
|
||||
var DEFAULT_WIDTH = 0.4375;
|
||||
|
@ -25,12 +23,13 @@ var CAMERA_MATRIX = -7;
|
|||
var ROT_Y_180 = {x: 0.0, y: 1.0, z: 0, w: 0};
|
||||
var ROT_LANDSCAPE = {x: 1.0, y: 1.0, z: 0, w: 0};
|
||||
var ROT_LANDSCAPE_WINDOW = {x: 0.0, y: 0.0, z: 0.0, w: 0};
|
||||
var ROT_IDENT = {x: 0, y: 0, z: 0, w: 1};
|
||||
var TABLET_TEXTURE_RESOLUTION = { x: 480, y: 706 };
|
||||
var INCHES_TO_METERS = 1 / 39.3701;
|
||||
var AVATAR_SELF_ID = "{00000000-0000-0000-0000-000000000001}";
|
||||
|
||||
var NO_HANDS = -1;
|
||||
var DELAY_FOR_30HZ = 33; // milliseconds
|
||||
|
||||
|
||||
// will need to be recaclulated if dimensions of fbx model change.
|
||||
var TABLET_NATURAL_DIMENSIONS = {x: 33.797, y: 50.129, z: 2.269};
|
||||
|
@ -561,9 +560,29 @@ function rayIntersectPlane(planePosition, planeNormal, rayStart, rayDirection) {
|
|||
}
|
||||
}
|
||||
|
||||
WebTablet.prototype.scheduleMouseMoveProcessor = function() {
|
||||
var _this = this;
|
||||
if (!this.moveEventTimer) {
|
||||
this.moveEventTimer = Script.setTimeout(function() {
|
||||
_this.mouseMoveProcessor();
|
||||
}, DELAY_FOR_30HZ);
|
||||
}
|
||||
};
|
||||
|
||||
WebTablet.prototype.mouseMoveEvent = function (event) {
|
||||
if (this.dragging) {
|
||||
var pickRay = Camera.computePickRay(event.x, event.y);
|
||||
this.currentMouse = {
|
||||
x: event.x,
|
||||
y: event.y
|
||||
};
|
||||
this.scheduleMouseMoveProcessor();
|
||||
}
|
||||
};
|
||||
|
||||
WebTablet.prototype.mouseMoveProcessor = function () {
|
||||
this.moveEventTimer = null;
|
||||
if (this.dragging) {
|
||||
var pickRay = Camera.computePickRay(this.currentMouse.x, this.currentMouse.y);
|
||||
|
||||
// transform pickRay into camera local coordinates
|
||||
var invCameraXform = new Xform(Camera.orientation, Camera.position).inv();
|
||||
|
@ -582,6 +601,7 @@ WebTablet.prototype.mouseMoveEvent = function (event) {
|
|||
localPosition: localPosition
|
||||
});
|
||||
}
|
||||
this.scheduleMouseMoveProcessor();
|
||||
}
|
||||
};
|
||||
|
||||
|
|
Loading…
Reference in a new issue