мир.слежения = { умолчание: { смещение: [0, 0], скорость: 1, }, задано: {}, обновить: обновитьСлежения, }; // // // // мир.ключники.push(function(ключ, путь, значение){ if (!путь[0].startsWith("слежения")) { return; } var имя = путь[1]; var свойство = путь.slice(2).join("."); if (!мир.слежения.задано[имя]) { мир.слежения.задано[имя] = {}; } мир.слежения.задано[имя][свойство] = значение; console.debug("слежения.задано имя/свойство", имя, свойство); }); // // // // function обновитьСлежения() { console.debug("обновитьСлежения"); var за = мир.слежения.задано; var ум = мир.слежения.умолчание; for (var имя in за) { console.debug("обновитьСлежения. имя:", имя); var эл = null; if (имя == "камера") { эл = document.getElementById("корень"); } else { эл = элементСлежения(за[имя]); } var тело = null; var имяТела = за[имя]["объект"]; if (имяТела) { тело = мир.объекты.тела[имяТела]; } обновитьЭлемент(эл, тело, за[имя], ум); } } // // // // function элементСлежения(задано) { var id = null; var изображение = задано["изображение"]; if (изображение) { id = мир.изображения.элементы[изображение].id; } var эл = document.getElementById(id); console.debug("элементСлежения. эл:", эл); return эл; } // // // // function обновитьЭлемент(элемент, тело, задано, умолчание) { if (!элемент || !тело || !умолчание) { return; } console.debug("обновитьЭлемент. элемент:", элемент, "тело:", тело, "за:", задано, "ум:", умолчание); var скорость = задано.скорость ? задано.скорость : умолчание.скорость; var смещениеX = задано.смещение ? задано.смещение[0] : умолание.смещение[0]; var смещениеY = задано.смещение ? задано.смещение[1] : умолание.смещение[1]; // Сейчас. var x0 = 0; if (элемент.style.left.endsWith("px")) { x0 = элемент.style.left.slice(0, -2); } var y0 = 0; if (элемент.style.top.endsWith("px")) { y0 = элемент.style.top.slice(0, -2); } // Цель. //var x1 = window.innerWidth / 2 - тело.position.x; //var y1 = window.innerHeight / 2 - тело.position.y; var x1 = тело.position.x + смещениеX; var y1 = тело.position.y + смещениеY; // Плавно. function lerp(v0, v1, t) { return v0 * (1 - t) + v1 * t; } var x = lerp(x0, x1, скорость); var y = lerp(y0, y1, скорость); корень.style.left = `${x}px`; корень.style.top = `${y}px`; } // // // // function обновитьКамеру() { var объект = мир.камера.задано.объект; var центрировать = мир.камера.задано.центрировать; var тело = мир.объекты.тела[объект]; if (!тело || !центрировать) { return; } var корень = document.getElementById("корень"); // Сейчас. var x0 = 0; if (корень.style.left.endsWith("px")) { x0 = корень.style.left.slice(0, -2); } var y0 = 0; if (корень.style.top.endsWith("px")) { y0 = корень.style.top.slice(0, -2); } // Цель. var x1 = window.innerWidth / 2 - тело.position.x; var y1 = window.innerHeight / 2 - тело.position.y; // Плавно. function lerp(v0, v1, t) { return v0 * (1 - t) + v1 * t; } var x = lerp(x0, x1, центрировать); var y = lerp(y0, y1, центрировать); корень.style.left = `${x}px`; корень.style.top = `${y}px`; }