Моддинг в 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
Информация
Посетители, находящиеся в группе Гости, не могут оставлять комментарии к данной публикации.

Онлайн

Сейчас на сайте: 82
Гостей: 79

Пользователи: 

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

MOD NOLDORION WORLDS
Dimar Leh, Сегодня, 11:17
Кстати советую один онлайн переводчик, неплохая помощь по...
MOD 1429 : la Guerre de Cent Ans - Steel Edition
Влад Сагайдачний, Вчера, 22:55
Здравствуйте,  возникла проблема, пролистал всё обсуждение и так и не нашёл идентичную проблему....
Флудилка V3
epilect, 18 июля 2024 20:53
iskanderzp, Я успел немного поиграть,не прорыв конечно,но за счет графики и некоторых плюшек...
Флудилка V3
iskanderzp, 18 июля 2024 20:31
epilect, Да. С фронтовых прикупил новое железо. Как-то до Баннера пока руки не дошли. Наверное,...
Флудилка V3
epilect, 18 июля 2024 18:07
iskanderzp, А чего ты Баннер не попробуешь,насколько я помню железо ты обновил?...
MOD A Clash of Kings
iskanderzp, 18 июля 2024 17:34
epilect, Держись, дружище!Цитата: epilect,4 ВЛК за два года...
MOD A Clash of Kings
epilect, 18 июля 2024 17:30
iskanderzp, Я тоже рад тебя видеть,а ты все пылишь и в основном по полям Китая).Так я и говорил,что...
MOD A Clash of Kings
iskanderzp, 18 июля 2024 15:50
epilect, Привет, друже! рад видеть на сайте!) Как дела?) Касательно развития персонажа, то тут...
MOD A Clash of Kings
epilect, 17 июля 2024 18:26
Довольно спорное утверждение.Смотря какого персонажа отыгрывать,если бойца много делающего в...