Это популярное сообщение. dsh 3 824 Опубликовано 5 Июля 2023 Это популярное сообщение. Поделиться Опубликовано 5 Июля 2023 Перемещения предметов между инвентарями происходят на апдейте, то есть один раз за кадр. Об этом нужно помнить и учитывать. У движка очень неудобная архитектура, построенная на очереди нетпакетов. Когда мы переместили предмет из одного инвентаря в другой, в очередь добавляется нетпакет с информацией об этом перемещении. И только в начале следующего кадра этот нетпакет будет обработан и перемещение отразится на клиентских объектах. 2 3 dsh mod: https://github.com/dsh2dsh/op2ogse Ссылка на комментарий
Norman Eisenherz 309 Опубликовано 10 Июля 2023 Поделиться Опубликовано 10 Июля 2023 [ЧН/ЗП] Перебор пояса через старый костыль со спавном предмета-маркера: пересчет при открытом инвентаре, вылет в момент удаления нового маркера, если в инвентаре не остался аналогичный маркер от прошлой проверки. Если отспавнить один лишний маркер до начала пересчета, вылета не происходит. Если сравнивать со старым кодом АМК, где выполнялся циклический переспавн маркера и сразу же перебор инвентаря (без ожидания регистрации), там как раз оставался один лишний маркер ввиду того, что первый перебор не находил ничего, второй перебор находил первый маркер и т. д. Почему без "запасного" маркера случается вылет? Spoiler Expression : assertion failed Function : CUICellContainer::GetItemPos File : E:\priquel\sources\engine\xrGame\ui\UIDragDropListEx.cpp Line : 702 -- в ЗП строка 769, обработчик тот же Description : 0 [xrGame\ui\UIDragDropListEx.cpp] Ivector2 CUICellContainer::GetItemPos(CUICellItem* itm) { for(int x=0; x<m_cellsCapacity.x ;++x) for(int y=0; y<m_cellsCapacity.y ;++y){ Ivector2 p; p.set(x,y); if(GetCellAt(p).m_item==itm) return p; } R_ASSERT(0); return Ivector2().set(-1,-1); Конфиг маркера: [marker]:harmonica_a inv_weight = 0 inv_grid_width = 0 inv_grid_height = 0 Скрипт пересчета пояса: https://drive.google.com/file/d/1sbr2Sc8zBVP-0qrSh-M4WTb6TnEs24DD Тест: загрузить сейв (можно начать новую игру), открыть инвентарь, запустить пересчет пояса on_belt.update() любым подходящим способом. В ТЧ спавн и удаление маркера выполняются без нарушений на любых сейвах и в новой игре. Мини-моды: ТЧ ЧН ЗП Шпаргалка Ссылка на комментарий
RayTwitty 492 Опубликовано 10 Июля 2023 Поделиться Опубликовано 10 Июля 2023 (изменено) 17 минут назад, Norman Eisenherz сказал: Почему без "запасного" маркера случается вылет? Так у тебя проблема не с "костылем-перебором", а с отображением ячеек инвентаря, раз вылет туда ссылается. Насколько я понял, отработал R_ASSERT, потому что функция не нашла предмет по указанной позиции. Нужно смотреть метод GetCellAt, возможно там предметы 0х0 не обрабатываются. Обратить также внимание на сравнение вещественных чисел с нулем, менялось это или нет. Или, может быть при удалении предмета из онлайна его уже нет в CUICellContainer, это вполне могло поменяться в ЧН, тогда как в ТЧ прокатывало. Изменено 10 Июля 2023 пользователем RayTwitty Ссылка на комментарий
Norman Eisenherz 309 Опубликовано 11 Июля 2023 Поделиться Опубликовано 11 Июля 2023 Методы GetItemPos и GetCellAt в ТЧ и ЧН имеют одинаковое описание. Что еще можно проверить? Если включить иконку, вылета нет. Неясно, почему два и более предметов без иконок обрабатываются правильно, а единичный предмет дает вылет при удалении. Мини-моды: ТЧ ЧН ЗП Шпаргалка Ссылка на комментарий
RayTwitty 492 Опубликовано 12 Июля 2023 Поделиться Опубликовано 12 Июля 2023 (изменено) 11.07.2023 в 19:39, Norman Eisenherz сказал: Если включить иконку, вылета нет. Неясно, почему два и более предметов без иконок обрабатываются правильно, а единичный предмет дает вылет при удалении. Возможно, когда предметов больше одного, по одним и тем же координатам их оказывается несколько, и при удалении первого гарантированно есть еще второй. В общем случае, по идее в одной ячейке может быть только один предмет. А когда у нас предмет 0х0, то их может быть бесконечно много, что уже выглядит как косяк с точки зрения системы. Почему тогда в ТЧ это работает?.. Нужно смотреть все цепочки вызовов, что откуда вызывается, в том числе GetItemPos. Изменено 12 Июля 2023 пользователем RayTwitty Ссылка на комментарий
Norman Eisenherz 309 Опубликовано 21 Июля 2023 Поделиться Опубликовано 21 Июля 2023 Задача: заполнить таблицу парами значений с суммированием (+/-) или просто нулями. Вместо суммирования таблица очищается на каждом шаге при проверке наличия заданного ключа. Вложенная таблица {0, 0} не успевает записаться в память до следующей проверки? Spoiler local count = {} for stat, v in pairs(st) do -- так заполняется правильно count[stat] = {0, 0} end if #arts > 0 then for i = 1, #arts do local sect = arts[i] if sect:find("^af_") then for stat, v in pairs(st) do local p = … local k = p < 0 and 2 or 1 -- позиция записи -- if not count[stat] then -- так очищается на каждом шаге -- count[stat] = {0, 0} -- else count[stat][k] = count[stat][k] + p -- end end end end end Мини-тест с такой же проверкой и правильным суммированием: Spoiler local count = {} for j = 1, 3 do for i = 1, 4 do if not count.name then count.name = {0, 0} else count.name[1] = count.name[1] + 2 end end end 2 Мини-моды: ТЧ ЧН ЗП Шпаргалка Ссылка на комментарий
abramcumner 1 146 Опубликовано 22 Июля 2023 Поделиться Опубликовано 22 Июля 2023 (изменено) 11 часов назад, Norman Eisenherz сказал: Вместо суммирования таблица очищается на каждом шаге при проверке наличия заданного ключа. А шагов не два случайно? 11 часов назад, Norman Eisenherz сказал: Вложенная таблица {0, 0} не успевает записаться в память до следующей проверки? Ошибка всегда в программе. В первый раз вместо того, чтобы прибавить p, ты пишешь нолики. Убери else. Ну и вариант с отдельной инициализаций count и отдельным заполнением в сто раз лучше. И ошибок в нем меньше. Изменено 22 Июля 2023 пользователем abramcumner 1 1 1 Ссылка на комментарий
Norman Eisenherz 309 Опубликовано 22 Июля 2023 Поделиться Опубликовано 22 Июля 2023 (изменено) 6 hours ago, abramcumner said: шагов не два случайно Варианты "так работает / так нет" включаются в код по отдельности – в одном блоке кода они указаны только для объяснения проблемы. Или мы говорим о разных вещах? С записью {0, 0} вместо значения на первом шаге поправка принимается, но основная проблема в том, что на следующем шаге, когда значение есть, проверка if not снова дает nil и значение перезаписывается парой нулей. Изменено 22 Июля 2023 пользователем Norman Eisenherz Мини-моды: ТЧ ЧН ЗП Шпаргалка Ссылка на комментарий
abramcumner 1 146 Опубликовано 22 Июля 2023 Поделиться Опубликовано 22 Июля 2023 (изменено) 2 часа назад, Norman Eisenherz сказал: проверка if not снова дает nil и значение перезаписывается парой нулей. Нет, не дает и не перезаписывается. Вот результат выполнения твоего кода local st={a=1} local arts ={"af_a", "af_b", "af_c"} i=1 stat=a count[stat]=nil i=2 stat=a count[stat][k]=0 i=3 stat=a count[stat][k]=1 count={a = {1 = 2,2 = 0}} Изменено 22 Июля 2023 пользователем abramcumner Ссылка на комментарий
Norman Eisenherz 309 Опубликовано 22 Июля 2023 Поделиться Опубликовано 22 Июля 2023 У меня при тестовом выводе таблицы на каждом шаге получается {0, 0}, потом какое-то значение, потом опять {0, 0} и другое значение, но не сумма. Мини-моды: ТЧ ЧН ЗП Шпаргалка Ссылка на комментарий
abramcumner 1 146 Опубликовано 22 Июля 2023 Поделиться Опубликовано 22 Июля 2023 @Norman Eisenherz выложи полную функцию с тестовым выводом. Ссылка на комментарий
Norman Eisenherz 309 Опубликовано 22 Июля 2023 Поделиться Опубликовано 22 Июля 2023 Потестил еще: сбой только в старом варианте "0, 0 else сумма". Если сделать "(0,0 + значение) else сумма", считает правильно даже в общем цикле (ожидаемо). Проще оставить вариант с предварительным заполнением нулями – меньше кода. 1 Мини-моды: ТЧ ЧН ЗП Шпаргалка Ссылка на комментарий
phalcor 60 Опубликовано 23 Июля 2023 Поделиться Опубликовано 23 Июля 2023 Приветы! Подскажите, как можно определить опьянение актора? Скриптовой функции, я так понял, нет. Может, как-то через нет-пакет это число добывается? Платформа: ОП 2.2 Добра. Ссылка на комментарий
mole venomous 3 386 Опубликовано 23 Июля 2023 Поделиться Опубликовано 23 Июля 2023 @phalcor , if db.actor.alcohol > 0 then Здесь могла быть ваша реклама. Ссылка на комментарий
phalcor 60 Опубликовано 23 Июля 2023 Поделиться Опубликовано 23 Июля 2023 2 минуты назад, mole venomous сказал: @phalcor , if db.actor.alcohol > 0 then Увы... attempt to perform arithmetic on field 'alcohol' (a nil value) Ссылка на комментарий
mole venomous 3 386 Опубликовано 23 Июля 2023 Поделиться Опубликовано 23 Июля 2023 (изменено) 13 минут назад, phalcor сказал: Увы... 28 минут назад, phalcor сказал: Платформа: ОП 2.2 У меня OGSR, в биндере actor_binder:update(delta) https://disk.yandex.ru/i/J16oMpsKFlCeUA Изменено 23 Июля 2023 пользователем mole venomous Здесь могла быть ваша реклама. Ссылка на комментарий
phalcor 60 Опубликовано 23 Июля 2023 Поделиться Опубликовано 23 Июля 2023 7 минут назад, mole venomous сказал: У меня OGSR Да, понятно. Но у меня обычный двиг. Тут, наверное, только net_packet подойдёт, да и то... знать бы, как? Ссылка на комментарий
mole venomous 3 386 Опубликовано 23 Июля 2023 Поделиться Опубликовано 23 Июля 2023 @phalcor , в трубочку дыхнуть надо? Ну если прибухнул, выдай инфопоршен, который удалится по таймеру... 1 1 Здесь могла быть ваша реклама. Ссылка на комментарий
Zander_driver 10 333 Опубликовано 23 Июля 2023 Поделиться Опубликовано 23 Июля 2023 27 минут назад, phalcor сказал: Но у меня обычный двиг 1 час назад, phalcor сказал: Платформа: ОП 2.2 Пардон, но разве это одно и то же? Мне кажется что в ОП с движком что-то все же делали. Стало быть, надо брать их справочную документацию/исходники и смотреть там. 4 минуты назад, mole venomous сказал: инфопоршен, который удалится по таймеру Костыль на костыле... и работать "так, как ожидалось", эта конструкция будет не всегда. И числовое значение если оно важно/нужно, из инфопоршня не вытянуть. Мод, где не бывает одинаковых путей - Судьба Зоны. (Лучшее, что у меня получилось на X-Ray) На базе модифицированного движка OGSR Engine. Бывший мододел на X-Ray / Начинающий игродел на Unreal Engine. Программист. AMD Ryzen 9 7950X (16 ядер, 32 потока, 5.75 ГГц); RTX 3080; 128 ГБ DDR5; Arctic Liquid Freezer II-420; 3 ТБ SSD PCIe 4.0; 4ТБ HDD. Ссылка на комментарий
mole venomous 3 386 Опубликовано 23 Июля 2023 Поделиться Опубликовано 23 Июля 2023 (изменено) 6 минут назад, Zander_driver сказал: Костыль на костыле... и работать "так, как ожидалось", эта конструкция будет не всегда. И числовое значение если оно важно/нужно, из инфопоршня не вытянуть. Никто не интересовался конкретно числовым значением, насколько я вижу. Также непонятно, всегда ли нужно проверять ГГ на градус, может лишь единожды. Есть скриптовый вариант? Предложи, ибо твоё мнение авторитетно. Изменено 23 Июля 2023 пользователем mole venomous Здесь могла быть ваша реклама. Ссылка на комментарий
Рекомендуемые сообщения
Создайте аккаунт или авторизуйтесь, чтобы оставить комментарий
Комментарии могут оставлять только зарегистрированные пользователи
Создать аккаунт
Зарегистрировать новый аккаунт в нашем сообществе. Это несложно!
Зарегистрировать новый аккаунтВойти
Есть аккаунт? Войти.
Войти