Моддинг в Bannerlord: Система сохранений


Моддинг в Bannerlord: Система сохранений 

Оригинал статьи - ​https://docs.bannerlordmodding.com/_csharp-api/savesystem/​​​

ВНИМАНИЕ!
Для патча e1.0.10/e1.1.0 при установке кастомных данных, содержащих основные модели игры, будьте предельно внимательны.
Если данные будут сохранены непосредственно в папку с самим модом, то при удалении мода сохранение не загрузится из-за отсутствия ваших кастомных данных.
Это будет иметь место при определении кастомных LogEntry моделей и введении их в игру
(LogEntry.AddLogEntry(customLog);.
В качестве обходного пути вы должны либо включить функцию для полного вынесения кастомных данных из игры, или предоставить для этого мод.

SaveableTypeDefiner
Для определения пользовательских классов и структур выполните ваш собственный TaleWorlds.SaveSystem.SaveableTypeDefiner
Вам не нужно нигде его регистрировать, игра сама его найдёт.

    public class CustomSaveDefiner : SaveableTypeDefiner
    {
        // use a big number and ensure that no other mod is using a close range
        public CustomSaveDefiner() : base(2 _333_000) { }
        protected override void DefineClassTypes()
        {
            // The Id's here are local and will be related to the Id passed to the constructor
            AddClassDefinition(typeof(CustomMapNotification), 1);
            AddStructDefinition(typeof(ExampleStruct), 2);
            AddClassDefinition(typeof(ExampleNested), 3);
            AddStructDefinition(typeof(NestedStruct), 4);
        }
        protected override void DefineContainerDefinitions()
        {
            ConstructContainerDefinition(typeof(List<ExampleStruct>));
        }
    }

SaveableField и SaveableProperty
Чтобы выделить данные в ваших пользовательских класс/структура как сохраняемые используйте TaleWorlds.SaveSystem.SaveableFieldAttribute и TaleWorlds.SaveSystem.SaveablePropertyAttribute.
Похоже, что нет разницы между SaveableField и SaveableProperty, но если вы использовали один из них, придерживайтесь его. Они не взаимозаменяемые и данные не загрузятся, если их поменяли.
    public struct ExampleStruct
    {
        // Local ID's start from one if the class/struct does not inherit from any
        // game's types with saveable data
        [SaveableField(1)]
        public PartyBase Attacker;
    }
    public class CustomMapNotification : InformationData
    {
        // InformationData already contains 5 definitions, so start from 6 for custom data
        [SaveableProperty(6)]
        public Hero Mercenary { get; set; }
        [SaveableProperty(7)]
        public bool IsHandled { get; set; }
    }
    
    public struct NestedStruct
    {
        [SaveableField(1)]
        public bool Flag;
    }
    public class ExampleNested
    {
        [SaveableField(1)]
        public NestedStruct Data;
    }


CampaignBehaviorBase.SyncData
Есть также «общая база данных», которую можно использовать между одним/несколькими CampaignBehaviorBase. С ней вы сможете хранить такие кастомные данные, как:
  • Array (массив)
  • List (список)
  • Dictionary (словарь)
  • Queue (Очередь (FIFO ("первый вошел - первый вышел")))

    public class CustomBehavior : CampaignBehaviorBase
    {
        private List<ExampleStruct> _customDataMap = new List<ExampleStruct>();
        public override void SyncData(IDataStore dataStore)
        {
            dataStore.SyncData("customDataMap", ref _customDataMap);
        }
    }

Заметки:
Сообщество теперь должно решить как справиться с противоречиями saveBaseId.



- используйте эту кнопку если вы обнаружили ошибку/искажение содержимого/отсутствие контента в новости или если хотите сообщить администрации о выходе новой версии мода и т.п.

Комментариев 1

Гридень
london22
Офлайн 14 августа 2020 21:07 поделиться
Надеюсь, будет полезно 


(A+B)2 = A2 + B2
Информация
Посетители, находящиеся в группе Гости, не могут оставлять комментарии к данной публикации.

Онлайн

Сейчас на сайте: 206
Гостей: 204

Пользователи: 
- отсутствуют

Последние комментарии

MOD Honour&Glory (Честь и Слава)
commando.com.ua, Сегодня, 15:01
Вот и вышло обновление ЧиСа, спустя столько лет. Поздравляю фанатов и разработчиков с релизом!...
MOD East 1135
Artkolobok, 25 февраля 2025 13:06
iskanderzp, У меня доступа нет к аккаунтам сайта (ГД), но я скачаю мод и попрошу другого админа...
MOD East 1135
epilect, 23 февраля 2025 19:20
iskanderzp, Я в тебе не сомневался)))...
MOD East 1135
iskanderzp, 23 февраля 2025 11:26
epilect, Есть такое. Залил на Фекс.нет.  Уважаемые админы, если есть желание и возможность,...
MOD East 1135
epilect, 22 февраля 2025 14:02
Это Анди была ссылка,эта версия может быть разве что у Искандера......
MOD East 1135
Artkolobok, 22 февраля 2025 12:37
Mikail Havrilyuk, Мы её никак заменить не можем...
MOD East 1135
Mikail Havrilyuk, 21 февраля 2025 18:46
Уважаемые Администраторы, ссылка на версию 1.2.5 не работает. Я прохожу авторизацию без конца....
Гайд по моду Age of Arthur
Asgard_guardian, 19 февраля 2025 17:41
Спящий, Если ещё актуально - методом проб и ошибок выяснил, что ловкость должна быть действительно...
Флудилка V3
Gut, 19 февраля 2025 16:52
SupportCaptain, Без знания модульки будет тяжело(я сам не мододел, в точности не подскажу), тяжело...