в канал два стейта подряд, с вашнотами и без; заводить тонну флагов во вью для каждого ваншота; мутировать объект стейта (хотя это нарушает основной принцип MVI). Сейчас сделал с одним флагом, что если вью была пересоздана, ваншоты пропускаются, но тут проблема как и в первом случае: если вью была разрушена (детачена) в момент, когда пришел новый стейт, то ваншоты не выполнятся вообще. Последний вариант, с мутированием стейта, как ни прискорбно, выглядит самым адекватным. А есть ещё какие-нибудь варианты? Может что-то упускаю?..
Можно делать стейты самодостаточными (без разностных изменений), и всегда вешать полноценные стейты на каждое изменение. В таком случае не придется парить мозг насчет частичных изменений. Да, это не очень оптимально (один и тот же текст или флаг может несколько раз вбиваться в одну и ту же вью), но если на практике будут заметные провисания в производительности и отрисовке, то можно будет тогда заморочиться или найти какую-нить diff-либу для view. Я тот же вопрос на 5-м мосдроиде задавал, там был доклад по архитектуре, докладчик (Кирилл Бяков) посоветовал какую-то либу на это, но я забыл название - пока и без нее хорошо работает, благо UI у меня не чаще раза в 5 сек апдейтиться, да и пока нету иерархически-тяжелых экранов )
Читал http://hannesdorfmann.com/android/mosby3-mvi-7 ? P.S. я бы сказал что такие "one-time-events" просто не нужны и надо их избегать, ибо от них много проблемм, даже тупо с ЖЦ android
Обсуждают сегодня