2024-07-21 13:44:40 +04:00

78 lines
2.1 KiB
JavaScript
Executable File

import {
math, Globe, control, utils, LonLat, GlobusTerrain, Vector, OpenStreetMap, Entity, Bing, GlobusRgbTerrain, Object3d
} from "../../lib/@openglobus/og.esm.js";
let myObjects = new Vector("MyObjects", {
scaleByDistance: [200, 190000, 1]
});
function setPitch(a) {
myObjects.each((e) => {
e.geoObject.setPitch(a)
});
}
function setYaw(a) {
myObjects.each((e) => {
e.geoObject.setYaw(a);
});
}
function setRoll(a) {
myObjects.each((e) => {
e.geoObject.setRoll(a);
});
}
async function main() {
let sat = new Bing();
let osm = new OpenStreetMap();
const planeObj3d = await Object3d.loadObj('./airplane.obj');
document.querySelector(".gpitch").addEventListener("input", (e) => {
setPitch(Number(e.target.value) * math.RADIANS);
});
document.querySelector(".gyaw").addEventListener("input", (e) => {
setYaw(Number(e.target.value) * math.RADIANS);
});
document.querySelector(".groll").addEventListener("input", (e) => {
setRoll(Number(e.target.value) * math.RADIANS);
});
for (let i = -80; i < 80; i += 10) {
for (let j = -180; j < 180; j += 10) {
myObjects.add(new Entity({
lonlat: [j, i, 20000], geoObject: {
color: "green",
scale: 10.0,
instanced: true,
tag: "plane",
object3d: planeObj3d[0],
yaw: 0,
pitch: 0
}
}));
}
}
const globus = new Globe({
target: "earth",
name: "Earth",
terrain: new GlobusRgbTerrain(),
layers: [osm, sat, myObjects],
atmosphereEnabled: false,
fontsSrc: "../../res/fonts",
sun: {
stopped: false
}
});
globus.planet.addControl(new control.DebugInfo());
globus.planet.addControl(new control.KeyboardNavigation());
globus.planet.addControl(new control.ToggleWireframe());
globus.planet.addControl(new control.LayerSwitcher());
}
main()