О жизни » Доработка Minecraft beta 1.7.3 6 февраля 2020 от lionovsky |
Давно уже сюда не писал. Итак, есть сырцы Minecraft beta 1.7.3, которые я тут дорабатываю ради поддержки ретро-сервера. Недавно столкнулся с проблемой - техническое ограничение Minecraft в 256 существующих блоков. Чекнул документацию - Region file format (mcregion) поддерживает ID до 4069 блоков. В исходном коде игры ID для предметов и блоков задаётся жёстко, выделены 2 зоны: Item.itemsList[pistonStickyBase.blockID] = new ItemPiston(pistonStickyBase.blockID - 256); protected Item(int i) Т.е., создаётся 2 списка, блоки - 0-255, предметы - 256+. Меняем значение на 2048 для создания новой "зоны" предметов - получаем аццкие тормоза на стороне клиента, хотя клиент работает - блок с ID 1000 создаётся. Оказывается, клиент майна загружает все ID в память, т.е. если раннее он загружал 0-255, то сейчас - 0-2074. Уменьшил размер до 1024 - падение производительности на 20% вместо 50%. Сервер при этом не падает - разработчики Bukkit уже предусмотрели такой сценарий, и сервер грузит в память только те блоки, ID которых не пуст. Сойдёт. Ок, загружаем старый мир, открываем любой сундук, наш клиент крашится, так как карта ему отдала вместо ID 1280 - 256. Конечно же, клиент не знает о таком ID и успешно падает. Думал уж костыли пилить, но нет - нашлась утилита NBTEditor. Заменяем в сундуках и инвентаре игроков все ID 256+ на 1280+, и наш клиент работает стабильно. Не знаю, почему моджанги столь долго ограничивались 256 блоками, это было пофикшено совсем недавно введением буквенных ID. Возможно, дело в памяти - однако можно подсмотреть систему загрузки пустых ID у Bukkit'a и реализовать в клиенте. |