|
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140 |
- мир.объекты = {
- умолчание: {
- x: 100,
- y: 100,
- ширина: 40,
- высота: 20,
- статика: true,
- },
- задано: {},
- тела: {},
- элементы: {},
- свойстваТела: ["x", "y", "ширина", "высота", "статика"],
- обновить: обновитьОбъекты,
- };
-
-
- // // // //
-
-
- мир.ключники.push(function(ключ, путь, значение){
- if (!ключ.startsWith("объекты"))
- {
- return;
- }
-
- var имя = путь[1];
- var свойство = путь[2];
-
- сохранитьЗаданноеЗначение(имя, свойство, значение);
- пересоздатьТело(имя, свойство, значение);
- обновитьЭлемент(имя, свойство, значение);
- обновитьВидЭлемента(путь, имя, свойство, значение);
- });
-
-
- // // // //
-
-
- function обновитьОбъекты()
- {
- for (var имя in мир.объекты.тела)
- {
- var тело = мир.объекты.тела[имя];
- if (тело.isSleeping)
- {
- continue;
- }
- var элемент = мир.объекты.элементы[имя];
- let x = тело.position.x - элемент.offsetWidth / 2;
- let y = тело.position.y - элемент.offsetHeight / 2;
- let угол = тело.angle;
- элемент.style.transform = `translate(${x}px, ${y}px) rotate(${угол}rad)`;
- }
- }
-
- function сохранитьЗаданноеЗначение(имя, свойство, значение)
- {
- if (!(имя in мир.объекты.задано))
- {
- мир.объекты.задано[имя] = {};
- }
- мир.объекты.задано[имя][свойство] = значение;
- }
-
- function пересоздатьТело(имя, свойство, значение)
- {
- if (!мир.объекты.свойстваТела.includes(свойство))
- {
- return;
- }
-
- // Удалить физическое тело.
- if (имя in мир.объекты.тела)
- {
- var тело = мир.объекты.тела[имя];
- Matter.Composite.remove(мир.физика.движок.world, тело);
- }
- // Пересоздать физическое тело.
- var за = мир.объекты.задано[имя];
- var ум = мир.объекты.умолчание;
-
- var x = за["x"] ? за["x"] : ум["x"];
- var y = за["y"] ? за["y"] : ум["y"];
- var ширина = за["ширина"] ? за["ширина"] : ум["ширина"];
- var высота = за["высота"] ? за["высота"] : ум["высота"];
- var свойства = {
- isStatic: ("статика" in за) ? за.статика : ум.статика,
- inertia: Infinity,
- };
-
- var тело = Matter.Bodies.rectangle(x, y, ширина, высота, свойства);
- Matter.Composite.add(мир.физика.движок.world, тело);
- мир.объекты.тела[имя] = тело;
- }
-
- function обновитьЭлемент(имя, свойство, значение)
- {
- var за = мир.объекты.задано[имя];
- var ум = мир.объекты.умолчание;
-
- if (!(имя in мир.объекты.элементы))
- {
- var элемент = document.createElement("div");
- элемент.id = `объекты-${имя}`;
- элемент.style.position = "absolute";
- элемент.style.display = "block";
- элемент.style.transformOrigin = "center";
- document.getElementById("корень").appendChild(элемент);
- мир.объекты.элементы[имя] = элемент;
- // Свойства по умолчанию.
- элемент.style.width = `${ум.ширина}px`;
- элемент.style.height = `${ум.высота}px`;
- }
-
- var элемент = мир.объекты.элементы[имя];
-
- if (свойство == "ширина")
- {
- var ширина = за["ширина"] ? за["ширина"] : ум["ширина"];
- элемент.style.width = `${ширина}px`;
- }
- else if (свойство == "высота")
- {
- var высота = за["высота"] ? за["высота"] : ум["высота"];
- элемент.style.height = `${высота}px`;
- }
- }
-
- function обновитьВидЭлемента(путь, имя, свойство, значение)
- {
- if (свойство != "вид")
- {
- return;
- }
-
- var элемент = мир.объекты.элементы[имя];
- var параметр = путь[3];
- элемент.style.setProperty(параметр, значение);
- console.debug(имя, свойство, параметр, значение);
- }
|