mirror of
https://github.com/JulianGro/overte.git
synced 2025-04-25 14:53:01 +02:00
69 lines
1.9 KiB
JavaScript
69 lines
1.9 KiB
JavaScript
//
|
|
// grabInspector.js
|
|
// examples/debugging/
|
|
//
|
|
// Created by Seth Alves on December 19th, 2015.
|
|
// Copyright 2015 High Fidelity, Inc.
|
|
// Copyright 2023 Overte e.V.
|
|
//
|
|
// Distributed under the Apache License, Version 2.0.
|
|
// See the accompanying file LICENSE or http://www.apache.org/licenses/LICENSE-2.0.html
|
|
//
|
|
|
|
// This script draws an overlay cube around nearby entities to show their queryAABoxes.
|
|
|
|
|
|
Script.include("../libraries/utils.js");
|
|
|
|
var INSPECT_RADIUS = 10;
|
|
var overlays = {};
|
|
|
|
function updateOverlay(entityID, queryAACube) {
|
|
var cubeCenter = {
|
|
x: queryAACube.x + queryAACube.scale / 2.0,
|
|
y: queryAACube.y + queryAACube.scale / 2.0,
|
|
z: queryAACube.z + queryAACube.scale / 2.0
|
|
};
|
|
|
|
if (entityID in overlays) {
|
|
var overlay = overlays[entityID];
|
|
Entities.editEntity(overlay, {
|
|
"position": cubeCenter,
|
|
"size": queryAACube.scale
|
|
});
|
|
} else {
|
|
overlays[entityID] = Entities.addEntity({
|
|
"type": "Shape",
|
|
"shape": "Cube",
|
|
"position": cubeCenter,
|
|
"size": queryAACube.scale,
|
|
"color": {
|
|
"red": 0,
|
|
"green": 0,
|
|
"blue": 255
|
|
},
|
|
"alpha": 1,
|
|
"primitiveMode": "lines",
|
|
"grab": {
|
|
"grabbable": false
|
|
}
|
|
}, "local");
|
|
}
|
|
}
|
|
|
|
Script.setInterval(function() {
|
|
var nearbyEntities = Entities.findEntities(MyAvatar.position, INSPECT_RADIUS);
|
|
for (var entityIndex = 0; entityIndex < nearbyEntities.length; entityIndex++) {
|
|
var entityID = nearbyEntities[entityIndex];
|
|
var queryAACube = Entities.getEntityProperties(entityID, ["queryAACube"]).queryAACube;
|
|
updateOverlay(entityID, queryAACube);
|
|
}
|
|
}, 100);
|
|
|
|
function cleanup() {
|
|
for (var entityID in overlays) {
|
|
Entities.deleteEntity((overlays[entityID]);
|
|
}
|
|
}
|
|
|
|
Script.scriptEnding.connect(cleanup);
|