80LK (обсуждение | вклад) м |
80LK (обсуждение | вклад) м |
||
(не показано 7 промежуточных версий этого же участника) | |||
Строка 2: | Строка 2: | ||
StructuresAPI - библиотека, упрощающая работу со структурами. | StructuresAPI - библиотека, упрощающая работу со структурами. | ||
<div class="mw-parser-output"><div class="mw-parser-output"><div class="mw-parser-output"><div class="mw-parser-output"><div class="mw-parser-output"><div class="mw-parser-output"><div class="mw-parser-output"> | <div class="mw-parser-output"><div class="mw-parser-output"><div class="mw-parser-output"><div class="mw-parser-output"><div class="mw-parser-output"><div class="mw-parser-output"><div class="mw-parser-output"> | ||
+ | <div class="mw-parser-output"> | ||
+ | <div class="mw-parser-output"><div class="mw-parser-output"> | ||
+ | <div class="mw-parser-output"><div class="mw-parser-output"> | ||
== Загрузка == | == Загрузка == | ||
− | {| border="1" cellpadding="1" cellspacing="1" style="width: | + | {| border="1" cellpadding="1" cellspacing="1" style="width: 100%;" |
|- | |- | ||
! colspan="3" scope="col" | '''Библиотека''' | ! colspan="3" scope="col" | '''Библиотека''' | ||
Строка 33: | Строка 36: | ||
*Библиотека переписана. Объект StructuresAPI устарел. | *Библиотека переписана. Объект StructuresAPI устарел. | ||
*Сохраняется содержимое сундуков, печей и воронок | *Сохраняется содержимое сундуков, печей и воронок | ||
+ | |||
+ | |- | ||
+ | | style="width: 64px; text-align: center;" | '''1.3''' | ||
+ | | style="width: 114px; text-align: center;" | [https://vk.com/wall-80513593_2305 Подробнее] | ||
+ | | style="width: 304px;" | | ||
+ | *StructuresAPI удален. | ||
+ | *Добавлен объект Rotate. Используется для сложных поворотов. | ||
+ | *Метод структуры get был изменен. struct.get(x, y, z, rotates, return_index). | ||
+ | *Метод структуры set был изменен. struct.set(x, y, z, rotate, progressively, time). | ||
+ | *Добавлен метод destroy(x, y, z, rotates, progressively, time) для структуры. | ||
+ | *Добавлен метод check(...) для структуры. Эквивалентен методу get(...). | ||
+ | *Добавлен метод Structure.setInWorld(name, ...). Альтернатива Structure.get(name).set(...). | ||
+ | *Добавлен метод Structure.destroyInWorld(name, ...). Альтернатива Structure.get(name).destroy(...). | ||
+ | *Добавлены константы Structure.PROGRESSIVELY и Structure.NOT_PROGRESSIVELY. | ||
+ | *Добавлены константы Structure.MIRROR_X, Structure.MIRROR_Y и Structure.MIRROR_Z. | ||
+ | *Исправлена установка блоков добавленных модом. | ||
+ | *Исправлено сохранение предметов и блоков. | ||
+ | *Исправлен поворот на 180 градусов по Y. | ||
+ | *Сохраняются TileEntity | ||
+ | |||
+ | |- | ||
+ | | style="width: 64px; text-align: center;" | '''1.4''' | ||
+ | | style="width: 114px; text-align: center;" | [https://vk.com/wall-80513593_2410 Подробнее] | ||
+ | | style="width: 304px;" | | ||
+ | *Дополнен перевод. | ||
+ | *Установка структуры производится в потоке, только если установка в режиме Structure.PROGRESSIVELY. | ||
+ | *Блоки воздуха в структуре больше не заменяются на камень. | ||
|- | |- | ||
Строка 39: | Строка 69: | ||
| style="width: 304px;" | | | style="width: 304px;" | | ||
|} | |} | ||
− | </div> </div> | + | </div> </div> |
+ | |||
== Условия использования == | == Условия использования == | ||
Строка 144: | Строка 175: | ||
=== Полный перечень методов и констант === | === Полный перечень методов и констант === | ||
<div class="mw-parser-output"><div class="mw-parser-output"> | <div class="mw-parser-output"><div class="mw-parser-output"> | ||
+ | <div class="mw-parser-output"> | ||
==== Structure ==== | ==== Structure ==== | ||
− | <div class="mw-parser-output"> | + | |
+ | <span style="color:#f39c12;">Добавлен с версии 1.2</span> | ||
+ | <div class="mw-parser-output"><div class="mw-parser-output"> | ||
===== Методы ===== | ===== Методы ===== | ||
Строка 168: | Строка 202: | ||
| Возвращает экземпляр объекта Structure с именем ''name'' | | Возвращает экземпляр объекта Structure с именем ''name'' | ||
+ | |- | ||
+ | | style="text-align: center;" | '''1.3''' | ||
+ | | style="width: 115px;" | setInWorld(string name, int x, int y, int z, array rotate, bool progressively, int time) | ||
+ | | style="width: 248px;" | | ||
+ | *name - Имя структуры | ||
+ | *x - Начальная координата структуры по оси X | ||
+ | *y - Начальная координата структуры по оси Y | ||
+ | *z - Начальная координата структуры по оси Z | ||
+ | *rotate - Массив матриц поворотов | ||
+ | *progressively - Если true, структура будет постепенно "строиться" | ||
+ | *time - Время в миллисекундах между установкой блоков | ||
+ | |||
+ | | Установить структуру ''name'' в мире по координатам ''x,y,z'', с выбраным рандомно поворотм из массива ''rotate'' | ||
+ | |- | ||
+ | | style="text-align: center;" | '''1.3''' | ||
+ | | style="width: 115px;" | destroyInWorld(string name, int x, int y, int z, array rotates, bool progressively, int time) | ||
+ | | style="width: 248px;" | | ||
+ | *name - Имя структуры | ||
+ | *x - Начальная координата структуры по оси X | ||
+ | *y - Начальная координата структуры по оси Y | ||
+ | *z - Начальная координата структуры по оси Z | ||
+ | *rotates - Возможные повороты структуры | ||
+ | *progressively - Если true, структура будет постепенно "строиться" | ||
+ | *time - Время в миллисекундах между установкой блоков | ||
+ | |||
+ | | Установить структуру ''name'' в мире по координатам ''x,y,z'', с возможными поворотами ''rotates'' | ||
|} | |} | ||
− | + | <div class="mw-parser-output"> </div> </div> | |
− | <div class="mw-parser-output"> | ||
===== Константы ===== | ===== Константы ===== | ||
Строка 251: | Строка 310: | ||
| Отражение по оси Z | | Отражение по оси Z | ||
|} | |} | ||
− | </div> | + | </div> <div class="mw-parser-output"> |
− | + | ===== Экземпляр Structure ===== | |
− | ==== Экземпляр Structure ==== | ||
<div class="mw-parser-output"><div class="mw-parser-output"><div class="mw-parser-output"><div class="mw-parser-output"> | <div class="mw-parser-output"><div class="mw-parser-output"><div class="mw-parser-output"><div class="mw-parser-output"> | ||
{| border="1" cellpadding="1" cellspacing="1" style="width: 100%;" | {| border="1" cellpadding="1" cellspacing="1" style="width: 100%;" | ||
Строка 262: | Строка 320: | ||
| style="text-align: center;" | '''Описание''' | | style="text-align: center;" | '''Описание''' | ||
|- | |- | ||
− | | style="text-align: center;" | '''1.2''' | + | | style="text-align: center;" | <span style="color:#e74c3c;">'''Только 1.2'''</span> |
| style="text-align: center;" | get(int x, int y, int z, bool rotate_y) | | style="text-align: center;" | get(int x, int y, int z, bool rotate_y) | ||
| | | | ||
Строка 271: | Строка 329: | ||
| Вернет true, если на координатах данная структура, иначе false | | Вернет true, если на координатах данная структура, иначе false | ||
+ | |- | ||
+ | | colspan="1" rowspan="2" style="text-align: center;" | '''1.3''' | ||
+ | | style="text-align: center;" | get(int x, int y, int z, array rotates, bool return_index) | ||
+ | | colspan="1" rowspan="2" | | ||
+ | *x - Начальная координата структуры по оси X | ||
+ | *y - Начальная координата структуры по оси Y | ||
+ | *z - Начальная координата структуры по оси Z | ||
+ | *rotates - Возможные повороты структуры | ||
+ | *return_index - Возвращать ли индекс найденного поворота(По стандарту false) | ||
+ | |||
+ | | colspan="1" rowspan="2" | Вернет true, если на координатах данная структура, иначе false | ||
+ | |- | ||
+ | | style="text-align: center;" | check(int x, int y, int z, array rotates, bool return_index) | ||
|- | |- | ||
| style="text-align: center;" | '''1.2''' | | style="text-align: center;" | '''1.2''' | ||
Строка 282: | Строка 353: | ||
| Сохранить структуру в файл | | Сохранить структуру в файл | ||
|- | |- | ||
− | | style="text-align: center;" | '''1.2''' | + | | style="text-align: center;" | <span style="color:#e74c3c;">'''Только 1.2'''</span> |
| style="text-align: center;" | set(int x, int y, int z, array rotate, bool destroy, bool progressively, int time) | | style="text-align: center;" | set(int x, int y, int z, array rotate, bool destroy, bool progressively, int time) | ||
| | | | ||
Строка 294: | Строка 365: | ||
| Установить структурув мире по координатам x,y,z, с выбраным рандомно поворотм из массива rotate | | Установить структурув мире по координатам x,y,z, с выбраным рандомно поворотм из массива rotate | ||
+ | |- | ||
+ | | style="text-align: center;" | '''1.3''' | ||
+ | | style="text-align: center;" | set(int x, int y, int z, array rotate, bool progressively, int time) | ||
+ | | | ||
+ | *x - Начальная координата структуры по оси X | ||
+ | *y - Начальная координата структуры по оси Y | ||
+ | *z - Начальная координата структуры по оси Z | ||
+ | *rotate - Массив матриц поворотов | ||
+ | *progressively - Если true, структура будет постепенно "строиться" | ||
+ | *time - Время в миллисекундах между установкой блоков | ||
+ | |||
+ | | Установить структурув мире по координатам x,y,z, с выбраным рандомно поворотм из массива rotate | ||
+ | |- | ||
+ | | style="text-align: center;" | '''1.3''' | ||
+ | | style="text-align: center;" | destroy(int x, int y, int z, array rotates, bool progressively, int time) | ||
+ | | | ||
+ | *x - Начальная координата структуры по оси X | ||
+ | *y - Начальная координата структуры по оси Y | ||
+ | *z - Начальная координата структуры по оси Z | ||
+ | *rotates - Возможные повороты структуры | ||
+ | *progressively - Если true, структура будет постепенно "уничтожаться" | ||
+ | *time - Время в миллисекундах между уничтожением блоков | ||
+ | |||
+ | | Уничтожить структуру в мире по координатам x,y,z, с возможными поворотами rotates | ||
|- | |- | ||
| style="text-align: center;" | '''1.2''' | | style="text-align: center;" | '''1.2''' | ||
Строка 307: | Строка 402: | ||
| Добавить блок в структуру | | Добавить блок в структуру | ||
|} | |} | ||
− | </div> </div> </div> </div> </div> | + | </div> </div> </div> </div> </div> <div class="mw-parser-output"> </div> </div> |
+ | |||
<div class="mw-parser-output"> | <div class="mw-parser-output"> | ||
+ | ==== Rotate ==== | ||
+ | |||
+ | <span style="color:#f39c12;">Добавлен с версии 1.3</span> | ||
+ | |||
+ | Объект Rotate позволяет задовать сложные повороты, которые будут выполнятся при поиске/уничтожении/установке структуры. | ||
+ | <syntaxhighlight lang="JavaScript">var rotate = new Rotate(); | ||
+ | rotate.addRotate(Structure.ROTATE_90Y); | ||
+ | rotate.addRotate(Structure.ROTATE_90X);</syntaxhighlight> | ||
+ | |||
+ | Данный код позволит повернуть структуру сначала на 90 градусов по оси Y, затем по оси X. | ||
+ | |||
+ | ===== экземпляр Rotate ===== | ||
+ | |||
+ | {| border="1" cellpadding="1" cellspacing="1" style="width: 100%;" | ||
+ | |- | ||
+ | ! scope="col" | Версия | ||
+ | ! scope="col" | Метод | ||
+ | ! scope="col" | Аргументы | ||
+ | ! scope="col" | Описание | ||
+ | |- | ||
+ | | style="text-align: center;" | '''1.3''' | ||
+ | | addRotate(array rotate) | ||
+ | | colspan="1" rowspan="2" | | ||
+ | *rotate - Матрица поворота или экземпляр Rotate | ||
+ | |||
+ | | colspan="1" rowspan="2" | Добавить поворот | ||
+ | |- | ||
+ | | style="text-align: center;" | '''1.3''' | ||
+ | | add(array rotate) | ||
+ | |- | ||
+ | | style="text-align: center;" | '''1.3''' | ||
+ | | addRotates(array rotates) | ||
+ | | colspan="1" rowspan="2" | | ||
+ | *rotates - Массив митриц и экземпляров Rotate | ||
+ | |||
+ | | colspan="1" rowspan="2" | Добавить повороты в указанном порядке | ||
+ | |- | ||
+ | | style="text-align: center;" | '''1.3''' | ||
+ | | adds(array rotates) | ||
+ | |} | ||
+ | |||
+ | | ||
+ | </div> | ||
+ | |||
==== StructuresAPI ==== | ==== StructuresAPI ==== | ||
Строка 434: | Строка 574: | ||
|} | |} | ||
− | </div> </div> </div> </div> </div> </div> </div> </div> </div> </div> | + | </div> </div> </div> </div> </div> </div> </div> </div> </div> </div> </div> |
</div> | </div> |
StructuresAPI - библиотека, упрощающая работу со структурами.
Библиотека | ||
---|---|---|
Версия | Ссылка | Изменения |
1 | Скачать |
Первая версия |
1.1 | Подробнее |
|
1.2 | Подробнее |
|
1.3 | Подробнее |
|
1.4 | Подробнее |
|
GitHub | GitHub |
Используя данный продукт вы автоматически соглашаетесь с этими правилами
Для сохранения структур есть два способа:
Для начала выделите вашу структуру топориком(1 точка - тап по блоку, 2 точка - ломание блока), затем выделите с помощью деревянного меча начальную точку структуры(Она может быть вне области структуры).
После введите в чат команду /save <name> [-a] [-x n] [-y n] [-z n] со следующими параметрами
!Не рекомендуется
1. Создать или получить объект структуры
var struct = Structure.get(name)
Где
2. Добавить блоки
3. Сохранить структуру
struct.save()
StructuresAPI.save(name, structures)
Где:
Для проверки структур используется функция get экземпляра объекта Structure
struct.get(x,y,z,)
stuct.get(x, y, z, rotate_y)
Где:
Вернет true если это нужная структура, иначе false.
Пример:
var struct = Structure.get("myStructure");
Callback.addCallback("ItemUse", function(coords, item){
if(item.id == 280 && struct.get(coords.x, coords.y, coords.z)){
alert("It's my structure");
}
});
Для проверки структур используется функция getStructures()
StructuresAPI.getStructures(name, x, y, z, rotate_y)
Где:
Вернет true если это структура name, иначе false
Пример:
Callback.addCallback("ItemUse", function(coords, item){
if(item.id == 280 && StructuresAPI.getStructures("myStructure", coords.x, coords.y, coords.z)){
alert("It's my structure")
}
});
Добавлен с версии 1.2
Версия | Метод | Аргументы | Описание |
---|---|---|---|
1.2 | init(string path) |
|
Устанавливает место хранения структур, относительно мода |
1.2 | get(string name) |
|
Возвращает экземпляр объекта Structure с именем name |
1.3 | setInWorld(string name, int x, int y, int z, array rotate, bool progressively, int time) |
|
Установить структуру name в мире по координатам x,y,z, с выбраным рандомно поворотм из массива rotate |
1.3 | destroyInWorld(string name, int x, int y, int z, array rotates, bool progressively, int time) |
|
Установить структуру name в мире по координатам x,y,z, с возможными поворотами rotates |
Версия | Константа | Описание |
1.2 | ROTATE_NONE | |
1.2 | ROTATE_90Y | Матрица поворота по оси Y на 90о |
1.2 | ROTATE_180Y | Матрица поворота по оси Y на 180о |
1.2 | ROTATE_270Y | Матрица поворота по оси Y на 270о |
1.2 | ROTATE_90X | Матрица поворота по оси X на 90о |
1.2 | ROTATE_180X | Матрица поворота по оси X на 180о |
1.2 | ROTATE_270X | Матрица поворота по оси X на 270о |
1.2 | ROTATE_90Z | Матрица поворота по оси Z на 90о |
1.2 | ROTATE_180Z | Матрица поворота по оси Z на 180о |
1.2 | ROTATE_270Z | Матрица поворота по оси Z на 270о |
1.2 | ROTATE_RANDOM | Рандомный поворот |
1.2 | ROTATE_ALL | Поворот по всем осям |
1.2 | ROTATE_Y | Поворот по оси Y |
1.3 | PROGRESSIVELY | Установка/уничтожение постройки постепенное |
1.3 | NOT_PROGRESSIVELY | Установка/уничтожение постройки не постепенное |
1.3 | MIRROR_X | Отражение по оси X |
1.3 | MIRROR_Y | Отражение по оси Y |
1.3 | MIRROR_Z | Отражение по оси Z |
Версия | Метод | Аргументы | Описание |
Только 1.2 | get(int x, int y, int z, bool rotate_y) |
|
Вернет true, если на координатах данная структура, иначе false |
1.3 | get(int x, int y, int z, array rotates, bool return_index) |
|
Вернет true, если на координатах данная структура, иначе false |
check(int x, int y, int z, array rotates, bool return_index) | |||
1.2 | getName() | Вернет имя структуры | |
1.2 | save() | Сохранить структуру в файл | |
Только 1.2 | set(int x, int y, int z, array rotate, bool destroy, bool progressively, int time) |
|
Установить структурув мире по координатам x,y,z, с выбраным рандомно поворотм из массива rotate |
1.3 | set(int x, int y, int z, array rotate, bool progressively, int time) |
|
Установить структурув мире по координатам x,y,z, с выбраным рандомно поворотм из массива rotate |
1.3 | destroy(int x, int y, int z, array rotates, bool progressively, int time) |
|
Уничтожить структуру в мире по координатам x,y,z, с возможными поворотами rotates |
1.2 | addBlock(x, y, z, block) |
|
Добавить блок в структуру |
Добавлен с версии 1.3
Объект Rotate позволяет задовать сложные повороты, которые будут выполнятся при поиске/уничтожении/установке структуры.
var rotate = new Rotate();
rotate.addRotate(Structure.ROTATE_90Y);
rotate.addRotate(Structure.ROTATE_90X);
Данный код позволит повернуть структуру сначала на 90 градусов по оси Y, затем по оси X.
Версия | Метод | Аргументы | Описание |
---|---|---|---|
1.3 | addRotate(array rotate) |
|
Добавить поворот |
1.3 | add(array rotate) | ||
1.3 | addRotates(array rotates) |
|
Добавить повороты в указанном порядке |
1.3 | adds(array rotates) |
Считается устаревшим с версии 1.2
Удален в версии 1.3
Версия | Метод | Аргументы | Описание |
1.1 | init(string path) |
|
Устанавливает место хранения структур, относительно мода |
1.0 | get(string name) |
|
Возвращает объект структуры, иначе false |
1.0 |
getStructures(string name, int x, int y, int z, bool rotate_y) |
|
Вернет true, если на координатах структура name, иначе false |
1.0 | save(string name, array structures) |
|
Сохраняет струкутуру name |
1.0 | set(string name, int x, int y, int z, array rotate) |
|
Установить структуру name в мире по координатам x,y,z, с выбраным рандомно поворотм из массива rotate |
1.1 | set(string name, int x, int y, int z, array rotate, bool destroy, bool progressively, int time) |
|
Установить структуру name в мире по координатам x,y,z, с выбраным рандомно поворотм из массива rotate |
Константа | Описание |
ROTATE_NONE | |
ROTATE_90Y | Матрица поворота по оси Y на 90о |
ROTATE_180Y | Матрица поворота по оси Y на 180о |
ROTATE_270Y | Матрица поворота по оси Y на 270о |
ROTATE_90X | Матрица поворота по оси X на 90о |
ROTATE_180X | Матрица поворота по оси X на 180о |
ROTATE_270X | Матрица поворота по оси X на 270о |
ROTATE_90Z | Матрица поворота по оси Z на 90о |
ROTATE_180Z | Матрица поворота по оси Z на 180о |
ROTATE_270Z | Матрица поворота по оси Z на 270о |
ROTATE_RANDOM | Рандомный поворот |
ROTATE_ALL | Поворот по всем осям |
ROTATE_Y | Поворот по оси Y |