(→Создание блоков) |
|||
(не показано 28 промежуточных версий 11 участников) | |||
Строка 1: | Строка 1: | ||
− | |||
<div class="mw-parser-output"> | <div class="mw-parser-output"> | ||
=== Регистрация ID === | === Регистрация ID === | ||
− | ID - уникальный | + | ID - уникальный идентификатор блока\предмета, задается строкой и натуральным числом, которое сопоставляется этой строке. Чтобы зарегистрировать ID, используется модуль IDRegistry. |
Для регистрации ID блока используется метод IDRegistry.genBlockID("строковый ID") - после вызова этой функции сгенерируется новый уникальный ID для блока, доступ к числовому значению которого может быть произведен как BlockID.<строковый ID> | Для регистрации ID блока используется метод IDRegistry.genBlockID("строковый ID") - после вызова этой функции сгенерируется новый уникальный ID для блока, доступ к числовому значению которого может быть произведен как BlockID.<строковый ID> | ||
Строка 12: | Строка 11: | ||
<syntaxhighlight lang="Javascript">IDRegistry.genBlockID("testBlock"); // доступ BlockID.testBlock | <syntaxhighlight lang="Javascript">IDRegistry.genBlockID("testBlock"); // доступ BlockID.testBlock | ||
IDRegistry.genItemID("testItem"); // доступ ItemID.testItem</syntaxhighlight> | IDRegistry.genItemID("testItem"); // доступ ItemID.testItem</syntaxhighlight> | ||
− | < | + | <div class="mw-parser-output"> |
− | |||
=== Текстуры === | === Текстуры === | ||
В ресурсах мода текстуры блоков и предметов задаются в определенном формате: каждая текстура должна быть в формате .png и имеет имя и номер, название любой текстуры выглядит так: имя_номер.png и никак иначе. Номера текстур с одним именем должны идти последовательно и начинаться с 0. | В ресурсах мода текстуры блоков и предметов задаются в определенном формате: каждая текстура должна быть в формате .png и имеет имя и номер, название любой текстуры выглядит так: имя_номер.png и никак иначе. Номера текстур с одним именем должны идти последовательно и начинаться с 0. | ||
− | Текстуры блоков в ресурспаке располагаются по адресу | + | Текстуры блоков в ресурспаке располагаются по адресу res/terrain-atlas/ |
− | Текстуры предметов в ресурспаке располагаются по адресу | + | Текстуры предметов в ресурспаке располагаются по адресу res/items-opaque/ |
− | <div | + | Текстуры брони в ресурспаке располагаются по адресу res/armor |
+ | </div> | ||
=== Создание блоков === | === Создание блоков === | ||
Строка 49: | Строка 48: | ||
Block.createBlock("testBlock", [ | Block.createBlock("testBlock", [ | ||
{name: "test block", texture: [["planks", 0], ["planks", 0], ["planks", 0], ["planks", 0], ["planks", 0], ["planks", 0]], inCreative: true} | {name: "test block", texture: [["planks", 0], ["planks", 0], ["planks", 0], ["planks", 0], ["planks", 0], ["planks", 0]], inCreative: true} | ||
− | ]) // создание простого блока на ID "testBlock" с текстурой досок на всех сторонах, будет добавлен в креатив</syntaxhighlight> | + | ]); // создание простого блока на ID "testBlock" с текстурой досок на всех сторонах, будет добавлен в креатив</syntaxhighlight> |
− | + | <div class="mw-parser-output"><div class="mw-parser-output"> | |
==== Создание блоков с поворотом ==== | ==== Создание блоков с поворотом ==== | ||
Метод Block.createBlockWithRotation - принимает те же аргументы, что и Block.createBlock, но для каждой вариации блока создает 4 вариации, которые реализуют поворот, блок, созданный этим методом, автоматически будет ставиться с нужным поворотом. | Метод Block.createBlockWithRotation - принимает те же аргументы, что и Block.createBlock, но для каждой вариации блока создает 4 вариации, которые реализуют поворот, блок, созданный этим методом, автоматически будет ставиться с нужным поворотом. | ||
− | </div> | + | </div> </div> |
− | |||
=== Создание предметов === | === Создание предметов === | ||
Строка 62: | Строка 60: | ||
Item.createItem("строковый ID", "имя предмета", текстура, параметры) - создает обычный предмет на ранее зарегистрированном строковом ID, с данным именем, текстурой и параметрами. | Item.createItem("строковый ID", "имя предмета", текстура, параметры) - создает обычный предмет на ранее зарегистрированном строковом ID, с данным именем, текстурой и параметрами. | ||
− | Параметры имеют формат, если вы не хотите изменять значения по | + | Параметры имеют формат, если вы не хотите изменять значения по умолчанию, просто не пишите их: |
<syntaxhighlight lang="Javascript">{ | <syntaxhighlight lang="Javascript">{ | ||
isTech: false, // если true, не добавляет предмет в креатив | isTech: false, // если true, не добавляет предмет в креатив | ||
stack: 64 // размер стака | stack: 64 // размер стака | ||
} </syntaxhighlight> | } </syntaxhighlight> | ||
+ | |||
+ | '''Пример''': | ||
+ | <syntaxhighlight lang="JavaScript">IDRegistry.genItemID("testItem"); | ||
+ | Item.createItem("testItem", "test item", {name: "stick", meta: 0}, {}); // создаем обычный предмет на ID testItem с текстурой палки и стандартными параметрами</syntaxhighlight> | ||
==== Создание еды ==== | ==== Создание еды ==== | ||
Строка 72: | Строка 74: | ||
Item.createFoodItem("строковый ID", "имя предмета", текстура, параметры) - создает съедобный предмет на ранее зарегистрированном строковом ID, с данным именем, текстурой и параметрами. | Item.createFoodItem("строковый ID", "имя предмета", текстура, параметры) - создает съедобный предмет на ранее зарегистрированном строковом ID, с данным именем, текстурой и параметрами. | ||
− | Параметры имеют формат, если вы не хотите изменять значения по | + | Параметры имеют формат, если вы не хотите изменять значения по умолчанию, просто не пишите их: |
<syntaxhighlight lang="Javascript">{ | <syntaxhighlight lang="Javascript">{ | ||
isTech: false,// если true, не добавляет предмет в креатив | isTech: false,// если true, не добавляет предмет в креатив | ||
Строка 83: | Строка 85: | ||
Item.createThrowableItem("строковый ID", "имя предмета", текстура, параметры) - создает кидаемый предмет на ранее зарегистрированном строковом ID, с данным именем, текстурой и параметрами. | Item.createThrowableItem("строковый ID", "имя предмета", текстура, параметры) - создает кидаемый предмет на ранее зарегистрированном строковом ID, с данным именем, текстурой и параметрами. | ||
− | Параметры имеют формат, если вы не хотите изменять значения по | + | Параметры имеют формат, если вы не хотите изменять значения по умолчанию, просто не пишите их: |
<syntaxhighlight lang="Javascript">{ | <syntaxhighlight lang="Javascript">{ | ||
isTech: false, // если true, не добавляет предмет в креатив | isTech: false, // если true, не добавляет предмет в креатив | ||
stack: 64 // сколько предметов будет в одном стаке, максимум 64. | stack: 64 // сколько предметов будет в одном стаке, максимум 64. | ||
}</syntaxhighlight> | }</syntaxhighlight> | ||
− | + | <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"> | |
− | ==== | + | '''Пример''': |
− | <syntaxhighlight lang=" | + | <syntaxhighlight lang="JavaScript">IDRegistry.genItemID("throwableItem"); |
− | + | Item.createThrowableItem("throwableItem", "Throwable Item", { name: "throwable_item", meta: 0}, {}) | |
+ | </syntaxhighlight> | ||
+ | </div> </div> </div> </div> </div> </div> | ||
==== Создание брони ==== | ==== Создание брони ==== | ||
<pre>Item.createArmorItem("строковый ID", "имя предмета", текстура, параметры) - создает предмет брони на ранее зарегистрированном строковом ID, с данным именем, текстурой и параметрами.</pre> | <pre>Item.createArmorItem("строковый ID", "имя предмета", текстура, параметры) - создает предмет брони на ранее зарегистрированном строковом ID, с данным именем, текстурой и параметрами.</pre> | ||
− | Параметры имеют формат, если вы не хотите изменять значения по | + | Параметры имеют формат, если вы не хотите изменять значения по умолчанию, просто не пишите их: |
<syntaxhighlight lang="Javascript">{ | <syntaxhighlight lang="Javascript">{ | ||
isTech: false, // если true, не добавляет предмет в креатив | isTech: false, // если true, не добавляет предмет в креатив | ||
Строка 103: | Строка 107: | ||
durability: 1 // прочность брони | durability: 1 // прочность брони | ||
}</syntaxhighlight> | }</syntaxhighlight> | ||
+ | <div class="mw-parser-output"><div class="mw-parser-output"> | ||
+ | '''Пример брони''': | ||
+ | <syntaxhighlight lang="Javascript">IDRegistry.genItemID("myHelmet"); // регистрируем ID шлема | ||
+ | IDRegistry.genItemID("myChestplate"); // регистрируем ID нагрудника | ||
+ | IDRegistry.genItemID("myLeggings"); // регистрируем ID понож | ||
+ | IDRegistry.genItemID("myBoots"); // регистрируем ID ботинок | ||
− | + | Item.createArmorItem("myHelmet", "Helmet", {name: "helmet"}, {type: "helmet", armor: 2, durability: 149, texture: "armor/lay_1.png"}); // создаём шлем с ID myHelmet | |
− | + | Item.createArmorItem("myChestplate", "Chestplate", {name: "chestplate"}, {type: "chestplate", armor: 6, durability: 216, texture: "armor/lay_1.png"}); // создаём нагрудник с ID myChestplate | |
− | + | Item.createArmorItem("myLeggings", "Leggings", {name: "leggings"}, {type: "leggings", armor: 5, durability: 203, texture: "armor/lay_2.png"}); // создаём поножи с ID myLeggings | |
− | + | Item.createArmorItem("myBoots", "Boots", {name: "boots"}, {type: "boots", armor: 2, durability: 176, texture: "armor/lay_1.png"}); // создаём ботинки с ID myBoots | |
− | |||
− | |||
− | Item.createArmorItem(" | ||
− | Item.createArmorItem(" | ||
− | Item.createArmorItem(" | ||
− | Item.createArmorItem(" | ||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
</syntaxhighlight> | </syntaxhighlight> | ||
− | </div> | + | </div> </div> </div> |
ID - уникальный идентификатор блока\предмета, задается строкой и натуральным числом, которое сопоставляется этой строке. Чтобы зарегистрировать ID, используется модуль IDRegistry.
Для регистрации ID блока используется метод IDRegistry.genBlockID("строковый ID") - после вызова этой функции сгенерируется новый уникальный ID для блока, доступ к числовому значению которого может быть произведен как BlockID.<строковый ID>
Для регистрации ID предмета используется метод IDRegistry.genItemID("строковый ID") - после вызова этой функции сгенерируется новый уникальный ID для предмета, доступ к числовому значению которого может быть произведен как ItemID.<строковый ID>
Примеры:
IDRegistry.genBlockID("testBlock"); // доступ BlockID.testBlock
IDRegistry.genItemID("testItem"); // доступ ItemID.testItem
В ресурсах мода текстуры блоков и предметов задаются в определенном формате: каждая текстура должна быть в формате .png и имеет имя и номер, название любой текстуры выглядит так: имя_номер.png и никак иначе. Номера текстур с одним именем должны идти последовательно и начинаться с 0.
Текстуры блоков в ресурспаке располагаются по адресу res/terrain-atlas/
Текстуры предметов в ресурспаке располагаются по адресу res/items-opaque/
Текстуры брони в ресурспаке располагаются по адресу res/armor
После регистрации ID для блока, создается сам блок на этом ID. На одном ID может быть создано несколько вариаций блока, каждая из которых обладает своим именем и текстурой, разные вариации одного блока в мире будут иметь один ID, но разные значения metadata, подробнее об этом будет позднее. Для создания блоков используется модуль Block.
Метод Block.createBlock("строковый ID", [вариация1, вариация2, ...]) - создает блок и все его вариации на ранее зарегистрированном ID, если вариация 1, то просто создает данный блок.
Каждая вариация в массиве имеет формат
{
name: "имя вариации",
texture: [
["название1", индекс1], // bottom
["название2", индекс2], // top
["название3", индекс3], // back
["название4", индекс4], // front
["название5", индекс5], // left
["название6", индекс6] // right
],
inCreative: true/false //(добавлять ли данную вариацию блока в креатив)
}
Если текстур указано меньше, чем 6, то последняя из них будет дублирована несколько раз, чтобы дополнить их кол-во до 6.
Пример:
IDRegistry.genBlockID("testBlock"); // регистрация
Block.createBlock("testBlock", [
{name: "test block", texture: [["planks", 0], ["planks", 0], ["planks", 0], ["planks", 0], ["planks", 0], ["planks", 0]], inCreative: true}
]); // создание простого блока на ID "testBlock" с текстурой досок на всех сторонах, будет добавлен в креатив
Метод Block.createBlockWithRotation - принимает те же аргументы, что и Block.createBlock, но для каждой вариации блока создает 4 вариации, которые реализуют поворот, блок, созданный этим методом, автоматически будет ставиться с нужным поворотом.
После регистрации ID предмета, создается сам предмет на этом ID. Предметы могут быть разных типов: обычный, броня, еда и кидаемый, для каждого из них существует свой метод. Для создания предметов используется модуль Item. Каждый предмет имеет текстуру, которая задается в формате {name: "имя текстуры", meta: <номер текстуры>}, если номер текстуры 0, его можно не указывать.
Item.createItem("строковый ID", "имя предмета", текстура, параметры) - создает обычный предмет на ранее зарегистрированном строковом ID, с данным именем, текстурой и параметрами.
Параметры имеют формат, если вы не хотите изменять значения по умолчанию, просто не пишите их:
{
isTech: false, // если true, не добавляет предмет в креатив
stack: 64 // размер стака
}
Пример:
IDRegistry.genItemID("testItem");
Item.createItem("testItem", "test item", {name: "stick", meta: 0}, {}); // создаем обычный предмет на ID testItem с текстурой палки и стандартными параметрами
Item.createFoodItem("строковый ID", "имя предмета", текстура, параметры) - создает съедобный предмет на ранее зарегистрированном строковом ID, с данным именем, текстурой и параметрами.
Параметры имеют формат, если вы не хотите изменять значения по умолчанию, просто не пишите их:
{
isTech: false,// если true, не добавляет предмет в креатив
stack: 64, // размер стака
food: 1 // восполнение здоровья едой
}
Item.createThrowableItem("строковый ID", "имя предмета", текстура, параметры) - создает кидаемый предмет на ранее зарегистрированном строковом ID, с данным именем, текстурой и параметрами.
Параметры имеют формат, если вы не хотите изменять значения по умолчанию, просто не пишите их:
{
isTech: false, // если true, не добавляет предмет в креатив
stack: 64 // сколько предметов будет в одном стаке, максимум 64.
}
Пример:
IDRegistry.genItemID("throwableItem");
Item.createThrowableItem("throwableItem", "Throwable Item", { name: "throwable_item", meta: 0}, {})
Item.createArmorItem("строковый ID", "имя предмета", текстура, параметры) - создает предмет брони на ранее зарегистрированном строковом ID, с данным именем, текстурой и параметрами.
Параметры имеют формат, если вы не хотите изменять значения по умолчанию, просто не пишите их:
{
isTech: false, // если true, не добавляет предмет в креатив
armor: 1, // количество добавляемой брони в шкале защиты
type: <обязательное значение>, // тип предмета "helmet"/"chestplate"/"leggings"/"boots"
texture: <обязательное значение>, // текстура модели данной брони
durability: 1 // прочность брони
}
Пример брони:
IDRegistry.genItemID("myHelmet"); // регистрируем ID шлема
IDRegistry.genItemID("myChestplate"); // регистрируем ID нагрудника
IDRegistry.genItemID("myLeggings"); // регистрируем ID понож
IDRegistry.genItemID("myBoots"); // регистрируем ID ботинок
Item.createArmorItem("myHelmet", "Helmet", {name: "helmet"}, {type: "helmet", armor: 2, durability: 149, texture: "armor/lay_1.png"}); // создаём шлем с ID myHelmet
Item.createArmorItem("myChestplate", "Chestplate", {name: "chestplate"}, {type: "chestplate", armor: 6, durability: 216, texture: "armor/lay_1.png"}); // создаём нагрудник с ID myChestplate
Item.createArmorItem("myLeggings", "Leggings", {name: "leggings"}, {type: "leggings", armor: 5, durability: 203, texture: "armor/lay_2.png"}); // создаём поножи с ID myLeggings
Item.createArmorItem("myBoots", "Boots", {name: "boots"}, {type: "boots", armor: 2, durability: 176, texture: "armor/lay_1.png"}); // создаём ботинки с ID myBoots