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

Онлайн

Сейчас на сайте: 219
Гостей: 217

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

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

Парламент commando
Samiraldos, Сегодня, 08:55
Цитата: ArtkolobokSamiraldos, Хорошо, но чтобы получить быстрый ответ, заходи на наш дискорд...
Парламент commando
Artkolobok, Вчера, 13:56
Samiraldos, Хорошо, но чтобы получить быстрый ответ, заходи на наш дискорд сервер:...
Парламент commando
Samiraldos, Вчера, 07:44
Цитата: ArtkolobokSamiraldos, Идея с партиями давно утратила свою актуальность, да и никто особо не...
MOD Voice Acting - AI Voice Acting for Every Character
Gut, 19 ноября 2024 18:13
с возвращением, грац!!...
Парламент commando
Gut, 19 ноября 2024 18:03
Samiraldos, Если есть желание, то всегда можно найти компромисс. Сами по себе партии утратили...
Парламент commando
Artkolobok, 19 ноября 2024 09:57
Samiraldos, Идея с партиями давно утратила свою актуальность, да и никто особо не хочет этим...
Парламент commando
Samiraldos, 19 ноября 2024 03:23
Я бы добавил должность партии в виде фрилансеров. Ну допустим я играю сейчас в МиБ потом буду...
Кольца
Samiraldos, 19 ноября 2024 03:06
https://commando.com.ua/uploads/posts/2018-05/1525510484_zol-bol-rad.png...