свойства физ
This commit is contained in:
@@ -4,12 +4,14 @@
|
|||||||
y: 100,
|
y: 100,
|
||||||
ширина: 40,
|
ширина: 40,
|
||||||
высота: 20,
|
высота: 20,
|
||||||
статика: true,
|
физика: {
|
||||||
|
isStatic: true,
|
||||||
|
},
|
||||||
},
|
},
|
||||||
задано: {},
|
задано: {},
|
||||||
тела: {},
|
тела: {},
|
||||||
элементы: {},
|
элементы: {},
|
||||||
свойстваТела: ["x", "y", "ширина", "высота", "статика"],
|
свойстваТела: ["x", "y", "ширина", "высота", "физика"],
|
||||||
обновить: обновитьОбъекты,
|
обновить: обновитьОбъекты,
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -26,8 +28,14 @@
|
|||||||
var имя = путь[1];
|
var имя = путь[1];
|
||||||
var свойство = путь[2];
|
var свойство = путь[2];
|
||||||
|
|
||||||
сохранитьЗаданноеЗначение(имя, свойство, значение);
|
if (!(имя in мир.объекты.задано))
|
||||||
пересоздатьТело(имя, свойство, значение);
|
{
|
||||||
|
мир.объекты.задано[имя] = {};
|
||||||
|
}
|
||||||
|
var свойствоПуть = путь.slice(2).join(".");
|
||||||
|
мир.объекты.задано[имя][свойствоПуть] = значение;
|
||||||
|
|
||||||
|
пересоздатьТело(имя, свойство);
|
||||||
обновитьЭлемент(имя, свойство, значение);
|
обновитьЭлемент(имя, свойство, значение);
|
||||||
обновитьВидЭлемента(путь, имя, свойство, значение);
|
обновитьВидЭлемента(путь, имя, свойство, значение);
|
||||||
});
|
});
|
||||||
@@ -53,16 +61,11 @@ function обновитьОбъекты()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function сохранитьЗаданноеЗначение(имя, свойство, значение)
|
|
||||||
{
|
|
||||||
if (!(имя in мир.объекты.задано))
|
|
||||||
{
|
|
||||||
мир.объекты.задано[имя] = {};
|
|
||||||
}
|
|
||||||
мир.объекты.задано[имя][свойство] = значение;
|
|
||||||
}
|
|
||||||
|
|
||||||
function пересоздатьТело(имя, свойство, значение)
|
// // // //
|
||||||
|
|
||||||
|
|
||||||
|
function пересоздатьТело(имя, свойство)
|
||||||
{
|
{
|
||||||
if (!мир.объекты.свойстваТела.includes(свойство))
|
if (!мир.объекты.свойстваТела.includes(свойство))
|
||||||
{
|
{
|
||||||
@@ -79,16 +82,22 @@ function пересоздатьТело(имя, свойство, значени
|
|||||||
var за = мир.объекты.задано[имя];
|
var за = мир.объекты.задано[имя];
|
||||||
var ум = мир.объекты.умолчание;
|
var ум = мир.объекты.умолчание;
|
||||||
|
|
||||||
var x = за["x"] ? за["x"] : ум["x"];
|
var x = за.x ? за.x : ум.x;
|
||||||
var y = за["y"] ? за["y"] : ум["y"];
|
var y = за.y ? за.y : ум.y;
|
||||||
var ширина = за["ширина"] ? за["ширина"] : ум["ширина"];
|
var ширина = за.ширина ? за.ширина : ум.ширина;
|
||||||
var высота = за["высота"] ? за["высота"] : ум["высота"];
|
var высота = за.высота ? за.высота : ум.высота;
|
||||||
var свойства = {
|
var физика = {};
|
||||||
isStatic: ("статика" in за) ? за.статика : ум.статика,
|
Object.assign(физика, ум.физика);
|
||||||
inertia: Infinity,
|
for (var путь in за)
|
||||||
};
|
{
|
||||||
|
if (путь.startsWith("физика"))
|
||||||
|
{
|
||||||
|
var свойство = путь.slice(7);
|
||||||
|
физика[свойство] = за[путь];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
var тело = Matter.Bodies.rectangle(x, y, ширина, высота, свойства);
|
var тело = Matter.Bodies.rectangle(x, y, ширина, высота, физика);
|
||||||
Matter.Composite.add(мир.физика.движок.world, тело);
|
Matter.Composite.add(мир.физика.движок.world, тело);
|
||||||
мир.объекты.тела[имя] = тело;
|
мир.объекты.тела[имя] = тело;
|
||||||
}
|
}
|
||||||
@@ -136,5 +145,4 @@ function обновитьВидЭлемента(путь, имя, свойств
|
|||||||
var элемент = мир.объекты.элементы[имя];
|
var элемент = мир.объекты.элементы[имя];
|
||||||
var параметр = путь[3];
|
var параметр = путь[3];
|
||||||
элемент.style.setProperty(параметр, значение);
|
элемент.style.setProperty(параметр, значение);
|
||||||
console.debug(имя, свойство, параметр, значение);
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -24,7 +24,10 @@
|
|||||||
y: 150,
|
y: 150,
|
||||||
ширина: 60,
|
ширина: 60,
|
||||||
высота: 60,
|
высота: 60,
|
||||||
статика: false,
|
физика: {
|
||||||
|
isStatic: false,
|
||||||
|
inertia: Infinity,
|
||||||
|
},
|
||||||
вид: {
|
вид: {
|
||||||
background: "url(р/колобок/колобок_неподвижен.png) no-repeat scroll 50% 0% / contain",
|
background: "url(р/колобок/колобок_неподвижен.png) no-repeat scroll 50% 0% / contain",
|
||||||
},
|
},
|
||||||
|
|||||||
Reference in New Issue
Block a user