Это копия, сохраненная 19 января 2024 года.
Скачать тред: только с превью, с превью и прикрепленными файлами.
Второй вариант может долго скачиваться. Файлы будут только в живых или недавно утонувших тредах. Подробнее
Если вам полезен архив М.Двача, пожертвуйте на оплату сервера.
Прошлый тред: https://2ch.hk/gd/res/809329.html#824166 (М)
Официальный сайт: https://unity3d.com/ru
Документация: https://docs.unity3d.com/ru/current/Manual/index.html
Уроки: https://unity3d.com/ru/learn/tutorials
Форум: https://forum.unity3d.com/
Магазин ассетов: https://unity3d.com/ru/asset-store
UnityWiki: http://wiki.unity3d.com/index.php/Main_Page
На Unity сделано много замечательных игр - Valheim, Genshin Impact, Subnautica, Albion Online, Endless Space, Beat Saber, Boneworks, Rust, Блицкриг 3, Pillars of Eternity, Tyranny, Kerbal Space Program и многие другие. Главным преимуществом Unity перед другими движками является его простота для одиночной разработки. Не нужно иметь целую компанию девелоперов, чтобы сделать хорошую игру. Если ты один или имеешь небольшую команду и хочешь сделать хорошую игру без претензий на ААА, то Unity станет лучшим выбором. Тем не менее, даже крупные корпорации зачастую выбирают для своих игр именно Unity.
FAQ
- Какие у Unity сильные стороны?
- Простота разработки, удобный инструментарий, кроссплатформенность, богатая документация, огромное сообщество.
- Какие у Unity слабые стороны?
- Сложность в создании фотореалистичной графики. Для графики "как в Crysis" рекомендуется взять другой движок. Хотя Unity вполне способен выдавать не уступающую любым другим движкам картинку, это требует определённого навыка от разработчика.
- На каких языках я могу писать скрипты для Unity?
- На выбор два языка - C# и UnityScript. UnityScript - это что-то среднее между JavaScript и ActionScript. Выбирай язык по своему вкусу, они оба вполне удобны, но помни, что большинство примеров написано на C#.
- Для каких жанров подходит Unity?
- Для абсолютно любых! Жанр ограничивается лишь фантазией разработчика (и его умением писать скрипты, разумеется). Можно создавать и РПГ, и стратегии, и слэшеры. Можно делать VR-проекты или Minecraft-подобные песочницы.
- На каких платформах работают созданные с помощью Unity игры?
- Windows, Linux, MacOS, SteamOS, Android, iOS, Windows Phone, PlayStation4, Xbox One, WebGL, Oculus Rift и многие другие. Полный список можно найти на официальном сайте. Таким образом, игры Unity работают на десктопах, на смартфонах, планшетах, приставках, в браузерах, VR-очках и некоторых других системах.
- Часто вижу скриншоты с красивой природой на Unity. Как такое создать?
- Очень просто! В Unity встроены удобные инструменты для создания террейна и SpeedTree для создания деревьев и готовая реализация ветра - не нужно ничего писать или скачивать и подключать плагины - ландшафт в Unity создаётся в пару кликов.
- Что такое стартер киты?
- Starter Kit - это набор скриптов и префабов, а зачастую и графических элементов для игры. Они призваны облегчить разработку игры определённого жанра и как правило разбиты по жанрам (Action-RPG Starter Kit, RTS Starter Kit, 3D Shooter Starter Kit, Space Game Starter Kit, VR Starter Kit и так далее). Также бывают стартер киты различных игровых элементов, не связанных с геймплеем (Nature Starter Kit с дополнительными природными объектами, Medieval Starter Kit со средневековыми объектами и так далее). По сути, стартер киты выполняют в разработке игры ту же роль, что и фреймворки в программировании. Однако стоит отметить, что использование геймплейного стартер кита принуждает разработчика изучать большое количество чужого кода и чужой структуры для внесения своих изменений и полноценного использования. В связи с этим большинство разработчиков предпочитает писать почти всё с нуля, получая полное понимание работы своей игры. Новичкам крайне не рекомендуется начинать знакомство с Unity со стартер китов.
- Что нужно уметь делать для создания полноценной игры, кроме Unity-разработки?
- Кроме непосредственной разработки игры на Unity, требуется также уметь создавать 3D модели (3ds Max, Blender, ZBrush), 2D рисунки (GraphicsGale, Aseprite, Piskel), текстуры (Substance Designer, NeoTextureEdit), музыку (FruityLoops, Ableton). Не обязательно учить это всё - например, в 2D играх не нужны 3D модели, а музыка необходима далеко не всегда. Также вы можете скачивать элементы для ваших игр на бесплатных сайтах. Если у вас есть деньги, то все необходимые элементы можно заказать у фрилансеров на https://www.fl.ru/ (русскоязычный) или https://www.upwork.com/ (англоязычный).
- Бесплатен ли Unity?
- Можно свободно скачивать, использовать и продавать готовые игры на Unity с лицензией Personal - это абсолютно бесплатно! Но на бесплатной версии при запуске игры будет появляться короткий стартовый ролик "Made with Unity", а также ваши доходы ограничены 100 000 долларов в год. Для снятия этих ограничений нужно приобретать платные версии лицензий Unity. В конечном итоге, платные варианты используются лишь крупными компаниями с огромными доходами, тогда как обычные разработчики в большинстве своём используют бесплатную Personal лицензию.
Обучение
- Язык
Итак, с чего же начать изучение этого замечательного движка? Прежде всего, с изучения языка. Самые основы C# можно узнать на интерактивных курсах здесь:
https://dotnetcademy.net/CSharp/Beginner
или в текстовом туториале здесь:
https://www.tutorialspoint.com/csharp/csharp_quick_guide.htm
Для изучения основ UnityScript выучи вначале основы JavaScript:
https://learn.javascript.ru/
Помни, что далеко не все элементы JS есть в US. Чтобы понять, в чём разница между этими двумя языками, прочти эту статью:
http://wiki.unity3d.com/index.php/UnityScript_versus_JavaScript
Помни, что тебе достаточно одного языка из двух и учить их оба одновременно не нужно.
- Движок
Если ты уже умеешь использовать язык, то можно приступать непосредственно к изучению движка. Крайне рекомендется купить/скачать книгу Unity in action (Unity в действии). В ней подробно описываются множество возможностей движка.
http://www.ozon.ru/context/detail/id/34792570/
Также посмотри на видеотуториалы с официального сайта:
https://unity3d.com/learn/tutorials
Если же ты не любишь видеотуториалы (или не понимаешь разговорный английский) и предпочитаешь текст, то посмотри здесь:
http://catlikecoding.com/unity/tutorials/
Тут крайне подробно описан процесс разработки и приведены примеры кода. Эти туториалы универсальны и описывают множество различных частей игры, от работы с текстурами до генерации карты мира. А вот в этом туториале описыватся разработка двухмерной игры с видом сверху:
https://www.raywenderlich.com/61532/unity-2d-tutorial-getting-started
Это будет полезно, даже если ты планируешь разрабатывать трёхмерную игру. Ни в коем случае нельзя обойти вниманием этот сборник туториалов:
https://noobtuts.com/unity
В нём подробно описывается процесс пошагового создания разных игр - двухмерных и трёхмерных.
Разумеется, все эти туториалы охватывают лишь часть возможностей Unity. Самый надёжный способ выучить Unity - это начать делать игру и по мере разработки гуглить непонятные моменты.
Шапка: https://www.writeurl.com/publish/qzgktisltkskaitem6aa
ОП-пост с дохлыми ссылками уже копируют 10 лет
Пусть бампает, может и ссылки сам обновит, которые ему не нравятся
Да как вы заебали делать перекат с 60% протушхей пастой по юнити. Там уже больше половина не актуальна сука!
Дайте я сделаю актуалочку блядь! Куда ты блядь летишь перекатывать!?
У нас старше блять доски уже.
Ну так че не сделал за столько перекатов, а смотрел на 60% протухшую пасту?
Могу сделать свой перекат в обновлённой шапкой, где будет актуалочка, но думаю что без одобрения модера без смысла, его потрут как дубль из-за того что по дате будет создан позже.
>>24259
Потому что было лень и похер? И надежда что уж следующий наконец кто-то сделает нормально. Честно не представляю почему среди столько анонов пользующихся юнькой не нашлось одного кто шапку бы переделал.
Ваши чатики вообще не нужны. Эхо-комнаты, где одни и те же дегроды пишут одно и то же.
Все потенциально годные идеи тредов канализурются в этих чатиках.
Что за поколение уебков с чатиками.
Зашел в "анимач", там одни чатики - половина оФФициальных закрепленных. Блять.
Перетирание одного и того же кала.
Я тут как-то сказал, что вышло новое издание юнити ин экшон, так местный перекатчик все стены говном измазал патамушта нинарусском книга.
>Потому что было лень и похер? И надежда что уж следующий наконец кто-то сделает нормально. Честно не представляю почему среди столько анонов пользующихся юнькой не нашлось одного кто шапку бы переделал.
Ну так не вини потом других в том, что тебе было похер. Что ты там думал никого в принципе не ебет, пока ты свое думало не озвучил или не описал. Если местный перекатчик говном стены намазал и тебя задел, ну так перекати быстрее него, чтобы у него хуй отсох. Какие там чатики-хуятики я вообще не ебу, я в треды захожу вопросы задавать, че там еще выдумали пидорасы зумеры для пиздежа - похуй. Три твоих проблемы разобрал, больше не ной.
А вообще перекатывал этот тред я лично, потому что по своей же глупости подумал о лимите в 500 постов, хотя знаю об увеличенном лимите для тематик.
Делай новую шапку, ее в любом случае учтут
Ну и получишь репорт пидор.
>Честно не представляю почему среди столько анонов пользующихся юнькой не нашлось одного кто шапку бы переделал.
Честно, не представляю почему ты такой душный нытик. Может быть потому что задумка таких тредов в помощи новичкам? Ты можешь себе представить ультра профессионала, который будет создавать тред на дваче и бесплатно отвечать на вопросы мимокроков, которым может и нахуй не нужен юнити, они просто интересуются? Не, ну может так и было, но я сильно в этом сомневаюсь.
Мое личное мнение, никому нахуй не нужное, в тредах большая часть новичков, к которым я отношусь и которые в большинстве своем мало что понимаю и знают. Какие там книги в шапках, новые или старые мало кого волнует, если что они задают вопрос блядь, ведь для этого существует принцип форума. В этом его цель блядь, обсуждать. Профессионалы тут бывают, и мне они ни раз помогали, даже переписывали коды, за что им благодарен. Но с таким хуесосом как ты, тут бы был телеграмм бот со ссылками на инфу. Инфу не нашел - нахуй пошел. И так большинство форумов по юнити мертвы, так ты еще и двачерский тред утопить хочешь.
Какой же ты пидор, как же ты бесишь.
Хуй соси. Но шапку исправь. <3
А ведь это форсится самой мочой. Блять, этот такой тотальный маркетинговый проеб, что я даже не знаю что в голове у админов двача.
>А вообще перекатывал этот тред я лично
Всего один вопрос. Куда ты так спешил перекатывать? Тред может хоть месяц лежать и тонут, но нет же, тебе надо прям срочно перекатить, зачем? Ты ебанутый? Или думаешь без тебя всё бы пропало?
>Тред может хоть месяц лежать и тонут
не ты случаем тот анон, который на маркетинговый проеб жаловался парой постов выше? В /gd в принципе сидит не много человек, не большим числом тут сидят люди, которые хотя бы понимают что-то в программировании. А уж если они еще и с юнити дружат, то цены им нет. Пока тред по их теме валяется на дне и вяло попердывает, время их появления в треде стремительно увеличивается.
Не знаю, какое у тебя мнение о тредах и в целом идеи завлекания новых людей или удерживания прежних, но в моих личных интересах привлечь в тред как можно больше людей, чтобы увеличить шансы на помощь. Будет у меня вопрос, который я нигде больше не смог решить, может быть, мне ответят тут. Вот почему я озаботился перекатом, чтобы быстрее находили тред.
Да, есть каталог и поиск по словам, я сам так попал в тред по юнити в свое время, однако, если ты реально думаешь, что поисковик и каталог упрощают поиск большинству людей - ты ахуенно ошибаешься, большинство нихуя не понимают, даже если они пиздец какие умные. Иначе бы не существовало техподдержек с им ебаными операторами, ведь всем бы хватало бота на линии.
Еще вопрос?
>Сделай другие треды.
Делал. Его удалили
Писал посты. Их удаляли. Зарекся создавать контент на двачепомойке после этого
По-человечески, жаль. Тебе не повезло, но мазать стены говном, как это делали до тебя не лучше. Проблемы ты так не решил
во что играет, то и делай
Если не хочешь стать подкаблучником, то никакую не делай.
>Какой же ты пидор
>Хуй соси
Ахуенно. Пишешь ты, а пидор якобы я. Охуенная логика.
>Но шапку исправь.
Ради всех нас юнитибогов, а не потому что ты написал, так и сделаю к следующему перекату.
Лол. Ты даже не понял суть моего высера.
Не повезло анонам, которые не увидят нового контента на доске и ответов на их вопросы
Какую качать? Там вообще один и тот же установщик для 2D и 3D?
И можно как-то уменьшить размер готовой папки с игрой, если у меня только 2D? Удалить может какие-то ненужные элементы?
лена бутс
Вон персональная версия универсальная для начала, ее можешь скачать. 2D и 3D создаются в одной программе, но в разных режимах. На счет уменьшения размера папки не знаю
Предположительно тебе прилетит от Лего.
Тут пдф на Lego Microgame, который идет щас с юнити хабом вместе:
https://images.response.unity3d.com/Web/Unity/{3d254713-049e-4de2-a0da-dfed89d56c70}_LEGO_Microgame_Terms_of_Service.pdf
Либо просто вбей в гугл LEGO® Microgame Terms of Service и найди.
В доке указано, что ты соглашаешься не использовать все ассеты от лего в коммерческих целях.
By designing in the Unity editor or elsewhere and/or uploading your LEGO
Designs, you agree that you and all aspects of your LEGO Designs comply with these
Terms, and that any such LEGO Designs shall not be used for commercial purposes,
in any manner whatsoever.
Не на разных режимах, а с разными предустановками (модулями которые можно вручную поменять, убрать, добавить на любой стадии работы с проектом)
Понял
никакую не делай, запили шейдор, который бы рисовал всякие ёбнутые спирали, мандельброты и она такая подумает НИХУЯ ОН УМНЫЙ
>shall not be used for commercial purposes,
in any manner whatsoever.
Я не силен в юриспруденции вообще, но мне кажется, что "не в коммерческих целях во всех смыслах" мой вольный перевод относится и к бесплатной игре, с которой ты будешь выкачивать бабки по рекламным банерам. Если не будешь интегрировать рекламу, а реально сделаешь бесплатную игру, наверное, не будет проблем.
Возможно стоит уточнить на форумах юнити, там девелоперы отвечают
Романтическую вн короткую. Картинки укради в гугле.
Да забей на эти шейдеры, нормальных туторов толком нетвезде какя то рванина, лучше уже дефолтными материалами обмазываться и хендпейнт текстурами.
2. Не могу добиться однородной прозрачности стен. Частично проблема в том, что текстуры накладываются одна на другую, как в случае швов. Пожалуй, там можно просто убрать текстуру. Но это не решит проблему полностью. Можно поиграться с разной прозрачностью.
Тут, конечно, дело в том, что в оригинале использовались не 3д модели, а спрайты, где легче было добиться прозрачности. Потому в 3д точно такого эффекта можно и не добиться.
Всё, что я сделал, только на экране. Никогда раньше изометрией не занимался.
Насчет своей проблемы, то такие мысли:
1) В Д3 просто заставляют пропадать стены.
2) В ПОЕ не изометрия, а камера сверху.
3) Скорее всего нужно делать 2д, парень по ссылке добился нужного освещения, и стены у него становятся прозрачными, но это ГМ, а не юнити.
https://www.youtube.com/watch?v=Q5P23eI0SqU
1) Не могу понять, в каком разрешении создавать спрайты.
2) Как эти спрайты точно подогнать в блендере под камеру.
3) После импорта в тайлсет, я не могу их выделить нормально, приходится выбирать по очень большой площади.
И самая главная проблема, что мне их нужно очень точно располагать, чтобы не было ни накладок, которые будут видны при прозрачности, ни пробелов между тайлами, которые часто встречаются даже в квадратных тайлах
>Не могу понять, в каком разрешении создавать спрайты.
Здесь два подхода. Либо делаешь любые размеры и руками подгоняешь в юньке. Или же имеешь весь тайлсет в одной палитре дабы чётко видеть размеры.
>Как эти спрайты точно подогнать в блендере под камеру.
В смысле точно? По карте у тебя они идеально ложаться, разве что размеры надо соблюдать. Если ты про камеру, то она опять же зависит от размеров, обычно 3-4.
>После импорта в тайлсет, я не могу их выделить нормально, приходится выбирать по очень большой площади.
Зажимаешь шифт и выделяешь все, потом переносишь, это старый способ. Новый это тупо всю картинку порезаную кидаешь в палитру, оно само всё вносит.
>>24670
>В смысле точно?
Там был глюк. Я пересоздал сетку и все норм.
Как правильно делать полы?
Есть несколько подходов.
Самый популярный это комнаты-блоки. Ты собираешь уровень из разных блоков, а швы на сходе между ними маскируешь любым мусором/другими объектами.
Другой вариант делаешь уровень в 3д редакторе, в конце режешь его чтобы текстуры не расплылись и смотрелись ок.
Вариант же который у тебя на пике тоже допустим и применим, но только в масштабах маленькой игры, или в комбинации с вышеперечисленными методами.
Если тебе нужен пиксель пёрфект то используй для нарезания aseprite.
Не пробовал, но по идее можно генерировать повторяющиеся элементы с плавающим рандомом геонодами блендера.
Умельцы так камни, траву, облака и прочее делают на ютубе.
>Ты собираешь уровень из разных блоков, а швы на сходе между ними маскируешь любым мусором/другими объектами.
Не очень понял как это. Если у меня будет перекресток со швами метра в два, то как мне такой крест закрывать? Ну допустим ковер можно сделать, но не от стены к стене же.
>Другой вариант делаешь уровень в 3д редакторе
А это не дорого по ресурсам компа выйдет? Я просто реально хз как рассчитывать нагрузку того или иного объекта на систему. В бледнере я могу сделать целый левел, вылепить деталей, но будут тысячи точек, которые жрут прилично.
>Так ты включи репит текстуре и управляй UV.
Это попробую.
>по идее можно генерировать повторяющиеся элементы с плавающим рандомом геонодами блендера.
можно, но по факту любой пол надо будет делать в блендере под размер комнаты
А, под блоками ты имеешь в виду просто разные модельки стен, потолка и пола, из которых комнату собирать можно? Такое я себе сделал, ими комнату собирал, но я думал пол иначе делается.
Почему синглотонннее в унити так уебански делается? Почему не как в годо?
Для ясности, в годо нужный скрипт добавляется в автозагрузку проекта и во всех скриптах доступен
В унити же какая-то блядская пляска, ещё и объект добавлять надо и чую, что на каждый уровень
Если я ошибаюсь, то объясните КАК?
Мне нужно для глобальной громкости звука, искал, но не нашёл ничего адекватного
Просто заебашь файл со статичным классом, в нем статические переменные хуячишь. И все.
Этот класс будет виден везде.
Вот прямо так?
Однако мне нужно ещё уточнить.
Просто создаю статик класс и он валяется где-то там в проекте, доступный везде в коде или так это надо будет вешать на объект пустышку в каждой сцене?
Просто хренинглтонн предлагают вешать на пустышку, потом префоб и его пихать на каждый уровень, мне такой план не нравится.
Вопрос снят, проверил в лоб первый вариант, заработало.
Правда непонятно чего тогда с синглотонном носятся, ибо по умолчанию такой подход и использовал
> вешать на объект пустышку в каждой сцене?
C# и .NET - самостоятельная платформа. Можешь "отдельно" от api юнити создать хоть синглтон, хоть сервис локатор, хоть что угодно.
https://gameprogrammingpatterns.com/contents.html
Если тебе нужен синглтон на основе именно игрового объекта юнити, то можешь сделать например так:
https://gamedevbeginner.com/singletons-in-unity-the-right-way/
Можешь при помощи ScriptableObject хранить списки конфигов и ссылки на префабы с менеджерами/сервисами, которые будут создавать при старте игры или по запросу. Вариантов очень много.
>Правда непонятно чего тогда с синглотонном носятся
Потому что тебе пиздюлей на работе не выписывали за статические классы.
У статика свои ограничения и особенности.
https://www.reddit.com/r/Unity3D/comments/9tx4rs/monosingleton_vs_singleton_vs_static_class/
Я просто создал скрипт со статичным классом, который ни к какому объекту не привязывал.
Хочешь сказать, что при загрузке каждой сцены будет создаваться новый?
Как включить AA, оно же антиализинг? То, что находил в нете в собранной игре не работает.
Я знаю, что лесенкоубиралок много видов
>> ScriptableObject
> Вот это интересная тема
Тема крутая. У меня на них хранятся все игровые конфиги. Все игровые предметы (их описание, иконки, редкость и прочая информация). Есть совсем уж безумные примеры использования SO от самих юнитеков:
https://www.youtube.com/watch?v=6vmRwLYWNRo
То есть через MonoBehaviour (компоненты) ты пишешь обычную логику, без данных. А сами данные передаёшь через ScriptableObject. У тебя есть логика какого-то моба, но сам компонент при этом не хранит информацию о его уроне, количестве жизней, баффах/дебаффах и т.п. Всё это передаётся через ссылку на SO. Можно использовать interface C#. Можно таким же образом передавать поведение (паттерн strategy).
Смотрю, интересная штука, но как же хочется закатить истерику - я хочу статические классы использовать как чэд, это просто и понятно, аррряяяя
480x480, 0:11
я хочу подменить кости одного рендерера(куртка) костями другого(тело), этакая модульность
вот сделал такую хуйню:
https://rentry.co/rtmsv
поясните мне где я объебался (кроме проверок в подмене костей рендерера)
протестировал, вроде работает, кости заменяются, куртка сразу на старте прыгает на персонажа, но обе модели пока еще не анимированы, может ли это проблем навалить потом?
Их можно загружать с ресурсов через код.
У меня на проекте был статический класс который подгружал скриптеблы по запросу из ресурсов, по типу. Очень удобно
отлично
но я внезапно осознал что хочу еще и плащ потом добавить, а у персонажа костей плаща нети не будет и у меня затык ведь если я подменю кости плеч и шеи плаща на кости персонажа то костяшки самого плаща(потомки шеи) не будут им следовать
Не обязательно, если на сцене есть какой-нибудь объект, который все их проинициализирует(чтобы они сбросили или подгрузили данные из файла)
с помощью адрессабле загрузка из ресурсов
https://docs.unity3d.com/Packages/com.unity.addressables@0.4/api/UnityEngine.AddressableAssets.AssetReference.html
8 лет разработки! Слабо так же?
если бы мне всякие куколдычи и симпычи донатили, чтобы я не сдох с голоду - не слабо
Ту новеллу от создателей Бесконечного лета про рокенрольщиц в советском посольстве в Японии? Неужели вышло?
Спасибо! Тогда переделаю спрайт персонажа и запилю!
>8 лет разработки!
Да как нехуй. За 7-8 лет разработки обычно посредственная хуйня выходит, которую еще после релиза 2-3 года надо допиливать, так что я справлюсь идеально. Ну а раз платят, то еще и с удовольствием
как сделали игру, так она и играется. Вальхейм не тормозит в меню
В случае если нужен движок - насколько это сложно будет делать?
Помимо этого, есть ли там верификация и что просят для подтверждения?
*Всякое - это в основном 3д ассеты окружения
Ассет ты можешь сделать только в самом юнити.
Для того чтобы выложить что либо в сторе нужно пройти анальную регистрацию.
Для того чтобы получать бабки еще 100500 кругов ада.
Вопрос: Делать ли игру в 2D полностью и заказывать полуспрайтерные ассеты, или бекраунды в 2D а корабли в 3D, потому что может потребоваться смена их деталей на лету и идл анимации разных корпусов, как в КР2?
612x1258, 0:12
Больше всего зависит от того кто это дело делает (Какой у него опыт в 2Д и 3Д, где больше), и от того кто будет делать спрайты и 3д модели.
Если сильна 3д сторона, то выгоднее работать с ней. Если 2д художник лучше то всё в 2д.
Чтобы получилось на подобие рейнджеров, то всё делается в 3д, фоны это несколько анимированных слоёв накладываемых друг на друга.
Плюсы 3д что его можно превратить достаточно просто в 2д. Из минусов то что его надо делать.
>Чтобы получилось на подобие рейнджеров, то всё делается в 3д, фоны это несколько анимированных слоёв накладываемых друг на друга.
Я не думаю что это обязательно, у того же Старсектора делают корабли сразу в 2D, хотя суть и похожая. Но там нет идл анимаций.
Как я и написал, всё упирается в того кто будет делать графику. Но у 3д есть бонус, что его проще создавать, изменять, и можно превратить в 2д.
У 2д такого нету.
В общем пацаны, тут надо чтобы по результатам проверки, при нахождении совпадения в баттон.текст копировалось значение из скилл.валуе. В противном случае баттон дестроится. Можно как-то это компактно ебануть через лямбды там всякие хуямбды?
Можно. В блендере
>Можно как-то это компактно ебануть
Зачем? Чтобы код был максимально непонятным? Пиши код так, чтобы он был понятным. Заводи для этого лишние локальные переменные, добавляй циклы, скобки и т.п.
Вот это >>26232 вообще шок-контент.
Хотя у тебя изначально код ебанутый. Но хотя бы не делай его безумно ебанутым.
Другой сеньёр, но вставлю свои 146 копеек.
Смысл кода которого ты пишешь, что ты мог понимать что происходит и не тратить по минуте расшифровывая каждую строчку в голове, тратя силы на не нужное.
Тебе не надо стесняться кода, или прятать его, он твой, только для тебя.
За количество знаков с тебя не берут деньги, твои комменты никто не будет читать.
В данном случае присутствует образовательный момент. Ну типо я могу ебануть полотно из ифов и форов с тем же результатом, а могу поковырять иенумерабл, лямбды и предикаты.
Т.е. о том, что мой код нечитаемое говно, пишет дурачок, который даже простой текст на русском понять не может? Я по слогу приблизительно чувствую, что ты за пидор, я тебя запомнил еще с твоих прошлых кукареков лол. Пошел ты нахуй, пес)))
Даже завтра весь код перелопачу.
>Чтобы код был максимально непонятным?
Компактный код может быть понятным.
>Пиши код так, чтобы он был понятным.
Это субъективно. Математикам формулы понятны, а гуманитарий в них ничего не поймёт... Среди программистов есть как те, кто ближе к гуманитариям, так и те, кто ближе к математикам. Последние увлекаются функциональными языками и непонятными конструкциями из однобуквенных слов, но для них-то это всё понятно, это только мы, программисты-гуманитарии, не можем понять, не разложив все их закорючки в виде длинной простыни текста на почти естественном языке.
>Вот это >>26232 вообще шок-контент.
А что такого, да, у C# некрасивый синтаксис, но алгоритм простой: для каждой второстепенной кнопки ищем у 0-й группы игроков умение с названием, совпадающим с надписью кнопки, а затем пытаемся взять значение найденного умения и дописать его к надписи кнопки в виде строки; если не получится найти умение, будет попытка обратиться к полю значения в null, что вызовет исключение AccessViolationException, которое мы обработаем уничтожением кнопки. Подход странный, но ничего непонятного тут не вижу. Однако, вместо вызова исключения лучше сделать условный оператор, т.к. исключение создаёт ООП объект, который затем уничтожается после обработки, а это лишние затраты ресурсов, которых практически нет в условном операторе и одной локальной переменной, получающей ссылку на давно существующий объект. Также лучше было бы не уничтожать лишние кнопки, а создавать нужные, чтобы сэкономить ресурсы, тратящиеся на создание и уничтожение лишних кнопок. Это может показаться экономией на спичках, но если осознанно подходить к таким моментам в разработке, потом не будет лишних проблем; кто наплевательски относится к ресурсам компьютера в одном месте, склонен так делать и во всех остальных...
>Также лучше было бы не уничтожать лишние кнопки, а создавать нужные, чтобы сэкономить ресурсы, тратящиеся на создание и уничтожение лишних кнопок.
И не только на создание и уничтожение кнопок, но и на поиск умений и сравнение названий. Вместо поиска умения под каждую кнопку логичнее было бы пройтись по списку умений и создать каждому умению свою кнопку, если конкретному умению кнопка вообще нужна. А чтобы потом обновлять значения на кнопках, не создавая кнопки заново, нужно повесить на каждую кнопку скрипт, хранящий ссылку на связанное умение и по запросу обновляющий свою надпись актуальными данными об умении. Хранение "лишнего" объекта со скриптом в памяти намного дешевле, чем выделение памяти под группу объектов с последующим освобождением. Надеюсь, все здесь это понимают и не создают интерфейс инвентаря с нуля каждый раз, когда игрок пытается его открыть? А то некоторые игры особенно на юнити создают впечатление, что там не только интерфейс с нуля формируется, но даже иконки с диска повторно считываются... Вот не надо так делать, это ухудшает юзабилити многим игрокам, создавая неприятные задержки при открытии меню.
> Это субъективно
Да так то любое восприятие субъективно, но так подходом далеко не уедешь.
Есть и объективные метрики(которые опять же вносят субъективный вклад в общее понятие понятности лол), просто их подсчитать нереально - типа сколько вещей надо минимально одновременно держать в голове, нужны ли знания другого фрагмента кода, нужны ли знания внутренней реализации используемых методов, есть ли побочные эффекты.
Но, разумеется, здравый смысл не дремлет и в особо запущенных случаях все, даже автор кода смогут почувствовать, что что-то не так.
> непонятными конструкциями из однобуквенных слов
> в виде длинной простыни текста на почти естественном языке.
Звучит так, будто вся разница в длине слов.
>Алгоритм простой
И я с тобой согласен. Если взять исключительно читаемость, то я типо серьезно не понимаю, что тут нечитаемого. Типо левая часть по дефолту надпись на кнопке. В правой тоже одно действие.
В начале игры вы создаёте пулл, в течении игры берёте из него нужный объект и реализуете его, а как только он вам не нужен просто выключаете и снова добавляете в пулл.
ЕЩЕ раз, никогда, не надо создавать и уничтожать объекты.
>на готовые и нормальные решения
Гуглить не научился? Уже столько лет, а досихпор пишешь такую глупость. Тебе дано направление, сформулированная мысль, а тебе и этого мало. Хочешь чтобы за тебя и код писали, а ты только копировал?
>Звучит так, будто вся разница в длине слов.
Если подумать, так оно и есть. Короткие идентификаторы не говорят сами за себя - нужно помнить, что они обозначают, чтобы понимать, что с ними или с их помощью происходит. К тому же их используют чаще всего для того, чтобы компактно совмещать множество операций - в итоге на одной строке может быть формула из десятка операций над десятком идентификаторов, не говорящих за себя. А оперативная память человека очень сильно ограничена, в среднем, как говорят, человек может удерживать всего 7 сущностей в этой памяти, добавление новой вызывает забывание одной из старых. Ты просто физически не можешь уместить в своей оперативной памяти десяток операций над десятком идентификаторов, а это нужно для понимания, что происходит на одной этой строчке.
Если же идентификаторы чётко описывают, что они означают, так, что в любом контексте не нужно бегать глазами в поиске объявления и потом удерживать его в памяти, становится проще понимать происходящее. К тому же длинные идентификаторы сложно напихать в одно место, ты невольно разбиваешь код на логические шаги, которые можно понять сами по себе. Становится проще разобрать код, хотя он и занимает намного больше места, но зато вся необходимая для понимания информация находится у тебя перед глазами столбиком, её не нужно удерживать в своей короткой оперативной памяти.
И ещё мозг легче распознаёт длинные слова, чем короткие, потому что первичная обработка зрительной информации опирается не на буквы, а на обобщённые геометрические формы и размеры. Это маленькие дети читают по буквам, потому что у них нет достаточного зрительного опыта, а взрослые бегло воспринимают слова и выражения, не всматриваясь в буквы. По этой причине, кстати, опечатки часто остаются незамеченными, но в коде это не проблема, особенно если идентификаторы длинные и отличаются больше, чем одним символом. Короче, распознать множество длинных идентификаторов из 3-4 полноценных слов каждое мозгу проще, чем расшифровать выражение из 3-4 коротких идентификаторов, ничем не напоминающих реальные слова, т.е. требующих внимательного разбора по буквам.
>Звучит так, будто вся разница в длине слов.
Если подумать, так оно и есть. Короткие идентификаторы не говорят сами за себя - нужно помнить, что они обозначают, чтобы понимать, что с ними или с их помощью происходит. К тому же их используют чаще всего для того, чтобы компактно совмещать множество операций - в итоге на одной строке может быть формула из десятка операций над десятком идентификаторов, не говорящих за себя. А оперативная память человека очень сильно ограничена, в среднем, как говорят, человек может удерживать всего 7 сущностей в этой памяти, добавление новой вызывает забывание одной из старых. Ты просто физически не можешь уместить в своей оперативной памяти десяток операций над десятком идентификаторов, а это нужно для понимания, что происходит на одной этой строчке.
Если же идентификаторы чётко описывают, что они означают, так, что в любом контексте не нужно бегать глазами в поиске объявления и потом удерживать его в памяти, становится проще понимать происходящее. К тому же длинные идентификаторы сложно напихать в одно место, ты невольно разбиваешь код на логические шаги, которые можно понять сами по себе. Становится проще разобрать код, хотя он и занимает намного больше места, но зато вся необходимая для понимания информация находится у тебя перед глазами столбиком, её не нужно удерживать в своей короткой оперативной памяти.
И ещё мозг легче распознаёт длинные слова, чем короткие, потому что первичная обработка зрительной информации опирается не на буквы, а на обобщённые геометрические формы и размеры. Это маленькие дети читают по буквам, потому что у них нет достаточного зрительного опыта, а взрослые бегло воспринимают слова и выражения, не всматриваясь в буквы. По этой причине, кстати, опечатки часто остаются незамеченными, но в коде это не проблема, особенно если идентификаторы длинные и отличаются больше, чем одним символом. Короче, распознать множество длинных идентификаторов из 3-4 полноценных слов каждое мозгу проще, чем расшифровать выражение из 3-4 коротких идентификаторов, ничем не напоминающих реальные слова, т.е. требующих внимательного разбора по буквам.
Двачую этого. Всё по делу сказано.
Выходит, что нужно писать максимально неочевидные конструкции с именами функций на экзотических языках. Тут осторожно, с китайским есть проблемы в самой юнити. Обфускация, ты понял? А то в один клик весь код вскрывается, хуйня же полная.
Для тебя все кроме простыни елс ифов будет неочевидно, теперь это стандартом должно стать или что?
Тут важно не путать говнокод по причине того что автор гуманитарий и лентяй, и объёмный код по причине того что автор адекватно реализует архитектуру, не пряча по десятку функций в одной строчке, тратя десятки минут на разворачивания каждой.
И на моей памяти с яндере девом скорее исключение чем правило, не помню чтобы кого так яростно форсили и обсирали в кодерской тусовке за всё время.
>именами функций на экзотических языках
>Обфускация
Точно не знаю, но я слышал, что после декомпиляции C# кода из игр на Юнити все идентификаторы выглядят как рандомный набор букв и цифр. Либо это особенность C#, либо эти имена получаются после работы обфускатора Юнити/стороннего обфускатора. Какой-то обфускатор точно есть, это целый бизнес, продавать волшебную палочку от неразрешимой проблемы. Собственно, если так хочешь обфусцировать код, делай это специальным обфускатором, потому что вручную с ума сойдёшь писать "непонятно".
>неочевидные конструкции
Если нет ограничений по времени, любую неочевидную конструкцию можно разгадать. Не существует защиты, которую нельзя было бы взломать. Поэтому хорошие поддерживаемые онлайн-игры меняют код по мере его разгадывания/взлома - хак действует только до тех пор, пока не выкатят очередной патч, после чего хакеры побанятся или не смогут использовать старые хаки. Но даже гигантам рынка не всегда удаётся защититься достаточно надолго, что уж говорить об инди. Так что если делаешь онлайн-игру, полагайся на старый-добрый банхаммер и желание сидеть 24/7, чистя игру от недобросовестных игроков. А на оффлайн игру вообще забей, кому нужен твой говнокод, если с него нельзя поиметь профит в виде преимущества перед другими игроками в онлайне... Кому захочется сделать клон твоей игры - возьмёт те же ассеты с ассет-стора и напишет такой же говнокод. Но скорее всего никто не захочет, потому что большинство игр проваливаются. Без обид, это статистика.
Объясняю. Написал я на бумаге как мне казалось охуеную идею, супер интересную и начал ее кодить. Пока кодил понял, что идея говно и переделал, раз, два, три, пять. И в итоге попал в круг, в котором я не двигаюсь дальше ни на шаг, потому что занят передумыванием и переделыванием основ и интерфейса под все этого по кругу. Сейчас я доделываю интерфейс создания персонажа в начале игры, чтобы он был независим от этих переделок и позволял создать персонажа и смотреть, и работать над тем что дальше. Кнопки выбора класса, расы и т.д. создаются через перебор имен соответствующих енамов. Но, если взять скилы, то у каждого класса свой набор, и у меня выбор, либо писать отдельный метод для спавна кнопок именно скилов, либо взять стандартный, который наспавнит вообще все скилы и удалить лишние. Причем завтра я могу решить, что скилы должны быть у всех одинаковые и просто закоменчу код с удалением кнопок и все.
этот код у меня спавнит буквально все кнопки в интерфейсе типа дндешного.
>не пряча по десятку функций в одной строчке
Ну сильно-то у тебя код не распухнет из-за сворачивания трёх строчек в одну.
>с яндере девом скорее исключение
Да его просто стало модным говнить, вот и говнили. Тем более, что было за что. Если бы он собрал всё это говно на крестах, хуй бы кто и узнал, что там в игре под капотом. Лишний стимул запутывать код - никто не сможет понять, где ты реально обосрался, а где переусложнил в целях защиты.
>>26312
>после декомпиляции C# кода из игр на Юнити все идентификаторы выглядят как рандомный набор букв и цифр
Возьми илспай да проверь этот пиздёж. Юнити даже после компиляции ill2cpp сохраняет имена функций, на этом основаны разные декомпиляторы, все имена в файле global-metadata.dat
>с ума сойдёшь писать "непонятно".
А когда пизданёшься - будешь писать непонятно по дефолту. Профит!
>хак действует только до тех пор, пока не выкатят очередной патч
Да тоже хуйня, хаки работают годами из-за отсутствия проверок на сервере. А если бы запутывали изначально в должной мере, то даже фришек ммо не появилось бы.
>Кому захочется сделать клон твоей игры - возьмёт те же ассеты с ассет-стора и напишет такой же говнокод.
А зачем стор, если юнити не защищает ассеты и можно выковырять прямо из игры? Как, собственно, и код.
>никто не захочет
Это если у тебя нет персональных хейтеров, которые готовы всрать каждый вечер в течении месяца, чтобы просто насрать.
>Юнити даже после компиляции ill2cpp сохраняет имена функций, на этом основаны разные декомпиляторы, все имена в файле global-metadata.dat
А вот это пиздёшь. После компиляции в ill2cpp, а не в моно, код становится нечитабельный от слова совсем. В моно да, если вскрыть скрипты почти тоже самое что и автора будет, за исключение отсутствия комментариев.
С 99.9% вероятностью если скомпилишь игру в ill2cpp, то её не смогут вскрыть, и уж тем более разобрать. А те кто смогут, они вообще в другой области обитают, и никогда в жизни не встретятся.
>код становится нечитабельный от слова совсем
Дядь, как минимум публичные классы и публичные методы сохраняют свои названия. Можно воссоздать структуру кода.
Короче смотри, немного советов. Старайся писать такие методы, которые выполняют одно конкретное действие. В твоём случае две проблемки:
1) Метод, помимо простого создания кнопок, ещё и заполняет массив объекта. Это уже два разных действия.
2) Твой метод знает структуру компонентов на кнопках, а он не должен этого знать. Тебе нужно создать для таких кнопок отдельный компонент, который внутри себя уже будет задавать имя, текст и тому подобное. Если ты изменишь структуру кнопки, тебе не придётся переписывать код извне, тебе нужно будет лишь изменить OptiоnВuttоn.
>А вот это пиздёшь
А знаешь, почему имена функций сохраняются? Да потому что краш дампы, логи, коллстаки. А там везде корректные имена, вот так "неожиданность". Да даже дебаг сборка сообщает в профайлер имена, хотя с твоих слов, она их "не знает".
На пике метаданные после il2cpp сборки, мне было лень создавать странное, просто создал новый дефолтный скрипт, собрал игру и нашёл его в сборке. На основе этих имен уже какая-нибудь ида может полностью разобрать всю логику и структуру игры.
>С 99.9% вероятностью если скомпилишь игру в ill2cpp
То её разберут каким-нибудь опенсорсным ill2cpp инспектором в один клик.
Я вот недавно узнал об всех этих декомпиляциях и возник вопрос. А как прятать пароли тогда? Допустим, ты из кода подключаешься к БД или к рекламному аккаунту. Получается, у любого человека есть этот код, если он скачал игру.
>То её разберут каким-нибудь опенсорсным ill2cpp
А его нету дятел. Бесплатно ты никак не вскроешь залётышь. Только моно.
Да не слушай бредни этого мамкиного хакера. Пустой проект он вскрыл, а не готовую игру.
>у меня выбор, либо писать отдельный метод для спавна кнопок именно скилов, либо взять стандартный, который наспавнит вообще все скилы и удалить лишние.
Ну и почему ты выбрал второе? У тебя уже есть способ определить, какие кнопки нужны персонажу - вот и добавь эту проверку в свой код создания кнопок, тогда ничего удалять не придётся.
А в идеале, если твоя игра предполагает переключение между персонажами разных классов, что потребует переключение кнопок, нужно создать все возможные кнопки и затем часть из них скрыть с экрана, но не уничтожать. И при переключении персонажа останется только включать и выключать видимость кнопок.
>Допустим, ты из кода подключаешься к БД или к рекламному аккаунту
Это два разных случая.
- Работа с БД: у тебя не должно быть прямого доступа к базе данных. Ты должен написать свой REST API. Пользователь сначала аутентифицируется, после посылает запросы. Все запросы тщательно проверяются твоим кодом.
- Работа с рекламным аккаунтом: в твоей игре хранится ключ доступа, который можно легко вытащить. Но что это даст тому, кто его получит? Да ничего, в общем-то.
>>26333
Лол, речь шла о названиях функций, которые программе для штатной работы не нужны совсем. Пароль вы сохраняете как строковую константу, а такие константы попадают в исполняемый файл вообще в открытом виде, если не использовать шифрование и сжатие, которое, во-первых, не даёт абсолютной защиты, а, во-вторых, вызывает негодование антивирусов, которым хочется посмотреть на ваш код в наиболее чистом виде.
Вывод: расслабиться и принять неизбежное. Нормальная система защищена от взлома даже с известным паролем, то есть ключ-то у тебя есть, да открыть им ничего нельзя...
>Работа с рекламным аккаунтом: в твоей игре хранится ключ доступа, который можно легко вытащить. Но что это даст тому, кто его получит? Да ничего, в общем-то.
Сделать 100500 запросов в секунду, чтобы твой аккаунт забанили за накрутку. Когда ты патчем сменишь ключ, повторить снова. И так пока ты не сойдёшь с ума, не удалишь игру с маркета или не выплатишь указанную сумму на высланный с одноразового почтового ящика криптокошелёк. Но поскольку ты пытаешься заработать на рекламе в 2022, денег у тебя нет, следовательно, останется только удалить рекламу из игры или бросить геймдев.
>у любого человека есть этот код, если он скачал игру
Очевидно, что да. Ты можешь его запаковать так, что он в принципе не будет вскрываться. Ну, допустим, используешь чёрную магию. А я скачаю снифер, какой-нибудь wireshark, и просто перехвачу его в процессе передачи по сети. Либо если у тебя БД прямо в игре и она зашифрована. То какой-нибудь уёбок напишет утилиту, которая находит ключ по сигнатуре и всё проёбано. Либо ты используешь AES шифрование и окажется, что AES key finder уже существует.
>>26332
Кек. Если ты долбоёб и о чём-то не слышал, это совсем не значит, что этого не существует. Вот пример тебе бесплатной опенсорсной утилиты.
https://github.com/Perfare/Il2CppDumper
Если бы ты немного больше знал о гейдеве, то слышал бы о вскрытии зашифрованного по самый анус хонкай импакта. Или хотя бы о вскрытии покемонов.
>А он действительно описал реальную ситуацию
А ещё на улице тебе можно сверху прилететь кирпич или сосулька, и ты умрёшь на месте. Бросай выходить из дома!
>А что за SecоndaryВuttоn? Что это означает?
ну типа нажимашь примари кнопочку Class в примари секции, после этого в секондари секции спавнятся секондари кнопки с названиями классов. По названиям объектов в сцене создания персонажа там все достаточно понятно.
>>26325
Спасибо за конструктив, покумекаю.
>>26317
ну покажи как надо.
>Если бы ты немного больше знал о гейдеве, то слышал бы о вскрытии зашифрованного по самый анус хонкай импакта.
Тупое ты животное каким местом ты читаешь? Там же я написал - 99.9% что твою игру не вскроют, и тут же приводишь пример игр-гигантов, которые как раз вксрывают, какая юы там не была защита.
Никто, никогда не вскроет твою игру если ты её запакуешь ill2cpp. Воот вообще без исключений.
Люди которые это могут сделать, не станут тратить своё время которое дороже твоей игры.
>Ну и почему ты выбрал второе? У тебя уже есть способ определить, какие кнопки нужны персонажу - вот и добавь эту проверку в свой код создания кнопок, тогда ничего удалять не придётся.
ну как вариант. ну типо у меня супер черновое уи только чтобы дойти до первой геймплейной сцены. Т.е. тут вообще не принципиально.
>Люди которые это могут сделать
Это бесконечное множество на самом деле - каждый может скачать дампер с гитхаба и распаковать. В том числе по моей ссылке. Хотя это далеко не единственный дампер. А хонкай я привел в пример потому, что там использовано дополнительное шифрование в плюс ко сборке в cpp. То есть задача была усложнена в несколько раз и всем похуй. Вскрыли не особо популярную игру просто потому что могут.
Если бы я сомневался в своих словах, я бы сказал так - давай я запакую свою игру, пришлю, и если у тебя получится хоть что-то разобрать в коде пришлю 5к.
Но я уверен что ниодин сидящий на этой доске пчелик не сможет вскрыть ill2cpp.
Те кто смогут скорее всего будут брать в долларах и с несколькими нулями. Делай выводы.
>>26351
То что я попускаю фантазёров нагугливших ссылки не способных даже прочитать что они делают? У меня в отличии от них был опыт, и скажу что это пиздец дрочь, и не на готовых решениях.
Матерь божья....
Ты только анус себе можешь вскрыть пёс. Если не жалко времени сделай проект, создай один скрипт, напиши пару функций, и запакуй в ill2cpp. Потрать пару дней ебли и пойми что ты тупое чмо, но никто же не узнает что именно ты тот пиздабол, и как не в чём не бывало вернись на сосачик чатиться дальше.
>Но я уверен
Так а я уверен в том, что ты долбоёб. И выше там был скриншот с распаковкой моего проекта, собранного в il2cpp. То есть ты долбоёб слепошарый, что даже хуже. И что дальше? Опять же, повторюсь, любой может проверить, что имена функций сохраняются юнити в первозданном виде. Дебаг сборка в il2cpp, потом запускаем профайлер и смотрим. Я даже могу повториться и написать, в каком именно дат файле все имена зашиты, но чего ради, если ты слепошарый и не сможешь прочесть?
я сам с этого орал.
НУ И В ЧЁМ ОН НЕ ПРАВ НАХУЙ?
меня только бесит хуйня с 0 ? 1 : слишком непонятно для меня, никогда вообще не понимал и не мог запомнить, как это работает
>0 ? 1 : слишком непонятно для меня, никогда вообще не понимал и не мог запомнить, как это работает
Слева от знака вопроса результат от сравнения, true или false, слева от двоеточия это то что присвоится если результат == true, справа если false. x = true ? 1 : 2; -- в результате x будет равен 1.
вот это я наверное даже переделаю. хардкод все равно будет дальше, но если я захочу чтобы игрок создавал не одного персонажа, а всю группу сразу, его количество не увеличится пропорционально количеству персонажей.
> Managers.PlayerGroup.playerGroup[0]
Немного сбивает с толку. Может лучше как-то так:
Game.PlayerGroupManager.GetCharacterAt(0)
Просто прямое обращение к массиву супер не интуитивное. И вот это повторение "PlayerGroup.playerGroup".
мм.
>PlayerGroupManager.GetCharacterAt(0)
возможно.
> PlayerGroup.playerGroup
согласен, самому давно режет глаз.
>>26391
чмохен, заебал визжать, серьезно. Я просто не понимаю, ради чего ты это делаешь? точнее я понимаю, что ты несчастен, но типо от того, что ты пытаешься обосрать мой код, который я сам же по рофлу выкладываю, твоя жизнь лучше не станет. Перестань быть дваче чмохой, стремись к лучшему лол. Иди прочитай про как эвенты и делегаты работают, с которыми ты уже не первый раз обкакиваешься, оно же всяко полезнее будет..
Двачую этого. Всегда пригрываю с этих понтарезв которые пользуются энтернал проверкой. Типо если ты можешь проверку записать в одну строку ты неибаться крут.
очевидно нужно сохранять в отдельные файлы на диске а не срать в реестр
>все через ПлауерПрефс
А через файлы не хочешь? Обычно в играх через файлы всё делают и хранят в 'Мои документы'.
В любом случае, тебе понадобится JSON:
https://docs.unity3d.com/ru/530/Manual/JSONSerialization.html
Раз ты хочешь через PlayerPrefs, то делаем следующим образом:
1) Сохраняем все сохранения по именам
PlayerPrefs.SetString("save_list", string.Join("\n", saveList));
2) Далее сохраняем сохранение
PlayerPrefs.SetString(saveName, JsonUtility.ToJson(saveData));
Как загружать думаю сам разберёшься. string.Split + JsonUtility.FromJson<SaveData>(...);
Далее можешь их отсортировать по дате сохранения. Дата должна храниться в классе SaveData.
Он тут пишет о том, что путается в том, как работает тернарный оператор, длина строки тут не при чем.
Ты скозал? Вот только в жизни такая концепция работает только у программистов, а не у юнити кодеров, пишущие скрипты.
Несколько раз пытался реализовать таким способом пули и всегда обсирался.
>GetCharacterAt(0)
У меня вообще в принципе к свойствам идет обращение просто через чистый get;. насколько я понимаю будет лучшей практикой переделать подобные вещи на функции с именами ГетПроперти?
Нет, ты меня не так понял. Тебе нужно разделять ответственность, а не просто делать обёртку над доступом к полям. У тебя в принципе не должно быть прямого доступа к внутреннему устройству класса. И работу с компонентами >>26355 желательно скрыть в отдельном классе ОptiоnButtоn как я показал здесь >>26325
Допустим, пикрелейтед код можно сделать гораздо удобнее как-то так:
оptiоnButtоn.IsМinimum = ...;
оptiоnButtоn.IsМaximum = ...;
Внутри этих свойств или методов ты уже обращаешься к чилдренам, задаёшь intеrаctаblе и тому подобное.
> оptiоnButtоn.IsМinimum = ...;
> оptiоnButtоn.IsМaximum = ...;
Можно назвать IsPlusEnabled / IsMinusEnabled, чтобы тебе ещё понятнее было. Или сделать методы SetPlusEnabled() / SetMinusEnabled(). Это уже сам смотри.
>Я просто не понимаю, ради чего ты это делаешь?
Глумлюсь над безыгорным, только и всего.
>по рофлу
Да-да по рофлу, весь тред своим говном засрал по рофлу, с актуальной инфой что и когда ты собираешься переделать.
>Иди прочитай про как эвенты и делегаты работают
Лучше ты расскажи своими словами хочется еще посмеяться
Не-не я примерно понимаю, как работает ПлауерПрефс и Джейсон, вообще сначала хотел сделать сохранение бинарным способом, как диды на чистом шарпе. Но не суть. Мне именно не понятно, как по средством юнити сделать строку которую я создаю на экране загружая её из сохранений кликабельной. Мне нужно с новой строкой создавать компонент кнопки или как то прикреплять эвенты к строке и считывать их райкастом при наведении курсора мыши на строку?
Ну, анон, это совсем базовые вещи. Посмотри на ютубе туториалы, как создавать интерфейс. У тебя должен быть создан интерфейс со списком. Далее ты создаёшь префаб(либо Template), который будет представлять элемент списка. И под каждое загруженное сохранение ты создаёшь новый объект, который копирует префаб.
Два чая.
У меня до переделки классов с разделением ответственности руки не дошли еще вообще, а начал вообще буквально с самого начала. Типо я не понимаю нахуя мне Value {get:private set} с которым получается я одно получаю с гетом, а для второго юзаю публичный метод, если, например, я могу сделать просто приватный филд и два метода к нему.
Cовсем не трушный путь, с префабами-то.
Есть арена с триггер коллайдером, который опускает двое ворот и ждет смерти босса, чтобы поднять их.
Я добавил аниматор и анимации на один префаб, но второй префаб с тем же аниматором и анимацией не хочет работать, само собой. Анимирован ведь первый префаб, а не второй.
Мне реально нужно дублировать анимации и в скрипте обращаться сразу к двум одинаковым объектам или есть проще способ? Я думаю, что я просто нахуивертил всякого и сам себя запутал, а решение элементарное. Но не для меня.
Код на пиках. Первый скрипт отвечает за триггер, второй за анимацию ворот.
Нормально у тебя анимации проигрываются 30 раз в секунду. Не надо такие вещи пихать в апдейты. По поводу аниматора - понятно что аниматор одинаковый, но экземпляры этого аниматора это разные объекты, так что надо на каждом запускать анимацию по отдельности. Можно это делать из одного места через какой-нибудь менеджер дверей.
Ну вообще такие вещи через эвенты делаются, но ты пока хотя бы булевый флаг сделай что анимация стартовала. Типа if(bossIsDead && !gateOpenAnimationStarted), void GateOpen() { gateOpenAnimationStarted = true; бла-бла }
А зачем мне gateOpenAnimationStarted, если я запускаю анимацию сразу после смерти босса? Пока босс не мертв только единожды проигрывается закрытие ворот
Так у меня в игре один раз проигрываются анимации закрытия и открытия. Если дело конкретно в фиксе, который внутри себя 30 раз за секунду нагружает память для одной анимации, то дело другое. Ты gateOpenAnimationStarted придумал для этого или зачем?
братик, сделай ивентом, а то кровь из глаз. Все проще чем кажется, какой либо контроллер локации где будет ивент Action<BossPrototype> OnBossDead, будешь сразу отписываться и запускать анимацию.
другой анон
1920x1120, 0:29
Завистливая чмоня
Блин, братан, ты так парился чтобы сделать плейсхолдерное меню, да еще и сделал через жопу. Освой уже MVP и не еби себе мозг.
>UI
Интересный подход, я вначале zenject, addressable, UniTask ставил и писал контроллер по загрузке ресурсов xD
сорян не удержался
Москва не сразу строилась, братишка.
Понаставил новомодных костылей и рад.
Недавно программируешь на юнити похоже
Класс Gate лучше назвать как-то вроде GateTrigger, чтобы понятно было, что он делает. Проверка на плеера не нужна, вместо этого можно и нужно добавить значение поля "player" в инспекторе (А ещё по-хорошему ещё заменить "public" на "[serializefield] private", но это так, на будущее) и уже это значение сравнивать с коллайдером, попавшим в триггер. Дальше вместо онТриггерСтей делаешь метод OnTriggerEnter и в нём проверяешь, является ли коллайдер коллайдером плеера. Дальше прямо от туда вызываешь метод open в классе "опен-клоз-скрипт", который как раз должен называться Gate. Можешь либо через список/массив добавить несколько ворот, либо через менеджер. А потом методы закрывающие ворота вызывает сам бот после смерти.
https://dtf.ru/gameindustry/1304199-korporaciya-applovin-predlozhila-kupit-unity-za-17-5-milliarda-dollarov-pri-uslovii-razryva-sdelki-s-ironsource
В чем он не прав?
Аноны, кто уже пощупал? как вам?
лучше бы микрософты купили
Кажется несколько лет назад очень много было упоминаний одного плагина.
Его суть в том, что он облегчал для нубов разработку и сводил всю логику в перемещение блоков .
Могу что то напутать, но суть была в том, что он делал жизнь легче новичкам.
Напомните название?
Если он действительно об этом, то не понимаю как это упрощает жизнь. Я свободно ебашу скрипты, но в этом дерьме потратил немало времени, чтобы набросать даже самый простой говнокод. Оптимизированный код без костылей через этот калл написать невозможно, как я понял. Боюсь представить, что оно генерирует, если попробовать сделать хотя бы что-то сложнее циклов и массивов.
>можно спокойно вкатываться?
Это бесполезное говно, ты на его изучение только время потеряешь. Существует только для того чтоб привлекать ньюфагов картиночками с лапшой, других задач у этого плагина нет.
Assets\Scripts\EventSys.cs(10,9): error CS0246: The type or namespace name 'Action' could not be found (are you missing a using directive or an assembly reference?)
Не понял, как ты обращаешь из разных подпространств к функции? Ты уверен что именно так и было в видео?
Да вроде бы я так же пишу, как он. Первый скрин видоса, второй мой.
>Action a = WritteHello();
Без скобочек надо, Action a = WritteHello;
Экшоны конечно не так юзаются. Делаешь эвент
public event Action OnMaximumZalupa;
в нужном месте инвокаешь его ... if(zalupaCount > 999) OnMaximumZalupa?.Invoke();
и эвент обработают те кто на него подписался ZalupaCheker.OnMaximumZalupa += () => zalupaUIText.text = "maximum zalupa".
>Без скобочек надо, Action a = WritteHello;
Да, это я поправил, но все равно не работает.
>
public event Action OnMaximumZalupa;
в нужном месте инвокаешь его ... if(zalupaCount > 999) OnMaximumZalupa?.Invoke();
и эвент обработают те кто на него подписался ZalupaCheker.OnMaximumZalupa += () => zalupaUIText.text = "maximum zalupa".
Ну к этому я наверное чуть позже дойду, пока мне это мало что объясняет. Пока что тупняк на расхождении с видосом.
На что накинуть скрипт, если он не работает? У меня игра даже не запустится, пока ошибку не уберу.
>The type or namespace name 'Action' could not be found (are you missing a using directive or an assembly reference?)
пчёл...
using System;
Он реально целый час не мог это исправить. Зря ты ему написал. Дебил даже не может построчно проверить 8 строчек кода. Не говоря уже про гугл ошибки.
Бля, помогло. Я думал я и так в системе, раз у меня System.Collections;
System.Collections.Generic;
Спасибо
Но я не кодер, а моделлер и мне гораздо лучше будет привыкнуть к этим нодам
Жаль я не такой умный как ты, мне вот приходится с тобой еще общаться
Там ровно тот же код, но квадратиками с текстом. Ничего не упрощено, нужно знать все нюансы программирования. Только вместо того, чтобы писать весь код, ты пишешь начало названия метода или объекта и выбираешь его мышкой. Базовое программирование в юнити проще простого, любой разберется.
Так ему на что то кушать нужно будет, а у меня нет возможности оплачивать фул тайм разработку.
>а можно я просто подгружу все свои модельки
Это и так делается мышкой
>персонаж просто сможет передвигаться
Три строчки
>вызывать квестовые окна при взаимодействии с нпс
Лол. Ты думаешь лапшину протянуть и окна с квестами магическим образом возникнут из ниоткуда? Это писать надо, готового ничего нет.
>Неужели отображение xml в окошке - требует много знаний и сил?
Отображение xml в окошке не требует много знаний. Реализация задачи "вызывать квестовые окна при взаимодействии с нпс" - требует. Нормально ты квестовую систему свёл к показу хмл в окне, удачи в разработке хуле.
>найди себе прогера
А может, мне ещё и тян найти, а? Если бы это было так просто, я бы тут с вами не сидел.
Ну я знаю С# и Unity.
Еще небольшие требования:
- желательно глубокое знание юнити
- не женат
-рыжий или шатен
>нужно быть онлайн с 9:00 до 21:00
Чек
>возможность сразу откликнуться
Чек
>рабочая неделя - 5 дней со вторника по субботу.
Чек
>желательно глубокое знание юнити
Знаю на 5+!
>не женат
Ес!
>рыжий или шатен
Чек
Куда писать?
Ладно, если серьезно я подготовлю презентацию своего проекта, и опубликую здесь или еще в паре тредов с контактами, может когда визуально все будет видно, найдется человек с 5-6 лишними часами в неделю
https://www.youtube.com/watch?v=vmAiOSH8zCE
на пальцах, есть объект в котором что то происходит, что то изменилось и ты должен из других объектов в момент узнать так ли это + может ещё дополнительную инфу получить. Ты можешь из этих объектов опрашивать постоянно тот объект и это будет дорого неправильно. Надо использовать ивенты, создаешь ивент в этом объекте где у тебя что то происходит, вызываешь этот ивент внутри его, а остальные сущности просто подписываются на этот ивент и получают тригер и инфу в момент срабатывания ивента
public class InventoryController
{
public static event Action<int> OnMoneyAdded;
public bool TryAddMoney(int amount)
{
if(amount <= 0)
return false
var currentMoney = PlayerPrefs.GetInt("playerMoney", 0);
PlayerPrefs.SetInt("playerMoney", current + amount)
OnMoneyAdd?.Invoke(current + amount) //вызываешь
return true;
}
}
public class UIBag
{
public TMP_Text moneyAmount;
void OnEnable()
{
InventoryController.OnMoneyAdded += UpdateMoneyView //подписка
}
void OnDisable()
{
InventoryController.OnMoneyAdded -= UpdateMoneyView //отписка
}
private void UpdateMoneyView(int amount)
{
moneyAmount.text = amount.ToString()
}
Здесь дженерик <int> это тип доп инфа которую хочешь получить.
}
https://www.youtube.com/watch?v=vmAiOSH8zCE
на пальцах, есть объект в котором что то происходит, что то изменилось и ты должен из других объектов в момент узнать так ли это + может ещё дополнительную инфу получить. Ты можешь из этих объектов опрашивать постоянно тот объект и это будет дорого неправильно. Надо использовать ивенты, создаешь ивент в этом объекте где у тебя что то происходит, вызываешь этот ивент внутри его, а остальные сущности просто подписываются на этот ивент и получают тригер и инфу в момент срабатывания ивента
public class InventoryController
{
public static event Action<int> OnMoneyAdded;
public bool TryAddMoney(int amount)
{
if(amount <= 0)
return false
var currentMoney = PlayerPrefs.GetInt("playerMoney", 0);
PlayerPrefs.SetInt("playerMoney", current + amount)
OnMoneyAdd?.Invoke(current + amount) //вызываешь
return true;
}
}
public class UIBag
{
public TMP_Text moneyAmount;
void OnEnable()
{
InventoryController.OnMoneyAdded += UpdateMoneyView //подписка
}
void OnDisable()
{
InventoryController.OnMoneyAdded -= UpdateMoneyView //отписка
}
private void UpdateMoneyView(int amount)
{
moneyAmount.text = amount.ToString()
}
Здесь дженерик <int> это тип доп инфа которую хочешь получить.
}
И вновь еблан тешит своё чсв, тратит силы и время вместо того чтобы просто ответить на вопрос.
Вывод: ты не выше джуниора
Еще небольшие требования:
- желательно глубокое знание мужской анатомии
- не замужем
-рыжая или шатенка
Я попробую во всем этом разобраться, спасибо
Не переживай, всё будет отлично! Будем под поединком обсуждать свежие версии Юнити.
Жду
Под пледиком, не поединком! Это автоисправление. Нам не придется драться, не бойся! Ты из какого города?
Нинка сильно возбудится если разместить это потом на itch?
>Как вам идея портировать на юнити старые гба игры про Покемонов, но в 3д ?
Хорошая идея. Начинай делать.
>Нинка сильно возбудится если разместить это потом на itch?
Тебя моментально выебут.
Идея интересная, но насколько это сложно?
Я вот подобную идею вынашивал после прохождения хреногеарс, даже карты в 3д скачал с текстурами готовые, покрутил в 3дмаксе, сделал вывод, что даже просто перекатить гемор, нужна команда
>>26865
Но фактически меня просто забанят как и мою поделку, так ведь?
>>26866
Если брать конкретно игры этой франшизы - то там самое сложное это запилить боевку и характеристики. Перенести самих покемонов (даже если пилить их с нуля) конечно займет время, но с этим справится даже школьник.
На пикриле образец 2019 года.
>Но фактически меня просто забанят как и мою поделку, так ведь?
Просто проебешь год на разработку игры, и тебя просто забанят. Так как ты и не собираешься ничего пилить то всё выходит еще проще.
Саму сюжетку конечно пилить лень. А вот сама основа - то есть выбор команды и баттлер, это уже интереснее. А если прикрутить сетевую то будет еще интереснее.
Породили целое поколение наглухо ебанутых "ретрогеймеров".
Все так, и что? Ты же зачем-то пришел в медленный тред двача вместо того, чтобы написать в тг по юнити, где отвечают мгновенно на такие днищенские вопросы и не только.
Ну ладно, шутки в сторону. Тут советуют MVP и разделение обянностей. Краем глаз глянул солид и мвп и понял так. Чтобы заебурить интерфейс создания персонажа мне нужно накодить класс, в котором будут храниться только данные, которые в последствии пойдут в конструктор создания персонажа. Создать класс, отвечающий за уи. и создать класс посредник, который перекрестит эвенты двух предыдущих. Все по феншую?
У виабушников там какую то игру пилят на донаты. так там вся логика через if else
Найди старую версию игры и открой любым декомпилятором сишарпа. Например - dotPeek. Код игры не обфусцирован и легко открывается.
Сорри, в вотсапе вряд ли есть такой канал. Только компьютером научился пользоваться? Тоже чересчур сложная технология для тебя? Говорю же, съебись, ну не твое это абсолютно. Ладно бы тебе было 12 лет, но ты пердишь так, словно тебе 50+.
Вообщем должен быть позлунок от 0 до 1, который регулирует длину лайн рендера.
То есть если ползунок на 0.5, то отображается только половина лайн рендера.
Пришел к тому, что нужен фрагментированный шейдер, и если 'какое-то условие', то col.a = 0, иначе 1, только не могу подобрать условие само, от чего можно оттолкнуться?
LayerMask ground = LayerMask.NameToLayer("Ground");
и передаю переменную в рейкаст, то нихуя не работает. Через сериалайзфилд выставления ручками переменной все ок.
Может ты название леера неправильно написал. У меня всё связанное с этой функцией работает.
10 раз перепроверил, вплоть до копипаста.. Пробовал передавать через int переменную еще, тоже нихуа.
У тебя какая версия юнити? Есть подозрение, что они чета сломали, потому что этот код выдает такое
GetMask работает, до этого правда не работал. видимо я что-то недопонимаю.
На первом скрине срипт для триггера, который детектит тэг игрока и от него отталкивается. Мне советовали не делать проверку на плеера, но я не понял почему и как иначе. У меня в зоне триггера коллайдеры босса, которые его постоянно теребят и закрывают двери арены. А мне надо, чтобы двери были открыты, пока я туда не зашел и закрыты, когда босс мертв. С триггером все работает. Раньше я делал так, чтобы триггер детектил толко коллайдер со скриптом игрока, но почему-то это не работало, двери не закрывались, хотя в инспекторе видно как триггер меня распознал.
На втором скрине, как я понимаю, сама эвент система, но нахуй она мне нужна я все равно не понял. Разве просто onTriggerEnter не будет щас работать без нее?
На третьем скрипт для анимации открытия-закрытия ворот. По какому принципу там что-то подписывается-отписывается, я тоже не очень понимаю, но работает. Из моего личного там по сути один метод public void onDoorwayOpen(), единственное, что я хоть как-то осознал: надо отписывать неиспользуемые состояние, подписывать новые. Ну это я вроде бы и сделал. Как советовали я сделал вызов открытия ворот внутри скрипта босса после смерти.
Собственно, это и есть эвент система или нет?
>А мне надо, чтобы двери были открыты, пока я туда не зашел и закрыты, когда босс мертв.
Надо чтобы были открыты, пока не зашел, закрыты пока идет бой, открыты, когда босс мертв*
> На втором скрине, как я понимаю, сама эвент система, но нахуй она мне нужна я все равно не понял. Разве просто onTriggerEnter не будет щас работать без нее?
Будет.
Подобная ивент система нужна, чтобы кто угодно мог подписаться на события, т.е. чтобы проще было связывать разные объекты.
Например пусть у тебя есть система стелса и враги должны на звуки прибегать. Как это сделать? Да просто инвокнуть эвент OnLoudSound(position), а враги его обработают.
В твоём примере она нахуй не нужна.
> На третьем скрипт для анимации открытия-закрытия ворот.
Неправильно, не надо так делать, к тому
Сделай bool переменную, которая эранит текущее состояние двери.
Делай только 1 подписку и й отписку ра ивент. Ну и повторюсь - конкретно в этом примере оно нах не нужно.
pun 2
Ну, тем что происходит ебанизм с переподпиской на ивенты, который кстати вроде как не работает, хз че там в аниматоре самом.
Да просто две анимации без транзишена, запускаются только со скрипта
Система уже второй десяток без нареканий работает под любую задачу
Не могу зайти в юнити, нажимаю sign in и открывается белая страница в браузере (акк я сделал).
КАК НАЧАТЬ ИГРАТЬ ДЕЛАТЬ ТО
У меня есть знакомый Игорь
хуя у тебя вопросы
в омске
по пику, ебурил в юнити норм все было, захотел ассетов поставить, некоторые с ошибкой не ставились. посоветовали проверить лицензию, не обновлялась. ща переустанавливаю, вроде обновилась, позже ассеты проверю
Ну я думал ты русский миллиардер в Англии и тебя решили задавить. Я бы в таких случаях только в сапорт юнити писал, лицензия-то их, они могут знать че делать. Но раз переустановка помогла
Просто отменяешь и заного регаешь бесплатную лицензию в чём трабла? Делов на 1 мин.
да после переустановки все заработало
просто когда каждый день заходишь в редактор и все норм, а на след день нихуя не работает немного странно
>Мне советовали не делать проверку на плеера, но я не понял почему и как иначе
Так ты её убрал. У тебя плеер сравнивался с null, хотя его можно было указать в инспекторе
>На втором скрине, как я понимаю, сама эвент система, но нахуй она мне нужна я все равно не понял
Она пригодится, если у тебя будет очень много дверей, которые все реагируют на одно событие.
>По какому принципу там что-то подписывается-отписывается, я тоже не очень понимаю, но работает
Молодец, это главное. Хотя у тебя подписки не в том месте Заебашил прикл через пеинт, потому что так быстрее, лол, но ты можешь вообще избавиться от эвентов, если хочешь. Хотя всё итак работать будет
так если ошибаюсь для этого нужно прописывать нужно каждый вектор, а нет что-ли метода для отрисовки коллайдера в одну строчку? Если нет, очень странное от решение юнити не добавлять такую возможность.
Чел, ну ты хотя бы просто в редакторе кода Gizmos. напиши, там тебе сразу DrawMesh вылезет
спасибо, мне тоже помогло
Как сделать чтобы транспарент материал отбрасывал тень? Типа, есть тонированное стекло, от него должна быть полупрозрачная тень
PostProcessing -> EdgeDetection
Поставить шейдор на материал.
вот что у меня сейчас на пикрелейтед, все работает, этих NodeElement создается адова толпа, каждый отмечается при старте и обрабатывается
Если это теоретический пример, то пойдет, подписался/отписался и все при старте/уничтожении. Надеюсь у тебя там будут важные события.
Могу предположить что события плохи если ты их подписываешь в процессе чего-то (и отписывать так же), можно самому себе в ногу стрельнуть.
Другая проблема всякие проверки "а подписан ли я".
Персонально я случайный хуй с горы предпочитаю использовать статичный лист с интерфейсами и дергать методы интерфейсов (возможно из-за интерпрайза стал так делать). Брат жив.
это реальный пример, суть задумки такова:
NodeElementManager создается в самом начале игры и работает до конца, т.е. Awake происходит в самом начале игры, OnDestroy - надеюсь в самом конце, менеджер единственный подписчик эвента, а сколько в процессе будет создано(префабы с этим моноб) NodeElement я заранее знать не могу, мне надо только передать ссылку когда префаб с ними готов перед первым Update(поэтому решил через Start эвент инвокать)
вроде работает, меня беспокоят истории про утечку памяти
но если у меня менеджер-подписчик сидит всю игру, наверное и норм?
К сожалению, в ЮРПе, если материал транспарент, то даже если он полностью непрозрачный, он не отбрасывает тень
>NodeElementManager создается в самом начале игры и работает до конца, т.е. Awake происходит в самом начале игры, OnDestroy - надеюсь в самом конце, менеджер единственный подписчик эвента
По-моему ты пытаешься придумать велосипед - синглтон
>менеджер единственный подписчик эвента, а сколько в процессе будет создано(префабы с этим моноб) NodeElement я заранее знать не могу, мне надо только передать ссылку когда префаб с ними готов перед первым Update(поэтому решил через Start эвент инвокать)
По описанию неправильное распределение обязанностей, менеджер элементов не менеджерит элементы. Если правильно понимаю цель этого всего, то знать обо всем должен менеджер, а элемент как раз ничего не знать.
У меня такая хуйня при каждом запуске юнити. Без впн нельзя открыть ни один проект. Зато можно с отключенным интернетом.
На какую платформу скомпилировал?
Что значит "почти пустую" игру? Показывай, что у тебя там. Может ты нахуярил текстур по 50 мегабайт.
я наверное очень сумбурно объясняю.
у меня есть три класса:
1 - фабрика, отвечает за создание инстансов из префабов
2 - менеджер элементов
3 - сам элемент
я не хочу чтобы фабрика что-то знала об элементах или их менеджере, поэтому решил добавить эвент в сам элемент, который будет инвокаться только если этот элемент окажется в сцене. так что вот что сейчас происходит:
1. фабрика создает новый объект из префаба
2. на нем оказывается элемент - фабрика ничего об этом не знает, просто создан новый объект
3. элемент орет о себе в пустоту
4. менеджер узнает что есть элемент
5. профит?
я вот и хотел узнать, как бы лучше это можно было сделать, без статического эвента в элементе. спасибо что еще не послал меня нахуй с такими тупыми вопросами
тот же хуй с горы
проблемы с утечками появятся из-за динамического подписания/отписаться т.к. ты забудешь в 1м месте отписаться и ВСЕ.
Еще, если я правильно понял, в твоем примере если ты создашь ноду динамически, метод start в ней не будет вызван т.к. его дергает менеджер, ты так и задумал? Или у тебя ноды заранее расставлены в сцене как статика?
Ну и еще раз повторюсь, с листом ты можешь обновлять его, узнать кто в нем есть и тд, а с евентом без костылей ты не можешь ни че го.
Вот еще поделюсь, я сделал себе некую обертку для листа и статики и все мои слабосвязанные евенты выглядят как код на пике (может вдохновить на что-то, а может и нет)
>я не хочу чтобы фабрика что-то знала об элементах или их менеджере
Правильно, менеджер говорит фабрике сделай мне элемент и отдай, если у тебя там префабы которые могут грузиться то возвращать нужно будет корутину с коллбеком или таску чтобы подождать. Мне нравиться реализация связка фабрика-пул, нет в пуле доступных фабрика досоздала, если есть сразу пул отдал.
context.control.ToString();
Да, уже нашел, чувствую себя крайне тупым. Все равно спасибо, анон
settings - project settings - time - вместо 1.00 ставишь 0.10 или сколько тебе там нужно
Если у тебя логика игры завязана на Time.deltaTime, то можно попробовать замедлить игру с помощью изменения Time.timeScale.
На камере постобработку включил?
Нормально безыгорного хохла-лапшетаскателя обоссали.
Если удобно юзай скриптаблы. Лично я использую пару скриптов подтипов предмета, это дело храню в байто сэйве одной стринг строчкой. Из-за того что не люблю когда у и игрока есть возможность блокнотом открыть и всё почитать.
Я еще с ходу бахнул 3 интерфейса типа консумабл, эквипабл, коллектбл. И пошел делать инхеритансы типа итем-армор-хелмет. Потом планировал соответственно слоты в инвентаре делать типа public Helmet helmet. Такая тема рабочая?
>в формате жсон
yaml
Нашел тебе в гугле полезную тему плюсов и минусов:
https://forum.unity.com/threads/why-are-scriptableobjects-worth-it-surely-plain-text-is-better.216881/
PS собираешься юзать so, пользуй тогда райдер чтобы видеть измененные поля сразу в нем, а не постоянно в юнити переключаться искать сам ассет. Или визуал уже умеет так же, не ебу.
спс
Главный критерий чтобы тебе было удобно и понятно с этим работать.
Имею домашний пет проджект в виде 2Д игоря и работаю в мелкой фирме что заказы на Юнити берет небольшие пока что. Начальник говорил скоро могут пойти заказы на виар, может там это смысл иметь будет?
Разве что для разворачивания нейронок для генерации текстур у себя на машине. Но проще оплачивать подписки на такие генераторы.
Между прочим сейчас так и делаю, есть доступ в закрытую и платную бетку Dall e 2. Но думал уже о поднятии собственных сеточек.
Вот только у 4090 и 3090 ti одни и те же 24ГБ памяти будут, разве что шустрее ебошить будет. Будет еще по идее 4090 ti на 48ГБ, но она вышибет нахуй пробки в квартире, ну нахуй. Да и то это инфа по сливам.
>Начальник говорил скоро могут пойти заказы на виар
Ты уверен что заказы будут именно под компьютерный виар? Я чет сильно в этом сомневаюсь.
Можно сделать, чтобы ассеты заранее загрузились? У меня много сцен, надо между ними перемещаться, и во всех одни и те же ассеты
Ну это конечно вариант, но хочется именно что заранее загрузить все ресурсы
Если это не под мобилу то смело дели всё на 2.
>квадраты сейчас 100 на 100
Чего "100 на 100"? Пикселей? Кто в наше время считает размеры интерфейсов в пикселях? Нужно считать в процентах, адаптивность же. Или ты будешь делать отдельный интерфейс под каждое разрешение экрана?
мимо проходил
Я делаю в пикселях. Беру разрешение 1920х1080 и под него всё делаю. У тех кого другое пусть страдают от кривого юи.
пздц, интерфейс уровня б
чтобы олдскулы сводило.
Ну юнити же растягивает там оттягивает че надо. 100 на 100 просто потому что клеточка канваса 100 на 100. Вообще это просто грубый набросок. У меня даже системы инвентаря еще, типо достаточно сложно для меня сходу разработать систему предметов, инвентаря и уи под все это. С учетом того, что инвентарь будет учитывать размер предметов.
Дальше сделать класс, в котором будет двумерный массив булиан значений, который будет представлять как бы реализацию пространственного размещения предметов.. И сделать промежуточный третий класс, который будет запоминать в какую конкретную ячейку положен предмет и от этой ячейки уже заполнять второй класс трушками или фолсами. Вин или шин?
У тебя есть объекты Физические Объекты предметы, у каждого объекта класс Предмета.
Инвентарь это пустышка гейм обджект менеджер в котором есть собственный список. При взаимодействие ты передаешь свой список предметов, которые допустим берутся из инвентаря(Еще одного списка) в него, или из инвентаря торговца.
Далее проходишься по списку и показываешь на юи иконки из этого списка.
Всегда считал такие ограниченные инвентари хуитой и издевательством... Какой еще нах реализм? А что тогда герои не срут? Нереалестично - срочно делайте сранье и туалеты
То есть я понимаю ограничения ячеек в фритуплей - ну купи еще ячеек в инвентарь, ну купи... Ладно, там что-нибудь про реальный мир... Но это все херня
Но в фентези...
Ты такой напал на замок злого колдуна, и перед главной комнатой - "падажи, у меня сумка полная, щас сбегаю в ближайший город, продам, не уходи никуда"... Вот так это блядь должно выглядить?
И почему-то только китайцы придумали решение. Хотя в DnD оно было, но никто его не взял
А именно - пространственные кольца. То есть кольца с пространством в которое можно скидывать любой мусор. Можно ограничить количеством, если это зачем-то надо для механик - только нормально, а не два меча положил и уже полный.
>Вот так это блядь должно выглядить?
Ты видимо из тех, кто в елдер скролсах все вилки подбирает и тарелки.
Делал своим велосипедом так - У предметов есть общий класс Item (В котором содержатся общий данные для всех предметов по типу уникального id или string).
И у каждого такого предмета в зависимости от типа или чего там надо уже висит скрипт по типу Weapon, Armor и т.п.
В менеджере ты берёшь предмет, смотришь его основное свойство в Item и далее уже решаешь откуда у него брать данные или как взаимодействовать.
При желании можно повесить также реваерэлемент.
тут все просто у тебя например простая иерархия:
Weapon<=Item
Armor<=Item
switch (Item)
{
case Weapon weapon:
Debug.Log($"This is {weapon.ToString()}")
break;
case Armor armor:
Debug.Log($"This is {armor.ToString()}")
break;
default:
throw new UnknownItemException();
break;
}
Но лучше посмотри несколько подходов по инвентарю на ютюбе, задача распространенная. Я смотрел пару роликов этого чувака, у него нет сильных косяков по логике и коду, так что у него можно глянуть(сам не смотрел кокретно этот видос)
https://www.youtube.com/watch?v=TGsyO3SmF-0
Item item;
if (item is Weapon)
{
Weapon weapon = (Weapon)item;
}
Я делаю такой костыль, какие подводные?
Ну как же, ты можешь получить уникальный айдишник в удобной форме, который будет глобальным, уникальным с подстветкой и подсказками ide. Работать удобно, ошибок допустить сложнее чем с string, пользовать ты его можешь как хочешь = получать коллекцию всех существующий значений, получать int и string значения, обобщать тип через T в абстракциях, даже cериализовать в инспектор. enjoy
Причем оператор is позволяет автоматически преобразовать значение к типу, если это значение представляет данный тип.
Советую: metanit.com/sharp/tutorial/3.11.php
Возможно я тормоз. Но на примере можешь показать как он реализуется и используется?
Вот у меня у каждого предмета есть id, либо string.
Я во всей своей логике использую их просто оперируя как с числом или строкой, передаю туда сюда, тягаю.
Объявляется у меня этот индификатор простым полем в инспекторе, туда пишется число или набор букв на английском. Сменить секундное дело.
Ну типа енам по сути целочисленная константа.
типа public enum example { govno} можно обрабатавать как через example.govno,string govno, 0. При этом
public class Example<T> where t: Enum как генерик
а через Enum.GetNames(typeof(T)), можно получить все имена в формате массива
Делать только для одного разрешения
>Беру разрешение 1920х1080 и под него всё делаю. У тех кого другое пусть страдают от кривого юи.
У меня разрешение 1440x900 и мне пока хватает, это больше HD и почти дотягивает до FullHD. А страдать я не буду, я просто удалю твою игру и напишу негативный отзыв, чтоб другие знали и не покупали твою игру.
Кроме меня в этом разделе ещё кто-то с таким же разрешением, а у кого-то вроде даже меньше.
>>28145
>тебе в годотю с таким подходом
Лол, там UI из коробки адаптивный - подстраивается под любое разрешение, если правильно расставить якори. Нет необходимости считать в пикселях, главное правильно настроить для сжатия и растягивания. В Unity такое возможно из коробки или нужно что-то качать?
>>28178
>Вообще это просто грубый набросок.
Ясно. Не забудь сделать отступ от краёв экрана. Даже если не планируешь на мобилки (которые сейчас все изуродованы круглыми углами и дырками), прижимать ячейки инвентаря вплотную к краю экрана не стоит, т.к. игроку придётся махать мышкой по всему экрану. Посмотри другие игры, там инвентарь обычно либо в центре экрана, либо в плавающем окне, но всегда есть отступы. Лучше уменьшить размер ячеек или даже сделать вертикальный скролл, либо разбить на несколько вкладок, но чтобы инвентарь не занимал весь экран. Также маленький инвентарь будет выгоден, если игра не ставится на паузу при его открытии - игрок будет видеть, что происходит вокруг, и успеет среагировать в случае чего.
>С учетом того, что инвентарь будет учитывать размер предметов.
Опять эта хрень, что в ней хорошего? Я редко такое встречаю в играх, но каждый раз бесит крутить-вертеть каждый предмет, чтобы освободить место под ещё что-то, чтобы не оставалось лишних дырок, в которые ничего не воткнёшь. Имхо, простой механики максимального веса более, чем достаточно, всё равно инвентарь в играх - игровая условность, и игрок будет носить в нём всякую хрень, которая ИРЛ порвала бы рюкзак (боевой топор, три штуки) или высыпалась из карманов (порох 1000 единиц, без мешка). Ограничения инвентаря на размер и форму предметов не играют на погружение в игровой мир, а только добавляют сложности при обращении с GUI игры, который, прошу заметить, в любом исполнении ломает погружение. Если хочешь высокое погружение, избавляйся от инвентаря и делай что-то вроде контекстных кнопок, чтобы персонаж сам доставал нужный предмет или ресурс, не заставляя игрока искать этот предмет в сетке предметов. Или делай 3D инвентарь, чтобы персонаж натурально снимал рюкзак и открывал его, показывая визуально лежащие там предметы, но это в разы сложнее и сильнее ограничивает геймплей, хотя и даёт максимальное погружение. С оружием такое сделать проще: если, скажем, нужно апгрейдить пушку, лучше будет чтобы персонаж приблизил пушку к камере и игрок мог кликать непосредственно на модули этой 3D пушки, а не просто отобразить меню с пушкой и кнопками модулей вокруг неё. Если же тебя не волнует погружение, забей на всё это и делай простейший инвентарь.
>Беру разрешение 1920х1080 и под него всё делаю. У тех кого другое пусть страдают от кривого юи.
У меня разрешение 1440x900 и мне пока хватает, это больше HD и почти дотягивает до FullHD. А страдать я не буду, я просто удалю твою игру и напишу негативный отзыв, чтоб другие знали и не покупали твою игру.
Кроме меня в этом разделе ещё кто-то с таким же разрешением, а у кого-то вроде даже меньше.
>>28145
>тебе в годотю с таким подходом
Лол, там UI из коробки адаптивный - подстраивается под любое разрешение, если правильно расставить якори. Нет необходимости считать в пикселях, главное правильно настроить для сжатия и растягивания. В Unity такое возможно из коробки или нужно что-то качать?
>>28178
>Вообще это просто грубый набросок.
Ясно. Не забудь сделать отступ от краёв экрана. Даже если не планируешь на мобилки (которые сейчас все изуродованы круглыми углами и дырками), прижимать ячейки инвентаря вплотную к краю экрана не стоит, т.к. игроку придётся махать мышкой по всему экрану. Посмотри другие игры, там инвентарь обычно либо в центре экрана, либо в плавающем окне, но всегда есть отступы. Лучше уменьшить размер ячеек или даже сделать вертикальный скролл, либо разбить на несколько вкладок, но чтобы инвентарь не занимал весь экран. Также маленький инвентарь будет выгоден, если игра не ставится на паузу при его открытии - игрок будет видеть, что происходит вокруг, и успеет среагировать в случае чего.
>С учетом того, что инвентарь будет учитывать размер предметов.
Опять эта хрень, что в ней хорошего? Я редко такое встречаю в играх, но каждый раз бесит крутить-вертеть каждый предмет, чтобы освободить место под ещё что-то, чтобы не оставалось лишних дырок, в которые ничего не воткнёшь. Имхо, простой механики максимального веса более, чем достаточно, всё равно инвентарь в играх - игровая условность, и игрок будет носить в нём всякую хрень, которая ИРЛ порвала бы рюкзак (боевой топор, три штуки) или высыпалась из карманов (порох 1000 единиц, без мешка). Ограничения инвентаря на размер и форму предметов не играют на погружение в игровой мир, а только добавляют сложности при обращении с GUI игры, который, прошу заметить, в любом исполнении ломает погружение. Если хочешь высокое погружение, избавляйся от инвентаря и делай что-то вроде контекстных кнопок, чтобы персонаж сам доставал нужный предмет или ресурс, не заставляя игрока искать этот предмет в сетке предметов. Или делай 3D инвентарь, чтобы персонаж натурально снимал рюкзак и открывал его, показывая визуально лежащие там предметы, но это в разы сложнее и сильнее ограничивает геймплей, хотя и даёт максимальное погружение. С оружием такое сделать проще: если, скажем, нужно апгрейдить пушку, лучше будет чтобы персонаж приблизил пушку к камере и игрок мог кликать непосредственно на модули этой 3D пушки, а не просто отобразить меню с пушкой и кнопками модулей вокруг неё. Если же тебя не волнует погружение, забей на всё это и делай простейший инвентарь.
>Или делай 3D инвентарь, чтобы персонаж натурально снимал рюкзак и открывал его, показывая визуально лежащие там предметы
Сразу бы рефанд сделал
>в DnD оно было
>То есть кольца с пространством в которое можно скидывать любой мусор.
О, так вот почему из днд пришёл термин "манчкин", описывающий людей, которые собирают всё подряд и гриндят циферки ради циферок. У них там инвентарь без ограничений, лол! Можно пропылесосить все локации и потом одним разом продать всё торговцу, так?
Это всё удобно, конечно. Но даже не говоря о реализме, который, конечно, не всегда уместен, возможность пропылесосить локации лишает тебя испытания, лишает необходимости думать об инвентаре. Если инвентарь ограничен, ты не будешь собирать лишнее, возьмёшь только самое нужное, а за лишним можешь вернуться потом. Если инвентарь бездонный, ты просто носишься и бездумно собираешь всё подряд, не задумываясь о том, нужно тебе что-то или нет, как пылесос. Конечно, форма предметов в инвентаре - раздражающая механика. Но ограничение по весу или по количеству всё же приносит пользу, заставляя думать и адаптироваться, а не просто пылесосить локации.
>>28181
>В кратце пока думаю сделать так.
Погугли, как делается Тетрис. Сделай что-то похожее. В тетрисе каждая фигура имеет форму и цвет, минимум одна из фигур может двигаться и вращаться игроком, пока не упадёт. Игровое поле разбито сеткой, но все фигуры чётко видно, по крайней мере пока не начнут удаляться линии. Подсмотри варианты реализации и сможешь сделать интерфейс по аналогии. Только тебе, конечно, нельзя терять ссылку на предмет и не нужно удалять линии, поэтому логика будет немного другой, но в целом система очень похожа.
Если кратко, такое можно сделать простым массивом, который будет храниться в классе инвентаря. Массив заполняется ссылками на предметы. У каждого предмета есть тип, у каждого типа есть собственный массив (в палитре предметов, из которой ты создаёшь новые предметы), описывающий форму предмета. Инвентарь при добавлении предмета ищет подходящее по форме свободное место и, если находит, заполняет ссылками в соответствии с массивом предмета. При удалении или перемещении обратная операция - ссылки в массиве обнуляются по той же форме. В общем-то простая система, сложнее продумать, какую форму должны иметь предметы, чтобы игроку было удобно (в любом случае будет неудобно 99% времени).
>в DnD оно было
>То есть кольца с пространством в которое можно скидывать любой мусор.
О, так вот почему из днд пришёл термин "манчкин", описывающий людей, которые собирают всё подряд и гриндят циферки ради циферок. У них там инвентарь без ограничений, лол! Можно пропылесосить все локации и потом одним разом продать всё торговцу, так?
Это всё удобно, конечно. Но даже не говоря о реализме, который, конечно, не всегда уместен, возможность пропылесосить локации лишает тебя испытания, лишает необходимости думать об инвентаре. Если инвентарь ограничен, ты не будешь собирать лишнее, возьмёшь только самое нужное, а за лишним можешь вернуться потом. Если инвентарь бездонный, ты просто носишься и бездумно собираешь всё подряд, не задумываясь о том, нужно тебе что-то или нет, как пылесос. Конечно, форма предметов в инвентаре - раздражающая механика. Но ограничение по весу или по количеству всё же приносит пользу, заставляя думать и адаптироваться, а не просто пылесосить локации.
>>28181
>В кратце пока думаю сделать так.
Погугли, как делается Тетрис. Сделай что-то похожее. В тетрисе каждая фигура имеет форму и цвет, минимум одна из фигур может двигаться и вращаться игроком, пока не упадёт. Игровое поле разбито сеткой, но все фигуры чётко видно, по крайней мере пока не начнут удаляться линии. Подсмотри варианты реализации и сможешь сделать интерфейс по аналогии. Только тебе, конечно, нельзя терять ссылку на предмет и не нужно удалять линии, поэтому логика будет немного другой, но в целом система очень похожа.
Если кратко, такое можно сделать простым массивом, который будет храниться в классе инвентаря. Массив заполняется ссылками на предметы. У каждого предмета есть тип, у каждого типа есть собственный массив (в палитре предметов, из которой ты создаёшь новые предметы), описывающий форму предмета. Инвентарь при добавлении предмета ищет подходящее по форме свободное место и, если находит, заполняет ссылками в соответствии с массивом предмета. При удалении или перемещении обратная операция - ссылки в массиве обнуляются по той же форме. В общем-то простая система, сложнее продумать, какую форму должны иметь предметы, чтобы игроку было удобно (в любом случае будет неудобно 99% времени).
>Ясно. Не забудь сделать отступ от краёв экрана.
Это в планах да.
>Опять эта хрень, что в ней хорошего?
Ну типа мне нравится лол. Меня тянет блевать от просто иконок. Ну типа серьезно. Вот посмотри на меч и магию, ну нашел ты такой доспех золотой, сразу большой такой видно, шишка привстает. или нвн 1. Кто бы мне конечно такие спрайты еще нарисовал лол))) Для меня лично, например, именно иконочный инвентарь был одним из разочарований в том же нвн2.
А так я согласен даже в том плане, что с точки зрения разумности надо либо в ограничение по массе идти, либо в объеме, а не сразу. Может сделаю просто иконки побольше. Что-то в стиле фолаута.
В общем и целом спасибо за фидбек так сказать.
Я
>О, так вот почему из днд пришёл термин "манчкин", описывающий людей, которые собирают всё подряд и гриндят циферки ради циферок.
насколько я понимаю, манчкины упарываются скорее в силу билда, а не количество денег. Собирать все подряд это мем скорее из моровинда.
>Погугли, как делается Тетрис.
спасибо за наводку.
>лишает тебя испытания, лишает необходимости думать об инвентаре.
Какое еще испытание?
>>28317
>Если инвентарь ограничен, ты не будешь собирать лишнее, возьмёшь только самое нужное, а за лишним можешь вернуться потом
это и есть издевательство над игроком.
Знаешь, какие из этого возникают проблемы? Игрок устает туда-сюда бегать, от данжа до торговца(кстати, это один из антипаттернов геймдизайна. Игроки ненавидят такое.)
Так вот, игрок устает, добывает более-менее оптимальное снаряжение и все. Он просто забивает на луттинг. А значит все твои охуенные секреты и загадки он тупо пробежит. То есть игра теряет половину игрового контента, игрок не хочет тратить время на исследование, потому что у него все одно забит инвентарь, и даже если он решит загадку, там будет какой-нибудь мусор который ему все равно некуда положить.
Вопрос: как фиксить? Ссылка на файл скрипта, который отвечает за это вот (Функция OnCollisionEnter2D) https://github.com/OUTS1D3R047/Pong/blob/main/Assets/Scripts/Playable%20objects/Ball.cs
Дополнительную инфу предоставлю по требованию
>Знаешь, какие из этого возникают проблемы? Игрок устает туда-сюда бегать, от данжа до торговца
если ты долбоеб, который собирает все подряд, потому что можно продать за 1 копейку, когда цены уже ушли в трех-четырехзначные числа в районе мидгейма, и не можешь адаптироваться и поменять отношение к лутингу в процессе развития игры, ну соболезную.
>Так вот, игрок устает, добывает более-менее оптимальное снаряжение и все.
проблемы твоего геймдизайна.
> и даже если он решит загадку, там будет какой-нибудь мусор который ему все равно некуда положить.
проблемы твоего мусорного геймдизайна.
>Он просто забивает на луттинг. А значит все твои охуенные секреты и загадки он тупо пробежит.
сначала сделан ничем не обоснованный вывод, а потом из него следует второй вообще без причинно-следственной связи.
Тот игрок, которого ты описываешь, это среднестатистический еблуша, который не умеет и не хочет играть в игры, а хочет чтобы игра играла в игру. И если таких долбоебов большинство, это не значит, что все должны быть долбоебами и делать игры для долбоебов.
Мимо играю почти во все на максимальной сложности.
Юнити пишет логи в файл, билд тоже пишет если ты не отрубал галочку для этой функции, она стоит по дефолту. Пути к логам тут:
https://docs.unity3d.com/Manual/LogFiles.html
Есть куб, растягиваю его по какой-нибудь оси, у него также расстягивается текстура. В настройках самой текстуры стоит repeat, tiling на метариале по 1/1. Не хочу увеличивать tiling, потому что тогда придётся создавать на каждый объект свой материал.
Что делать, котаны, есть выход?
В дьябле нет секретов и загадок. То есть там уровни из-за генерации построенны так, что игрок ничего не потеряет проигнорировав 50% карты (например это игнорят в склепах в пустыне - сразу бегут в склеп с боссом, игнорируя все остальные)
Плюс в дьябле легко вернуться на базу - цена дешевого свитка и двух кликов мыши
>И че то на лутинг никто не забивает.
Забивают, посмотри стримы (особенно когда фармят какой-то арт или руну).
>это элемент баланса
поэтому во всех модах в первую очередь увеличивают инвентарь.
А еще в ремастере увеличили кол-во ячеек (а игроки просили больше)
>и поменять отношение к лутингу
Как раз долбоеб ты - такое отношение обесценивает работу геймдизайнера, так как ты скипаешь 90% его труда
Плюс есть игры, где в предметах прописан лор игры (соулсы например, или таже might and magic откуда скрин)
Плюс есть игры, в которых есть крафт, но когда игрок решает - взять ли крутой меч, или мусор на крафт - он возьмет меч, и не будет заниматься крафтом (снова обесценивая работу геймдизайнера)
>>28386
>который не умеет и не хочет играть в игры
По твоему игра в игры - это дрочь с инвентарем, постоянный бэктреккинг, и отсутствие наград за испытание? Ну охуенно, и ты меня еще называешь долбоебом.
>>Мимо играю почти во все на максимальной сложности.
ито есть для тебя максимальная сложность - это когда надо вставить меч в инвентарь? Тут надо вставить картинку с аутистом пихающим квадратный кубик в треугольную дырку - это явно про тебя, если тебе нравятся такие занятия
>Забивают, посмотри стримы (особенно когда фармят какой-то арт или руну)
У тебя ОКР и ты мимо каждой какашки спокойно не можешь пройти, обязательно подбираешь?
>поэтому во всех модах
А ну васян мододел хуйни не сделает, куда до него глупеньким близам из 2000х которые сами не додумались инвентарь увеличить.
>А еще в ремастере увеличили кол-во ячеек
В сундуке.
Выдает такую ошибку
Input string was not in a correct format.
at System.Number.ThrowOverflowOrFormatException (System.Boolean overflow, System.String overflowResourceKey)
я пытаюсь поженить друг с другом трансформы из разных префабов.
к сожалению у меня нет parent constraint из более новых версий.
пытаюсь отойти от варианта 1 к чему-то вроде варианта 2, как правильно это сделать?
Понял в чем ошибка, у меня сохранение идет и видимо оно криво сделано, буду править
>Как раз долбоеб ты - такое отношение обесценивает работу геймдизайнера, так как ты скипаешь 90% его труда
Т.е. ты собираешь в игре абсолютно все предметы, потом бегаешь к торговцу продавать, из-за чего скипаешь в итоге контент, а долбоеб я, потому что я собираю только предметы имеющие нормальную ценность и играю весь контент? может ты долбоеб в квадрате просто не?
>Плюс есть игры, где в предметах прописан лор игры (соулсы например, или таже might and magic откуда скрин)
кроме солсов то игр нет же, не говоря уже о том, что говнолор в предметах это наименьшее из того, ради чего играют в солс. Сравнивать майт энд меджик "по написанию лора в предметах" может конечно каждый, но ставить на одну ступень - только дебил, в клиническом смысле.
>Плюс есть игры, в которых есть крафт
Ну да, есть игры в которых есть крафт и надо на него собирать мусор, поэтому во вех играх должен быть мусор, который надо собирать. С формальной логикой знаком?
>По твоему игра в игры - это дрочь с инвентарем, постоянный бэктреккинг, и отсутствие наград за испытание? Ну охуенно, и ты меня еще называешь долбоебом.
это ты с чего высрал вообще? самопридуманный тезис оппонента, который ты типа разнес?
>ито есть для тебя максимальная сложность - это когда надо вставить меч в инвентарь?
сказал идиот, который ноет, что ограничение инвентаря это сложно и от перекладывания предметов ему не хочется играть.
Ты просто тупой, чел. Ты даже тезисы не можешь изложить не противоречащие сами себе.
в первом варианте трансформы вместе со всем мясом выдираются из префаба-child и протаскиваются в префаб-parent
хз насколько это стремно т.к. я в текущем варианте кеширую их оригинальные родители и когда нужда отпадает(перед удалением инстанса префаба из сцены) проворачиваю фарш назад этим же методом. меня беспокоит ситуация если внезапно что-то не так пойдет и трансформы от child останутся на parent висяком после удаления.
а что со вторым не так? есть ли лучше вариант? я себя сам хочу уебать если что.
По слогу кстати похож на дауна, который усирался тут, что книги на английском не надо в шапку постить лол. Такой же конч, который ровняет весь мир по себе, при этом является планкой на малой высоте.
в 2022 есть addressable
> а долбоеб я, потому что я собираю только предметы имеющие нормальную ценность и играю весь контент? может ты долбоеб в квадрате просто не?
Ты просто обычный подпивасный дотер. Ты наверное и квесты не читаешь.
В нормальных играх ВСЕ предметы ценны. В олдовых играх времен доса вообще каждая вилка была ценной - потому что всю игру ты был бомжом. (таже might and magic к примеру... это при том что в ней было 4 (а в более ранних - 6) окон инвентаря... но тогда страдали рюализмом (тогда даже были игры, где надо было в диалогах самому текст писать с клавиатуры задавая вопросы... странно что таки не сделали туалеты и сранье (сон и еда были)))
> только предметы
Ну да конечно, а остальные предметы от балды накидали.. Вот делать нехуй геймдизайнерам - давай мусора наделаем вместо игры.
>В нормальных играх ВСЕ предметы ценны.
обоснуй
>В нормальных играх ВСЕ предметы ценны. В олдовых играх времен доса вообще каждая вилка была ценной - потому что всю игру ты был бомжом.
да да да. утверждение на чем основано? На том что ты тогда писал под себя и посмотрел как батя играет теперь типа олдово рассказываешь или истории с пикабу принес?
>таже might and magic к примеру
ты типа пытаешься уверенно пиздить или что? В поздних мм дешевые предметы потенциально имели ценность только когда ты становился грандмастером магии и грандмастером торговли в лейтгейме. Па факту денег всегда хватало и без этого просто с продажи магического лута и наград за квесты.
>Ну да конечно, а остальные предметы от балды накидали..
Ну т.е. ты реально долбоеб, который просто механически собирает абсолютно весь лут, потому что считает его ценным и накиданным с превеликим смыслом?
>Вот делать нехуй геймдизайнерам - давай мусора наделаем вместо игры.
Какой-то очередной абсурд. Аргумент твой в чем? В том, что если каждый кусочек лута в игре раположен не по пиздец какому-то вселенскому замыслу великому, то игра мусор? или в том, что если игра хорошая, то значит там великие геймдизайнеры, а если они великие геймдизайнеры то значит вот с того гоблина упала кожаная броня за 20 монет по его таблице лута и это пиздец какое красивое решение со смыслом? Ты че несешь то вообще?
>В нормальных играх ВСЕ предметы ценны
Таких игр значит нет. Ведь в большинстве игр реализованно использовать более крутые циферки и выкидывать остальной мусор, либо сюжетное получение более крутой брони.
>might and magic к примеру.
Ну не наю. Я играл в четвёртые и шестые, но там лут это буквалити мусор, который валится нонстопом и ты по кэдэ продаёшь его, а более крутую экиперовку одеваешь.
> а остальные предметы от балды накидали.
Мусор создаёт эффект добычи и заполнености.
> В олдовых играх времен доса вообще каждая вилка была ценной
Мне нравится это одухотворение старыми легендами. Воооот были времена. Не смогли мы с пацанами настроить кривую сложности в игре, выправить лут и награды должным образом, а накидали просто вилок, просто дохуя вилок чисто каждую примостырили чтобы от души и продавай карочи иди и на тебе инвентарь бесконечный. апхапх
Никто из вас не прав и в тоже время не виноват.
С одной стороны игра может предоставлять кучу различных действий, пусть и кажущихся бессмысленными с первого взгляда (По типу тех же собираний вилок из домов в скайриме).
С другой же стороны когда игра становится линейной и отбирает все дополнительные возможности с ней контактировать оставив лишь выпадение нужных предметов и только выше ранга чтобы апать свою силу, тут тоже может скрываться большая проблема что этим самым игра превращается в заскриптованное кино.
Разные подходы, жанры, игры.
>обоснуй
>>28526
>Таких игр значит нет
предметы могут использоваться в крафте и заточке другого снаряжения (и я тут не про крафт майнкрафта, а про крафт зелий, свитков, палочек, кузнечества и т.д. - короче то, чем ценны рпг с гриндом)
предметы могут продаваться торговцам, особенно когда в игре мало источников золота (ну в жизни же кошельки не валяются в каждой луже)
А особенно - в игре могли быть механики заточенные под определенное снаряжение (но которые не делают как раз из-за уебанских ограничений на инвентари). Например снаряжение с уроном по водным существам (тем более сейчас на фоне геншина такая механика стихий снова возродилась). То есть снаряжение, которое ты оденешь в определенных ситуациях.
Но если у тебя в инвентарь два меча помещается, то ты не будешь такое хранить - а значит из-за баланса такие механики если и будут, то только для галочки
Как это было в олдовых играх, где пытались даже разные виды ударов делать (рубящие, колящие, дробящие - вроде в готике такое было или пытались (там были разные анимации замахов мышкой)).
А мозгов сделать нормальный инвентарь чтобы было куда разные оружия помещать - им не хватило. поэтому эти механики оказуаливались, чтобы подпивас с одним мечом и против голема и против зомби воевал, и норм
Все игры надо делать одинаковыми, про одно и тоже и главное под твой вкус? Вопрос только зачем, если ты просто шизик, который не может структурно изложить мысли и просто какую-то кашу выкакивает, понадергав отовсюду что-то одно и смешав все в жижу.
>реализованно использовать более крутые циферки
Ну смотри, приведу пример. В игре есть разные монстры:
- големы, их можно бить только дробящим
- оборотни, на них действует только серебряное снаряжение
- слизь, на них вообще не действует оружие, а только магия или огонь
- ифриты - боятся воды и льда
- скелеты - убиваются только святым оружием (любым другим воскреснут)
Итого если делать нормально все эти механики - тебе уже нужно шесть комплектов снаряжения.
Но так как в рпг в первую очередь изобрели ячейковый инвентарь, то все это не будет работать, потому что в любой момент нападения у игрока не будет нужного снаряжения.... В инвентарь же не лезет, а ему еще лут собирать, да квестовые предметы таскать.
Поэтому такую интересную механику срезают, чтобы любой подпивас мечом мог убивать всех... Иногда конечно пытаются делать исключения (например бесмертные скелеты в дарк соул), но редко и в единичных случаях.
А вот если бы в 80-90 годы догадались давать героям пространственные кольца - ух какие бы были механики в играх
И нет, переодевание не будет дрочерским - просто делать переодевание в одну кноку. Даже в дьябло есть компекты снаряжения (два, но есть)
>Все игры надо делать одинаковыми
но вы же делаете - весь спор начался с того что опять какой-то довнич захотел ячейковый инвентарь. нахуя он не знает, но уже дрочится тем как делать предметы разных размеров (вместо того чтобы делать интересную игру)
>но вы же делаете - весь спор начался с того что опять какой-то довнич захотел ячейковый инвентарь. нахуя он не знает, но уже дрочится тем как делать предметы разных размеров (вместо того чтобы делать интересную игру)
и в чем противоречие?
>нахуя он не знает
вообще-то знаю
>вместо того чтобы делать интересную игру)
ну ты главное свою интересную игру делай, ох вейт.
>>28543
Да всех играх должны быть големы и оборотни с одинаковыми механиками это итак всем ясно. И если в солсе, скелетов надо убивать святым оружием, то во всех играх должно быть святое оружие, а так как святое оружие в солсах было с заточки, то надо заточку обязательно в игру мечты. А лут надо собирать как в секиро.
>Поэтому такую интересную механику срезают, чтобы любой подпивас мечом мог убивать всех...
>И нет, переодевание не будет дрочерским - просто делать переодевание в одну кноку.
Как это сочетается в одной голове?
В действительности дружок, я тебе сейчас открою тайну, но скелеты в дарк солсе сделаны в некоторых местах бессмертными, потому что смысл как раз в их бессмертности, а для подпивасов вроде тебя, специально сделали святое оружие, чтобы ты игру не дропнул, потому что не смог.
И не надо рассказывать пожалуйста про разнообразные игры 80х и 90х, как там было все чудно. Какие это были золотые времена механик и полетов фантазий. Это банально пиздеж.
Справедливо.
Вводные: программирую на C#, и на работе тоже. Делаю игру для себя (уже сделал, но хочу новые делать). Наткнулся буквально 5 минут назад на ролик, где автор говорит о том что 99% гайдов в интернете они сделаны максимально неверно с точки зрения оптимизации, и хуже начинающего юнити разраба трудно найти кого-то.
Вопрос: как всю эту хуйню применять в реальной жизни? Ну изучил я какие-нибудь алгоритмы, ну знаю я эту концепцию ООП и SOLID, а дальше то что? На работе у нас один из главных принципов "главное чтобы работало", но хочется же делать нормально. А как сяду делать игру, то постоянно костыль на костыле получается, хоть и игра до безумия простая и там оптимизация особо не нужна. Но меня пугает что эта привычка сохранится и я так и останусь долбаебом.
Уважаемые наносеки, как лечиться от этой хуйни? Только можно без советов в стиле "пиздуй учить ассемблер и регистры"? Спасибо
П.С. Это я нашел под одним из роликов где объясняется несостоятельность 99% гайдов по юнити
Никак. Это с опытом приходит. Быстрее всего набираются опыта те, кто работают с чужими проектами в команде.
Если ты инди, то смысла задрачивать код так сильно нет. Многие инди-шедевры написаны через жопу. В них спокойно может быть ОДИН класс со всей игровой логикой и ничего как бы.
Так это и плохо. Я и пытаюсь от этого уйти. В итоге я недавно вернулся к своей игре после перерыва, фиксил баги, долго понимал нахуя я понаписал вещей и куда я их понаписал тк файлов было много. А в "командной" разработке опять же - на работе читаю чужой код, нихуя мне он особо не дает, я максимум просто понимаю что хотел сделать автор и все
Для начала научись пользоваться профайлерами, для обычного кода и для шойдеров. В геймдеве у тебя время на расчёт кадра ограничено, поэтому ты должен знать во сколько каждая операция обходится, в терминах временного бюджета. Замороченый код никому не нужен, писать надо как можно проще, при условии того что расширять код при необходимости можно без костылей, т.е. интерфейсы и инкапсуляция должны быть предусмотрены абсолютно везде. Если алгоритм не придуман идиотом, то для производительности важнее всего не промахиваться мимо процессорного кэша, потому что частое чтение из оперативки превратит любую игру в слайдшоу. Поэтому начинаешь писать программу всегда держа в уме, что данные должны быть расположны рядом, а разветвления логики должны быть в минимальном количестве. Тогда будет у тебя 1000FPS. ООП это удел энтерпрайза, его надо использовать по минимуму в геймдеве, он просто помогает писать программы из тысяч компонентов, в игре это не важно и не нужно. В игре мы просто читаем данные и записываем данные, главное делать это без запонок, которые тебе как раз покажут профайлеры.
> нихуя мне он особо не дает
Если бы ты работал в геймдеве, то увидел бы, как много всего они используют. Они много своих инструментов пишут под тот же юнити. Используют активно всякие Zenject'ы, UniTask'и. Код пишут максимально модульным. И так далее.
> долго понимал нахуя я понаписал вещей и куда я их понаписал тк файлов было много
Это опыт. Теперь ты знаешь проблемы своего кода, а значит сможешь его улучшить.
Привет ребята. Вопрос по поводу assets store
Кто как деньги выводит? У меня после 24 февраля вообще ничего (на pay pal не поступают деньги) Быть может и был такой вопрос, но я его проебал. Пишу снова, не обессудьте.
>Ну смотри, приведу пример. В игре есть разные монстры:
- големы, их можно бить только дробящим
- оборотни, на них действует только серебряное снаряжение
- слизь, на них вообще не действует оружие, а только магия или огонь
- ифриты - боятся воды и льда
- скелеты - убиваются только святым оружием (любым другим воскреснут)
Итого если делать нормально все эти механики - тебе уже нужно шесть комплектов снаряжения.
нПока похоже на кал
А если, к примеру, через тинькоф банк?
В профиле на вывод денег указать счёт. Или тухлый номер?
Попробуй, может прокатит.
>если бы
Так я и хочу. Нихуя не выходит, везде мидлы нужны. Но из плюсов - сделал переключение между компонентами меню
Я чтобы не создавать дохуя сцен сделал все в одной и при "переключении" просто скрываю компоненты меню путем уменьшения масштаба до нуля
титькоф и хуйфайзен банк принимают по свифту
И тут случилось неприятное открытие. Создаю веапон Longsword, a переменная weaponType возвращает... Scimitar. посос.
Походу придется вместо енама с одинаковыми значениями делать отдельный статический класс, в котором будет хранится дикшенари, с ключем енамом, и целочисленным значением в валуе. Пиздец пушка. ((
двачую этого дева. Поработал пару лет на продакшен увидел разные проекты, встратые, сложные, простые, но неудобные и т.д. Потом сидишь такой пишешь в одной методе if else, потом ещё if else и ещё, и думаешь хуйню делаю такого не видел раньше - надо разделять, получилось много методов которые все равно запускаются из одно места, ага опять что то не так... и тут ты лезешь в шаблоны и например понимаешь что тебе подойдет паттерн стейт машина.
Ну и пиздец. Загугли скриптабл... нет, лучше сразу прямую ссылку дать https://habr.com/ru/post/421523/
> В них спокойно может быть ОДИН класс со всей игровой логикой и ничего как бы.
Вот такие гении годами пишут свою хуйню, хотя если делать по науке то за месяц уже игра будет готова.
да, балдёж, если ты в этом ориентируешься, не нужно в ссаный редактор лезть, чтобы что-то отредачить
Сделаю наверное немного не так. Сами данные буду хранить в структуре, чтобы можно было разные типы данных использовать, плюс все таки там филды с именами, меньше шанс запутаться. А потом создам дикшенари, с ключем енамом и велью структурой. По ключу енаму в коде опять же будет понятнее, чем по индексу от енама искать в массиве.
мне кажется у тебя все не пиздец, что ты в нубогайдах не нашел)) Щас отполирую и будет конфетка вообще, а не код.
Мне кажется, у тебя проблемы с самокритикой с головой . Это если посмотреть на проблему в общем. Поэтому у тебя сразу подлива потекла с нубогайда лол.
А если брать конкретнее, то ты пукаешь нубогайдами, потому что только по их лейкалу можешь работать, причем скорее всего мобильную хуйню по кальке производишь. Поэтому не понимаю че ты выебываешься вообще лол.
Ну пости дальше свой говнокод, будешь местным клоуном. Только на помощь больше не рассчитывай.
>Адский гемор, не понимаю того анона что писал
Там на самом деле мем оказался вообще в другом. У меня структура weaponStats дублирует по сути класс Weapon, в которую я хотел с нее гнать данные. Т.е. по сути это можно сделать например одним классом и свитч в конструкторе, например, но я не хочу, свитч на сотню итемов это не то что я хочу. или реально делать вот так
>>28649
Ору с долбоеба.
С точки зрения программы хз, нет какого-то типа технически обоснованного мнения. Не хочу лишний раз в редакторе сидеть и кликать там это все. Сначала зайди в коде поменяй енамы, потом табайся в редактор, ищи нужное место, пкм, создать .... потом ищи все это в списке ассетов. Как-то муторно.
>>28744
согласен.
>анон, не тупи OnEquip у тебя должен быть в абстрактном классе Item
абстрактный класс айтем включает в себя не экипируемые вещи. Я либо интерфейсы буду делать, либо как-то через менеджер инвентаря мутить. пока хз.
Ты статы оружия будешь постоянно менять, нет конечно. Все делают по разному, но самые правильные это so или сериализуемый в json класс, почему, потому что дев бережет свое время и делает статические данные таким способом чтобы ГД мог править, ГД в свое время будет работать с понятным интерфейсом, а это so где ты можешь ему ограничения поставить чтобы он не заебашил невалидные значения, так же json выводят на вебморду где ГД правит поля без закачки проекта, ещё профитнее.
Ну это так лирика, естественно ты можешь делать как хочешь, ведь это домашние поделки, но если ты задаешь вопросы здесь, то тебе отвечают как правильно, мы же не можем угадать как ты хочешь.
PS видел проект где основная статика была в json, для ГД были созданы гугл таблицы, где они уже и работали, потом все конвертировалось в json и обновлялись файлы в проекте. Вот так выебнулись не имея вебморды.
>сериализуемый в json класс
пока делаю чтобы работало.
>но если ты задаешь вопросы здесь, то тебе отвечают как правильно
Ну я вообще просто вбросил код и поделился задачами проблемами и неудачами. На что какие-то долбоебы агрятся и кукарекают про говнокод лол.
А был анон, который пару раз мне уже советовал про стринги. Я в стрингах не весь функционал знаю. Там реализация какая приблизительн? типо забиваешь данные в стринг с какиеми-то метками, по которым потом дергаешь из него данные и приводишь к нужному типу чи шо?
в
со стрингами работать гемор, очень легко сделать ошибку. Все стараются избегают парсинг, и используют его если нет других вариантов.
>типо забиваешь данные в стринг с какиеми-то метками, по которым потом дергаешь из него данные и приводишь к нужному типу чи шо?
ты описал json, xml.
У тебя аж поддувало сорвало.
Хз как ты разбираешься в этой каши, я бы сделал всё намнго проще но в паре скриптов.
El clasasique
Мало кто хочет шкварить свою игру о харкач
>это и есть издевательство над игроком
В БОЛЬШИНСТВЕ игр инвентарь ограничен как минимум количеством, а в РПГ зачастую ещё и весом. Ограничение по форме предметов встречается реже и лучше бы вообще не встречалось, но оно тоже встречается. И во все эти игры играют. Если тебе в такие игры играть не нравится, это скорее твоё субъективное мнение, не сильно влияющее на статистику конкретных игр. Что есть издевательство над игроком - должны решать сами игроки (целевая аудитория конкретной игры), а не один ты.
>Игрок устает туда-сюда бегать, от данжа до торговца
Ну и не будет собирать всякий мусор. В идеале пусть лишний лут сам деспавнится или подбирается какими-нибудь мобами/НПЦ, чтобы не замусоривать локации. А вообще, балансируй систему лута, чтобы из дохлой крысы первого уровня не выпадало 5 шмоток, которые игроку вообще не нужны и приходится оставлять их на земле.
>это один из антипаттернов геймдизайна
И как он называется/где о нём прочитать?
>Игроки ненавидят такое
Абстрактные игроки ненавидят любой элемент геймплея. Эти же абстрактные игроки обожают любой элемент геймплея, даже самый садистский. Всё зависит от выбранной группы игроков (ЦА).
>Так вот, игрок устает, добывает более-менее оптимальное снаряжение и все. Он просто забивает на луттинг. А значит все твои охуенные секреты и загадки он тупо пробежит.
Это значит, что твои "секреты и загадки" нахрен не нужны данному конкретному манчкину игроку, раз он всё время собирает всякий мусор и бегает продавать его торговцу, вместо поиска секретов и решения загадок. Вопрос, который ты должен задать сам себе, почему игрок занимается уборкой бесполезного мусора вместо поиска секретов и решения загадок? Может, он не знает о существовании секретов, а загадки слишком сложны?
>То есть игра теряет половину игрового контента
Игра ничего не теряет. Если конкретный игрок предпочитает пылесосить мусор с локаций - пусть пылесосит, это его дело. Другие игроки будут искать секреты и решать загадки, беря в инвентарь только реально нужные вещи вместо всякого лишнего мусора. Главное чтобы игра автоматически чистила (деспавнила) лишний лут, чтобы игрок не беспокоился о потере производительности игры.
>игрок не хочет тратить время на исследование, потому что у него все одно забит инвентарь
Разве исследование == новый лут? Обычно в играх исследование связано с получением какого-то нового игрового опыта, а лут - это второстепенное, необязательное. К тому же, даже если инвентарь забит под завязку, а ты нашёл что-то новое, это новое может оказаться значительно лучше мусора в инвентаре и ты просто скинешь на землю лишнее, чтобы поднять это новое.
>и даже если он решит загадку, там будет какой-нибудь мусор который ему все равно некуда положить.
Эээ... Ну это уже проблема геймдизайна, если решение загадок выдаёт бесполезный мусор, который некуда положить. Делай загадки такими, чтобы они выдавали достойный лут или начисляли какую-то валюту - опыт, монетки и тому подобное, либо открывали проход в новые локации. Возможностей масса, не обязательно выдавать какой-то мусор в инвентарь.
Твои жалобы выглядят как обида на какую-то конкретную игру с неудачным геймдизайном или игру, которая лично тебе не подошла по субъективным ощущениям и/или твоему стилю игры. Успокойся, есть масса игр, которые подойдут лично тебе, не нужно пытаться исправить игры, которые сделаны не для тебя - ты просто не входишь в целевую аудиторию этих игр и это нормально.
Лично я никогда не имел фрустрации от ограниченного инвентаря в играх. Правда, я редко играю в классические РПГ с квестами, лутом и т.д. Мне больше нравятся игры на выживание с элементами песочницы, в таких инвентарь почти всегда жёстко ограничен и это очень хорошо - безлимитный инвентарь убивает весь кайф от игры. Если бы инвентарь был безлимитным, не было бы смысла строить сундуки и сортировать имущество, не было бы смысла строить жилища/базы/транспорт, не было бы необходимости продумывать тактику следующих действий, сортируя в инвентаре инструменты, оружие, патроны, лечилки, еду и так далее. Короче, ограниченный инвентарь - очень важный компонент таких игр, формирующий геймплей, а не просто играющий на погружение (чаще всего ты таскаешь буквально тонны ресурсов в "рюкзаке", так что ни о каком реализме речи не идёт).
>>28424
>такое отношение обесценивает работу геймдизайнера, так как ты скипаешь 90% его труда
>снова обесценивая работу геймдизайнера
1. Скипать скучную часть игры - это нормально.
2. Если игра лично тебе скучна на 90% - эта игра просто не для тебя, ты не входишь в её ЦА.
3. Если игра скучна для большинства игроков, которым эту игру продали - её геймдизайн говно, а её геймдизайнера нужно уволить или отправить на переобучение. Либо нужно уволить маркетологов, которые продали игру не тем игрокам, которым нужно было продать (пример: маркетолог советовал сделать анимешную стилистику графики, но геймдизайнер таргетировал игру на любителей вахи, в итоге игроки, купившие игру за графику, недовольны геймплеем, потому что он рассчитан не на них).
4. Игроку насрать на геймдизайнера. В 99% случаев игрок даже не знает, кто делал его игру. Ему важно только получить удовольствие от игры. Что он и делает, рационально скипая скучные моменты игры.
>По твоему игра в игры - это дрочь с инвентарем, постоянный бэктреккинг, и отсутствие наград за испытание?
1. Дрочь с инвентарём может быть основополагающим для всего геймплея, пример см. выше (выживач).
2. Путешествие назад, в город или на базу - это уже проблема левел-дизайна. Делай так, чтобы прогулки были не слишком долгими или чтобы из любой точки можно было пойти в разные города (для разнообразия).
3. Испытание должно быть само по себе наградой. Игроку должно быть приятно проходить испытание. Если игроку неприятно проходить испытание, он не будет его проходить даже ради супер эпичного лута, потому что он играет ради удовольствия, а не ради виртуальных пикселей.
>>28513
>каждая вилка была ценной - потому что всю игру ты был бомжом
Лол, так у тебя просто синдром Плюшкина. ИРЛ ты тоже любое говно с мусорки домой несёшь или как? Не все игры заточены под больных синдромом Плюшкина, извини уж. Играй в игры, которые позволяют набивать бездонные карманы бесконечным лутом...
>>28543
>тебе уже нужно шесть комплектов снаряжения
>просто делать переодевание в одну кноку
1. Делая переодевание однокнопочным действием ты полностью обесцениваешь саму механику "комплектов снаряжения". Потому что если игрок может в любой момент переодеться в нужный шмот, это равносильно тому, что никаких комплектов нет - он всегда в подходящем снаряжении. Смысл тогда эти комплекты делать?
2. Если мы говорим об РПГ играх, то они как правило заточены на некоторый уровень реализма, чтобы игрок мог ОТЫГРЫВАТЬ РОЛЬ, например, быть "святым рыцарем" в блестящих доспехах и с освящённым мечом, борящимся с порочной нежитью и порождениями тьмы, но бессильным против магов света и чистых душой существ. Этот святой рыцарь не должен внезапно переодеваться посреди боя и брать в руки другое оружие, иначе какой он святой рыцарь? Так, фальшивка какая-то... Да и как ты себе это представляешь? Монстры нападают на рыцаря, а он такой "падажжи..." и, резко сбросив броню, вдруг выхватывает из жопы лук на +50 урона и становится дофига опытным лучником? Херовый отыгрыш в твоей РПГ получается.
3. Комплекты снаряжения могут сосуществовать с ограниченным инвентарём. Да. У тебя есть база, на базе есть сундуки с различным шмотом. Ты на базе решаешь, в какую локацию пойти. Зная, какие монстры обитают в той локации, ты выбираешь подходящий шмот. Если ты идёшь в ледяные пещеры, ты берёшь огненное оружие и защиту от мороза, а если идёшь в жерло вулкана, то берёшь морозящее оружие и защиту от огня. Логично? Логично. Левел-дизайн должен это учитывать - чтобы в ледяных пещерах не спавнились огненные ифриты, а в жерле вулкана не спавнились ледяные големы. Конечно, могут быть универсальные монстры, но тут ты просто должен выбирать, чем ты пожертвуешь, выбирая тот или иной комплект оружия и брони. Всё просто - заранее продумывай свои действия и всё будет хорошо.
Надеюсь, когда-нибудь ты найдёшь себе игру по душе или сделаешь игру мечты, аналогов которой пока нет. В любом случае, удачи и успехов, не забудь собрать мусор со свалки по дороге домой)) Шучу, не обижайся.
>это и есть издевательство над игроком
В БОЛЬШИНСТВЕ игр инвентарь ограничен как минимум количеством, а в РПГ зачастую ещё и весом. Ограничение по форме предметов встречается реже и лучше бы вообще не встречалось, но оно тоже встречается. И во все эти игры играют. Если тебе в такие игры играть не нравится, это скорее твоё субъективное мнение, не сильно влияющее на статистику конкретных игр. Что есть издевательство над игроком - должны решать сами игроки (целевая аудитория конкретной игры), а не один ты.
>Игрок устает туда-сюда бегать, от данжа до торговца
Ну и не будет собирать всякий мусор. В идеале пусть лишний лут сам деспавнится или подбирается какими-нибудь мобами/НПЦ, чтобы не замусоривать локации. А вообще, балансируй систему лута, чтобы из дохлой крысы первого уровня не выпадало 5 шмоток, которые игроку вообще не нужны и приходится оставлять их на земле.
>это один из антипаттернов геймдизайна
И как он называется/где о нём прочитать?
>Игроки ненавидят такое
Абстрактные игроки ненавидят любой элемент геймплея. Эти же абстрактные игроки обожают любой элемент геймплея, даже самый садистский. Всё зависит от выбранной группы игроков (ЦА).
>Так вот, игрок устает, добывает более-менее оптимальное снаряжение и все. Он просто забивает на луттинг. А значит все твои охуенные секреты и загадки он тупо пробежит.
Это значит, что твои "секреты и загадки" нахрен не нужны данному конкретному манчкину игроку, раз он всё время собирает всякий мусор и бегает продавать его торговцу, вместо поиска секретов и решения загадок. Вопрос, который ты должен задать сам себе, почему игрок занимается уборкой бесполезного мусора вместо поиска секретов и решения загадок? Может, он не знает о существовании секретов, а загадки слишком сложны?
>То есть игра теряет половину игрового контента
Игра ничего не теряет. Если конкретный игрок предпочитает пылесосить мусор с локаций - пусть пылесосит, это его дело. Другие игроки будут искать секреты и решать загадки, беря в инвентарь только реально нужные вещи вместо всякого лишнего мусора. Главное чтобы игра автоматически чистила (деспавнила) лишний лут, чтобы игрок не беспокоился о потере производительности игры.
>игрок не хочет тратить время на исследование, потому что у него все одно забит инвентарь
Разве исследование == новый лут? Обычно в играх исследование связано с получением какого-то нового игрового опыта, а лут - это второстепенное, необязательное. К тому же, даже если инвентарь забит под завязку, а ты нашёл что-то новое, это новое может оказаться значительно лучше мусора в инвентаре и ты просто скинешь на землю лишнее, чтобы поднять это новое.
>и даже если он решит загадку, там будет какой-нибудь мусор который ему все равно некуда положить.
Эээ... Ну это уже проблема геймдизайна, если решение загадок выдаёт бесполезный мусор, который некуда положить. Делай загадки такими, чтобы они выдавали достойный лут или начисляли какую-то валюту - опыт, монетки и тому подобное, либо открывали проход в новые локации. Возможностей масса, не обязательно выдавать какой-то мусор в инвентарь.
Твои жалобы выглядят как обида на какую-то конкретную игру с неудачным геймдизайном или игру, которая лично тебе не подошла по субъективным ощущениям и/или твоему стилю игры. Успокойся, есть масса игр, которые подойдут лично тебе, не нужно пытаться исправить игры, которые сделаны не для тебя - ты просто не входишь в целевую аудиторию этих игр и это нормально.
Лично я никогда не имел фрустрации от ограниченного инвентаря в играх. Правда, я редко играю в классические РПГ с квестами, лутом и т.д. Мне больше нравятся игры на выживание с элементами песочницы, в таких инвентарь почти всегда жёстко ограничен и это очень хорошо - безлимитный инвентарь убивает весь кайф от игры. Если бы инвентарь был безлимитным, не было бы смысла строить сундуки и сортировать имущество, не было бы смысла строить жилища/базы/транспорт, не было бы необходимости продумывать тактику следующих действий, сортируя в инвентаре инструменты, оружие, патроны, лечилки, еду и так далее. Короче, ограниченный инвентарь - очень важный компонент таких игр, формирующий геймплей, а не просто играющий на погружение (чаще всего ты таскаешь буквально тонны ресурсов в "рюкзаке", так что ни о каком реализме речи не идёт).
>>28424
>такое отношение обесценивает работу геймдизайнера, так как ты скипаешь 90% его труда
>снова обесценивая работу геймдизайнера
1. Скипать скучную часть игры - это нормально.
2. Если игра лично тебе скучна на 90% - эта игра просто не для тебя, ты не входишь в её ЦА.
3. Если игра скучна для большинства игроков, которым эту игру продали - её геймдизайн говно, а её геймдизайнера нужно уволить или отправить на переобучение. Либо нужно уволить маркетологов, которые продали игру не тем игрокам, которым нужно было продать (пример: маркетолог советовал сделать анимешную стилистику графики, но геймдизайнер таргетировал игру на любителей вахи, в итоге игроки, купившие игру за графику, недовольны геймплеем, потому что он рассчитан не на них).
4. Игроку насрать на геймдизайнера. В 99% случаев игрок даже не знает, кто делал его игру. Ему важно только получить удовольствие от игры. Что он и делает, рационально скипая скучные моменты игры.
>По твоему игра в игры - это дрочь с инвентарем, постоянный бэктреккинг, и отсутствие наград за испытание?
1. Дрочь с инвентарём может быть основополагающим для всего геймплея, пример см. выше (выживач).
2. Путешествие назад, в город или на базу - это уже проблема левел-дизайна. Делай так, чтобы прогулки были не слишком долгими или чтобы из любой точки можно было пойти в разные города (для разнообразия).
3. Испытание должно быть само по себе наградой. Игроку должно быть приятно проходить испытание. Если игроку неприятно проходить испытание, он не будет его проходить даже ради супер эпичного лута, потому что он играет ради удовольствия, а не ради виртуальных пикселей.
>>28513
>каждая вилка была ценной - потому что всю игру ты был бомжом
Лол, так у тебя просто синдром Плюшкина. ИРЛ ты тоже любое говно с мусорки домой несёшь или как? Не все игры заточены под больных синдромом Плюшкина, извини уж. Играй в игры, которые позволяют набивать бездонные карманы бесконечным лутом...
>>28543
>тебе уже нужно шесть комплектов снаряжения
>просто делать переодевание в одну кноку
1. Делая переодевание однокнопочным действием ты полностью обесцениваешь саму механику "комплектов снаряжения". Потому что если игрок может в любой момент переодеться в нужный шмот, это равносильно тому, что никаких комплектов нет - он всегда в подходящем снаряжении. Смысл тогда эти комплекты делать?
2. Если мы говорим об РПГ играх, то они как правило заточены на некоторый уровень реализма, чтобы игрок мог ОТЫГРЫВАТЬ РОЛЬ, например, быть "святым рыцарем" в блестящих доспехах и с освящённым мечом, борящимся с порочной нежитью и порождениями тьмы, но бессильным против магов света и чистых душой существ. Этот святой рыцарь не должен внезапно переодеваться посреди боя и брать в руки другое оружие, иначе какой он святой рыцарь? Так, фальшивка какая-то... Да и как ты себе это представляешь? Монстры нападают на рыцаря, а он такой "падажжи..." и, резко сбросив броню, вдруг выхватывает из жопы лук на +50 урона и становится дофига опытным лучником? Херовый отыгрыш в твоей РПГ получается.
3. Комплекты снаряжения могут сосуществовать с ограниченным инвентарём. Да. У тебя есть база, на базе есть сундуки с различным шмотом. Ты на базе решаешь, в какую локацию пойти. Зная, какие монстры обитают в той локации, ты выбираешь подходящий шмот. Если ты идёшь в ледяные пещеры, ты берёшь огненное оружие и защиту от мороза, а если идёшь в жерло вулкана, то берёшь морозящее оружие и защиту от огня. Логично? Логично. Левел-дизайн должен это учитывать - чтобы в ледяных пещерах не спавнились огненные ифриты, а в жерле вулкана не спавнились ледяные големы. Конечно, могут быть универсальные монстры, но тут ты просто должен выбирать, чем ты пожертвуешь, выбирая тот или иной комплект оружия и брони. Всё просто - заранее продумывай свои действия и всё будет хорошо.
Надеюсь, когда-нибудь ты найдёшь себе игру по душе или сделаешь игру мечты, аналогов которой пока нет. В любом случае, удачи и успехов, не забудь собрать мусор со свалки по дороге домой)) Шучу, не обижайся.
Сумасшедший, просто сделай ScriptableObject со всеми этими полями и нормальными ссылками на ресурсы, а не ебанутый Resources.Load (который вообще не для этого создавался)
Тебе несколько дней подряд говорят как правильно делать, а ты продолжаешь срать себе в штаны.
Ты не сможешь сделать лучше, чем гайды с хабра. это невозможно. импосибуру, анбеливбл
>гайды с хабра
Их пишут такие же люди, как и мы с вами. Только у них никнеймы и аватарки. В остальном они тоже ошибаются, делают сомнительные решения и т.д. Алсо, невозможно написать универсальный гайд, если он касается чего-то сложнее совсем тривиального. В каждом конкретном случае может быть выгоднее тот или иной способ. В программировании всегда много разных путей, и если бы один из путей был выгоден в 100% случаев, программисты были бы не нужны - просто возьми готовое решение.
навык демагогия +100 не даст соврать
> Читайте книги и код профессионалов
Лучше послушайте меня, не слушайте этого уебана, книги не нужны, начинайте делать игру не мечты и всё у вас будет заебись, если что-то непонятно - гугл, ютуб
Вот у меня объект и он выполняет какую-то корутину. При этом ему нужно время на выполнение корутины, например, в корутине время считается.
Но тут я снова обращаюсь к объекту и вызываю эту же корутину.
Что произойдет? У меня же, по идее, нет двух экземпляров корутины которые работают параллельно и независимо. Я обосрусь тут?
Если go активный и не уничтожен и ты не стопнишь корутину вручную, она будет работать. Ты это легко можешь чекнуть добавив логи и запустить, ну или проще прочитать документацию, которая гуглится в первую выдачу
>У меня же, по идее, нет двух экземпляров корутины которые работают параллельно и независимо
IEnumerator KOPYTNHA() {
if(coroutineRunning) return;
coroutineRunning = true;
...
coroutineRunning = false;
}
Про дроу колы и как включить батчинг я в курсе, нужно что-то более глубокое и неочевидное
private Coroutine runningCoroutine = null;
void DoSomething()
{
if(runningCoroutine == null)
{
runningCoroutine = StartCoroutine(nameof(MyCor));
}
}
IEnumerator MyCor()
{
// DO
runningCoroutine = null;
}
Тут более контролируемо, есть ссылка на корутину, которую можно стопнуть.
Кодишь симулятор девственника?
Извини, братишка, походу статьи на хабре нет.
Спасибо, понял. Просто у меня возникли сомнения из-за того что я в корутине использовал одну "глобальную" переменную. Заменил на локальную и все стало нормально и логично.
Алсо, глянул документацию. Забавно, что если отключить объект через SetActive(false), то корутина тоже остановится. Так что потенциально не такие уж они неостановимые, эти корутины.
Это плюс корутины что они привязаны к жизненному циклу go, в отличии от тасок которые вручную надо стопить, создавать каселятион токены и т.д.
>AngleAxis
Типа сперва сделать LookAt а потом подкорректировать AngleAxis? Или в качестве второго аргумента можно указать направление?
Усиленно реквестирую, вроде во всей инфе что нашел за день никто блять с такой проблемой не сталкивался, что Агент из одной ареи в другую не мог, причем изначально стартуя из зеленой ареи.
Паготь, пытаюсь найти гайд на хабре
там ничего у тебя сверху, внизу нет? что то ему мешает, может дорога возвышенность с которой он не может сойти? Почекай настройки. Если долго сидишь создай пустую сцену сделай там часть функционала с 0 и попробуй так же
Нашел? Во всех гайдах, что я видел там просто пересказывают документацию юнити.
Да если вы думаете, что впустую провели день, то вспомните этот реквест. Пиздец оказывается, чтоб путь нормально высчитывался все слои должны быть на одной координате. Мое ебало представьте.
Вопрос, какие паттерны лучше изучить, какие вообще используются в геймдеве? Из всего списка требуемого это для меня самое темное.
Вообще, я думаю, что пока я не поработаю в команде над проектами, никакая теория не даст мне нужного понимания, поэтому сначала надо побыть джуниор-рабом. Там конечно конкуренция, но у меня с юнити опыт большой и есть 3 завершенные игры
>Там конечно конкуренция, но у меня с юнити опыт большой и есть 3 завершенные игры
помню пришел дев на собес, есть две игры и учит детишек программированию через игры как мило, у него говнокод в котором нехуя не понятно, addcomponent & findobjectoftype по всему проекту, 10 скриптов которые делают все.
Не взяли на джуна сразу на сениора-лида
А findobjectoftype - это всего лишь проблема уровня "хуево, но можно легко пофиксить", делов-то сделать поиск, и закешировать в таких местах искомые обжекты. Так же, всратое именование классов и переменных типа car moya_Peremanaya - тоже хуйня. Если чел хороший архитектур и пишет все по паттернам - то ему это можно простить, ведь научить этим штукам несложно.
А вот когда игра начала расширятся при хуевой архитектурой... вот тут поиском по коду не поможешь.
Или я могу работать программистом не думая о паттернах? Этим пусть занимаются специальные люди ? (более высокоуровневые программисты, или там кураторы, на чью должность я не претендую)
Ну вот допустим мне дали задачу: надо реализовать, чтобы игрок мог хакнуть все камеры в здании через компьютер, чтобы через них смотреть и переключаться между ними. Я такое вполне могу сделать. Но я хз правилен ли будет код с точки зрения "гибкости и расширяемости" и "по паттернам", что так требуют в вакансиях.
В общем, пока не поработаю в команде, наверное, нет смысла что-то изучать по паттернам, ибо такое можно только в команде понять, на живых примерах
> Хочу однажды устроится как юнити программист. В вакансиях пишут знать паттерны программирования.
Тебе обязательно надо знать обсервер - в общем-то эвенты это оно и есть. Ими ты обязательно должен знать как пользоваться.
Неплохо бы ещё команду, стратегию, евент бас, сервис локатор(но учти, что он считается анти паттерном)
Конечно синглтон - ты должен знать его реализации и популярную в юнити кругах версию, где инстанс в авейке задают, на практике не факт что тебе им придется пользоваться, но синглтоном джунов многие душить будут точно.
Model View Presenter неплохо знать тоже
Dependency Injection очень многие используют
Реактивное програмиирование(Unirx гугли) много где используют.
Также надо знать принципы SOLID. На праутике ты должен понимать, что разделение обязанностей классов и соблюдение их зон ответственности - это очень важно.
Пулинг кстати нередко тоже называют паттерном, ну разумеется ты должен уметь пулы делать.
>Тебе обязательно надо знать обсервер - в общем-то эвенты это оно и есть.
а в чем прикол фигачить какие-то интерфейсы и прочее, если делаешь просто паблик эвент и инвоакаешь и типо результат такой же. в чем профит?
Интерфейсы для совсем другого нужны.
Без интерфейсов ты делаешь Slime.OnAttack += ...
А с интерфейсом IEnemy.OnAttack += ...
А что там за IEnemy тебя не ебет
Не лезь в реактивное программирование. Оно тебя сожрёт.
Вот я и спрашиваю, нахуя делать паттерн обзервер с тремя интерфейсами, если можно ебануть айенемионаттак+=. в чем так сказать профит подхода? Дроча то явно чуть больше, чем строчка с эвентом.
> Вот я и спрашиваю, нахуя делать паттерн обзервер с тремя интерфейсами, если можно ебануть айенемионаттак+=. в чем так сказать профит подхода?
А, ты про это.
Не, вручную обсервер тебе делать не надо - евенты это и есть обсервер который уже за тебя сделан.
Хули оно блять вылетает.
Начал делать игру майнкрафт только лучше, осваиваю юнити и эта хуйня стабильно намертво зависает раза 3 в день после изменений кода. Просто висит минутами без прогресса на updating scripts или reloading assets и все, нихуя.
Это у всех так и вы просто продолжаете есть кактус или это я одаренный?
P.S. После убийства через диспетчер задач эта хуйня еще и gpu ускорением перестает пользоваться, 3 фпса в редакторе, пока не перезагружусь.
P.P.S. Переустанавливать пробовал
P.P.P.S. Еще использую райдер, может он че-то ломает
Как жить нахуй
Ноут Dell XPS 15 9560 (i7 7700k, gtx 1050, 40gb ram, ssd)
Остальные тулзы / игры нормально себя ведут, только юнити чудит
Ну хорошо хоть что у тебя не вылетает, значит технология нормальная хотя бы можно на годот не переезжать
Я пошел дальше, я его просто использую)))))
Ну вообще да через евенты все очень красиво делается. Объясните только почему вы используете юнитевские ебенты вместо майкрософтских? Там есть, что ли какие-то крутые фишки?
>почему вы используете юнитевские ебенты
Ну типо есть такой момент, что кнопки кушают только юнити эвенты. В остальных местах использую обычные.
юнити эвенты еще в иерархи видно. для тех кто привык все в редакторе делать наверное удобно.
я идиот который запилил ассет с ебенячей кучей блендшейпов но не подумал что потом, возможно, нужно будет использовать два абсолютно разных материала на одном рендерере
я могу разделить свой ассет на две части на границах материалов и назначить каждому свой, но это удваивает количество блендшейпов которыми мне надо будет управлять.
возможно ли в юнити объединить блендшейпы в один, но для разных мешей?
или же стоит допилить шейдер чтобы можно было две разные текстуры использовать?
чё думаете? для себя несколько интересных приметил, например destroyit, unistorm
а mech combat - это пиздец, видел в стиме несколько мобильно-донатных помоек, которые почти не отличаются, но от разных разрабов может так же сделать?
Что за бандл? У меня не грузит чето
все научились
Это копия, сохраненная 19 января 2024 года.
Скачать тред: только с превью, с превью и прикрепленными файлами.
Второй вариант может долго скачиваться. Файлы будут только в живых или недавно утонувших тредах. Подробнее
Если вам полезен архив М.Двача, пожертвуйте на оплату сервера.