Compare commits
6 Commits
804aa6dc8d
...
1d2caf9d74
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
1d2caf9d74 | ||
|
|
164ddbb896 | ||
|
|
bddc7075a0 | ||
|
|
c29a00c327 | ||
|
|
e10d402ed3 | ||
|
|
bed828e0b8 |
@@ -25,8 +25,8 @@ const ИМЯ_ОТЛ_РАСКЛАДКИ = "Отладочные раскладк
|
|||||||
ЗагрузитьОтладочнуюРаскладку = мир =>
|
ЗагрузитьОтладочнуюРаскладку = мир =>
|
||||||
{
|
{
|
||||||
var модуль = мир.модули.модульПоИмени(ИМЯ_ОТЛ_РАСКЛАДКИ);
|
var модуль = мир.модули.модульПоИмени(ИМЯ_ОТЛ_РАСКЛАДКИ);
|
||||||
//var ресурс = "/успех|success.layout";
|
var ресурс = "/успех|success.layout";
|
||||||
var ресурс = "/провал|failure.layout";
|
//var ресурс = "/провал|failure.layout";
|
||||||
var содержимое = модуль.содержимое[ресурс];
|
var содержимое = модуль.содержимое[ресурс];
|
||||||
мир.раскладкаKMahjongg = {
|
мир.раскладкаKMahjongg = {
|
||||||
"содержимое": содержимое,
|
"содержимое": содержимое,
|
||||||
|
|||||||
139
фишки|tiles.js
139
фишки|tiles.js
@@ -3,6 +3,106 @@
|
|||||||
// // // //
|
// // // //
|
||||||
|
|
||||||
|
|
||||||
|
ВывестиПобеду = мир =>
|
||||||
|
{
|
||||||
|
console.debug("ПОБЕДА");
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
// // // //
|
||||||
|
|
||||||
|
|
||||||
|
ВывестиПоражение = мир =>
|
||||||
|
{
|
||||||
|
console.debug("ПОРАЖЕНИЕ");
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
// // // //
|
||||||
|
|
||||||
|
|
||||||
|
ПроверитьНаличиеФишекНаИгровомПоле = мир =>
|
||||||
|
{
|
||||||
|
if (Object.keys(мир.индексыФишек).length > 0)
|
||||||
|
{
|
||||||
|
мир.уведомить("фишки на игровом поле присутствуют");
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
мир.уведомить("фишки на игровом поле отсутствуют");
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
// // // //
|
||||||
|
|
||||||
|
|
||||||
|
ВывестиПрисутствиеХодов = мир =>
|
||||||
|
{
|
||||||
|
console.debug("ходы есть");
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
// // // //
|
||||||
|
|
||||||
|
|
||||||
|
ВывестиОтсутствиеХодов = мир =>
|
||||||
|
{
|
||||||
|
console.debug("ходов нет");
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
// // // //
|
||||||
|
|
||||||
|
|
||||||
|
ПроверитьНаличиеХодов = мир =>
|
||||||
|
{
|
||||||
|
var номера = мир.доступныеДляВыбораНомераФишек;
|
||||||
|
for (var н0 in номера)
|
||||||
|
{
|
||||||
|
for (var н1 in номера)
|
||||||
|
{
|
||||||
|
// Пропускаем одну и ту же фишку.
|
||||||
|
if (н0 == н1)
|
||||||
|
{
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
var номер0 = номера[н0];
|
||||||
|
var номер1 = номера[н1];
|
||||||
|
var группа0 = мир.группыФишек[номер0];
|
||||||
|
var группа1 = мир.группыФишек[номер1];
|
||||||
|
if (группа0 == группа1)
|
||||||
|
{
|
||||||
|
мир.уведомить("ходы присутствуют");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
мир.уведомить("ходы отсутствуют");
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
// // // //
|
||||||
|
|
||||||
|
|
||||||
|
СобратьДоступныеДляВыбораНомераФишек = мир =>
|
||||||
|
{
|
||||||
|
мир.доступныеДляВыбораНомераФишек = [];
|
||||||
|
for (индекс in мир.индексыФишек)
|
||||||
|
{
|
||||||
|
if (фишкуМожноВыбрать(мир.индексыФишек, индекс))
|
||||||
|
{
|
||||||
|
var фишка = мир.индексыФишек[индекс];
|
||||||
|
var номер = номерФишки(мир.фишки, фишка.id);
|
||||||
|
мир.доступныеДляВыбораНомераФишек.push(номер);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
// // // //
|
||||||
|
|
||||||
|
|
||||||
ЗапуститьПлавноеСкрытиеФишек = мир =>
|
ЗапуститьПлавноеСкрытиеФишек = мир =>
|
||||||
{
|
{
|
||||||
var шаг = 10;
|
var шаг = 10;
|
||||||
@@ -11,7 +111,6 @@
|
|||||||
var дельтаПрозрачности = шаг / длительность;
|
var дельтаПрозрачности = шаг / длительность;
|
||||||
const анимация = setInterval(
|
const анимация = setInterval(
|
||||||
function() {
|
function() {
|
||||||
const позиции = мир.раскладкаKMahjongg.позиции;
|
|
||||||
прозрачность -= дельтаПрозрачности;
|
прозрачность -= дельтаПрозрачности;
|
||||||
// Возвращаем прозрачность материалам перед последующим скрытием фишек.
|
// Возвращаем прозрачность материалам перед последующим скрытием фишек.
|
||||||
// И планируем выход из этой анимации.
|
// И планируем выход из этой анимации.
|
||||||
@@ -214,25 +313,6 @@
|
|||||||
|
|
||||||
ОкраситьНайденнуюФишку = мир =>
|
ОкраситьНайденнуюФишку = мир =>
|
||||||
{
|
{
|
||||||
/*
|
|
||||||
// Очищаем цвета всех фишек.
|
|
||||||
for (var номер in мир.фишки)
|
|
||||||
{
|
|
||||||
var фишка = мир.фишки[номер];
|
|
||||||
var группа = мир.группыФишек[номер];
|
|
||||||
var материал = мир.материалыФишек[группа];
|
|
||||||
фишка.material = материал;
|
|
||||||
}
|
|
||||||
// Окрашиваем выбранные фишки.
|
|
||||||
for (var id in мир.номераВыбранныхФишек)
|
|
||||||
{
|
|
||||||
var номер = мир.номераВыбранныхФишек[id];
|
|
||||||
var фишка = мир.фишки[номер];
|
|
||||||
var группа = мир.группыФишек[номер];
|
|
||||||
var материал = мир.материалыВыбранныхФишек[группа];
|
|
||||||
фишка.material = материал;
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
var номер = мир.номерНайденнойФишки;
|
var номер = мир.номерНайденнойФишки;
|
||||||
var фишка = мир.фишки[номер];
|
var фишка = мир.фишки[номер];
|
||||||
var группа = мир.группыФишек[номер];
|
var группа = мир.группыФишек[номер];
|
||||||
@@ -266,25 +346,12 @@
|
|||||||
|
|
||||||
ПроверитьДоступностьФишкиДляВыбора = мир =>
|
ПроверитьДоступностьФишкиДляВыбора = мир =>
|
||||||
{
|
{
|
||||||
// Проверяем заблокированность фишки одновременно с обеих сторон.
|
|
||||||
var позиция = мир.раскладкаKMahjongg.позиции[мир.номерНайденнойФишки];
|
var позиция = мир.раскладкаKMahjongg.позиции[мир.номерНайденнойФишки];
|
||||||
var слева = уФишкиЕстьСоседи(мир.индексыФишек, позиция, 0, -2);
|
var индекс = индексПозицииФишки(позиция);
|
||||||
var справа = уФишкиЕстьСоседи(мир.индексыФишек, позиция, 0, 2);
|
if (фишкуМожноВыбрать(мир.индексыФишек, индекс))
|
||||||
if (слева && справа)
|
|
||||||
{
|
{
|
||||||
return;
|
мир.уведомить("фишка доступна для выбора");
|
||||||
}
|
}
|
||||||
|
|
||||||
// Проверяем заблокированность сверху.
|
|
||||||
for (var смещениеСтолбца = -1; смещениеСтолбца < 2; ++смещениеСтолбца)
|
|
||||||
{
|
|
||||||
if (уФишкиЕстьСоседи(мир.индексыФишек, позиция, 1, смещениеСтолбца))
|
|
||||||
{
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
мир.уведомить("фишка доступна для выбора");
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -26,10 +26,10 @@
|
|||||||
отключить возможность поиска фишки
|
отключить возможность поиска фишки
|
||||||
сравнить выбранные фишки
|
сравнить выбранные фишки
|
||||||
фишки совпадают
|
фишки совпадают
|
||||||
вывести совпадение фишек
|
# вывести совпадение фишек
|
||||||
плавно скрыть фишки
|
плавно скрыть фишки
|
||||||
фишки не совпадают
|
фишки не совпадают
|
||||||
вывести различие фишек
|
# вывести различие фишек
|
||||||
очистить окрашивание первой найденной фишки
|
очистить окрашивание первой найденной фишки
|
||||||
очистить выбор первой найденной фишки
|
очистить выбор первой найденной фишки
|
||||||
включить возможность поиска фишки
|
включить возможность поиска фишки
|
||||||
@@ -40,4 +40,15 @@
|
|||||||
скрыть совпадающие фишки
|
скрыть совпадающие фишки
|
||||||
очистить индексы выбранных фишек
|
очистить индексы выбранных фишек
|
||||||
очистить выбор фишек
|
очистить выбор фишек
|
||||||
|
собрать доступные для выбора номера фишек
|
||||||
|
проверить наличие ходов
|
||||||
|
ходы присутствуют
|
||||||
|
вывести присутствие ходов
|
||||||
включить возможность поиска фишки
|
включить возможность поиска фишки
|
||||||
|
ходы отсутствуют
|
||||||
|
вывести отсутствие ходов
|
||||||
|
проверить наличие фишек на игровом поле
|
||||||
|
фишки на игровом поле присутствуют
|
||||||
|
вывести поражение
|
||||||
|
фишки на игровом поле отсутствуют
|
||||||
|
вывести победу
|
||||||
@@ -1,5 +1,29 @@
|
|||||||
|
|
||||||
|
|
||||||
|
фишкуМожноВыбрать = (индексы, индекс) =>
|
||||||
|
{
|
||||||
|
var позиция = позицияИндексаФишки(индекс);
|
||||||
|
// Проверяем заблокированность фишки одновременно с обеих сторон.
|
||||||
|
var слева = уФишкиЕстьСоседи(индексы, позиция, 0, -2);
|
||||||
|
var справа = уФишкиЕстьСоседи(индексы, позиция, 0, 2);
|
||||||
|
if (слева && справа)
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Проверяем заблокированность сверху.
|
||||||
|
for (var смещениеСтолбца = -1; смещениеСтолбца < 2; ++смещениеСтолбца)
|
||||||
|
{
|
||||||
|
if (уФишкиЕстьСоседи(индексы, позиция, 1, смещениеСтолбца))
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
// // // //
|
// // // //
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user