Хочу кое что сказать начинающим разработчикам, которые включили это видео. Посмотрите первый раз - да, возможно вы многое не поймете. Отдохните. Поизучайте документацию, или как я, поспрашивайте у GPT различные реальные примеры реализации Zenject. Посмотрите второй раз - вы увидите, что начинаете понимать, что к чему. Посмотрите третий раз - и вот вы уже в полном понимании происходящего. Спасибо за ролик, капитан!
уже раз 10 посмотрел, кучу видосов ру и англ посмотрел, и нифига не понятно как с ним работать, в глобально плане понятно что он удобен, но как его использовать хз, в каких ситуациях? сделал как по туториалу, а мне пишет предупреждение зенжект, мол плохая идея так делать(( документация на мудренном написана(( дня 4 уже убил(( да написал игру которая работает на зенжект и решает все проблемы, но там 1 вариант решения, в основном биндим обычные классы, а как забиндить префаб игрока которого нет на сцене, который нужно создать как то, внутри префаба игрока допустим в классе Player есть псевдоконструктор который инжектит доступ к обычным классам забиндженным в инсталлере((
На какое бы обучающее видео я не знашёл, везде пишут "начинающим разработчикам". Я: Начинаю учиться кодить. Челы: "Начинающий разработчик". Я: Написал свою первую игру. Челы: "Начинающий разработчик". Я: Сделал резюме и выучил основные паттерны, начинаю углубляться в более сложное проектирование. Челы: "Начинающий разработчик". Я: Устроился в компанию Junior-ом, уже даже не стажёр. Челы: "Начинающий разработчик". Мне кажется, у челов в принципе будет до самого конца мнение, что если он смог освоить что-то (даже не паттерн, а правило проектирования KISS, например)) ), то все, кто ещё этого не знают (или просто не слышали формулировку) - начинающие. Ору с самомнения))
Как же часто я возвращаюсь на этот канал, ибо, чаще всего, поиск того, что мне нужно в данный момент, ведет, чуть ли не первой ссылкой в ютубе - сюда :D Как раз препод наругал меня за то, что я слишком часто использую статику и свой "псевдосинглтон", и что пора бы уже задуматься об изучении Зенжекта и использовать пул, забыв о моем обычном Destroy :DDD (надо будет поглядеть ролик про Night pool) Благодарю за чудесный контент)) Даже не смотря на то, что приходится часто жамкать паузу и прослушивать некоторые моменты несколько раз, чтобы пережевать информацию мозгом - ролики эти бесценны!..
Большое спасибо, очень приятно) К моим ассетам в идеале читать документацию на GitHub, так как их я частенько обновляю, а ролики, к сожалению, нет У меня есть классный синглтон на гитхабе. Пул и прочее тоже там, можешь код поизучать. Документация везде написана
Я что, перестаю быть джуном? Охренеть конечно. Вообще не удивлён, ибо на самообучении такую инфу не нуйдёшь, а без опыта работы в компании тем более, но тут нашёл, спасибо огромное! Даже один концепт того что можно создать стек фреймворков для такой красивой реализации и убрать все NullRef`ы меня радует. Я прям типичный пример самоучки - документация Юнити, GPT, гайды с Ютуба, работаем. Результат - FindObjectOfType как единственное решение, которое заработало, но и проблем насыпало, а кто ж знал? В моём виденьи - в гайдах юзают, оно работает, вроде норм, чёт автоматизирую, подправлю под свои нужды и норм. А оказывается можно и так. И мне нравится, это офигенный подход, но всю прелесть подобного решения такой как я может почувствовать только пройдя через говнокод. Как считаете, надо ли проходить через период говнокода? Типа, в начале обучения даже говнокодить надо научиться, что бы хоть что-то создать рабочее, инфы больше, чем за 5 лет школьной программы по ощущениям. Мне нравится, но не дропнул потому что был опыт в том же DaVinchi, желание постигать сложное и ещё куча факторов. Или пример с модовой террарией. Есть Ванилла с сундуками, в которых ничего не найдёшь, а пока рассортируешь красиво уйдёт 20 часов. А есть TModLoader, в котором MagicStorage даёт возможность искать айтем по тегу. Будешь ли ты ценить второе без опыта первого? Сложный вопрос. Сразу в голову приходит воспитание ребёнка. Давать ли ему то чего не было у тебя просто так и тем самым убрать потребность достигать того же стейта, когда ты не паришься о деньгах и можешь создавать что хочешь, но с риском того что он не будет хотеть ничего делать. Либо же равномерно из грязи в князи вести, но с поправками? Представьте как будет выглядеть обучение: Язык (от 1 месяца до 3 месяцев, в зависимости от подхода к обучению и обучаемости). Немного теории, IDE, Фреймворки, библиотеки (именно что они из себя представляют). Стек фреймворков обязательно сказать. Unity (что само по себе огромный стек информации. Спустя полгода работы в нём я всё ещё мальком себя ощущаю). И ко всему ещё другие фреймворки, облегчающие работу, безусловно, но и количество информации растёт конкретно. Я ещё Draw.IO пару дней тестил и учил, дабы можно было учиться более наглядно и проектировать хотя бы базовое представление взаимодействия логики. GPT тоже правильно вопросы надо ставить, дабы получать именно тот результат который нужен (будьте честны, рядовой пользователь ПК не умеет гуглить, что подводит к следующему пункту) Умение искать информацию и скилл увидеть то что тебе нужно. У меня этот скилл наверное самый важный, он в принципе личность можен поменять, что думаете? Ну и ещё бы хотел отметить умение менеджить время для такой работы, все же знают это ощущение когда процесс прям прёт, достигаешь безумного прогресса, а потом после столкновения с одной банальной ошибкой хернёй страдаешь и не заходить в проект неделю? У меня так было. Многое применимо к любой профессии, но в программировании лично у меня больше проблем было, нежели в том же монтаже, пусть и не очень сложном. Мемы, переходы, базовые эффекты, что в прочем тоже при первом знакомстве может вводить в ступор. Например когда я подруге говорил о концепции секвенций в редакторе (по сути кусок видео на таймлайне) она не могла вдуплить. Когда показал даже не вдуплила. Сразу выказываю уважение тем учителям, которые всё это понимают и умеют объяснить любому любую информацию. Так что ещё раз спасибо! Удачи каждому кто дочитал жо конца :D
@@Bushido_Cat Челы на позициях Senior, которые ни одного фреймворка не написали: Аааа... Ну, пойду, начальству скажу, чтобы мне платили не 250к, а 50, как нашим джунам, спасибо гению из интернета, глаза открыл!)
Я - без опыта работы, все время на самообучении, и чтобы ПОПАСТЬ на позицию джуна учу Dependency injection. - Челы рядом, пытаясь найти те же знания: ООО, я уже не джун!) Пздц, мы реально в разных мирах живём, или что это за бред?)))
Очень полезный материал. Но все же нжект в поля это как-то грязновато. Получается кто-то из вне знает внутреннюю реализацию объекта к которому не относится? Вариант с псевдо конструктором куда как чище и аккуратнее. Но это тема для холивара, а на него времени нет, код писать надо !)))) з.ы. Да и как-то ты очень быстро пропаровозил тему фабрик, а это довольно важная часть возможностей иньекций.
Отличные темы на канале раскрываются! Что ECS, что DI, крайне полезно) На работе тоже используем Zenject, но при первом взаимодействии мне там рассказали меньше, чем в этом видео!)
Большое спасибо) Пока нет видосов на широкую аудиторию, а в основном для тех, кто уже шарит или хочет шарить Но, думаю, будущие видосы и время всё залечат)
Лул) Для синглтона можно реализовать очень простую и незамысловатую конструкцию в getter, он тебе при первом общении создаёт объект, если его нет. Или префаб... Сути не меняет, синглтон, это не только инициализация в Start или Awake. Так же не забываем про C# синглтон, можно юзать его даже без monoBeh-а Про синглтон много можно придумать реализаций, а эта самая геморная. И не понятно для чего оно нужно, если честно 😅 Возможно подойдет тому, кто не умеет строить зависимости
Начал нормально объяснять, а когда дело коснулось кода, то "пиши это" без объяснения почему. Придется более подробно где-то в другом месте читать про все то, что ты там написал, чтобы переделать это под свой проект
Каким образом интерфейсы разорвали зависимости? С таким же успехом можно было сделать базовый класс Weapon и от него наследников. Пистолеты и шотганы..
Спасибо за видео! Я получил отличное представление по Zenject. Ещё ты сказал очень интересную фразу: что статические поля и свойства остаются после перехода между сценами. И теперь я понимаю почему статику критикуют при неумелом использовании. Если я правильно понял, то статические классы так-же остаются в оперативной памяти при переходе между сценами?
Привет, на здоровье, рад, что тебе пришло осознание Zenject'а и статики) Да, статика на то и статика. Ещё есть интересная штучка - статический конструктор. В следующем видео я про него немного расскажу, надеюсь, до конца февраля его выпущу
Привет, спасибо за данный урок. Но есть несколько вопросиков, ты говоришь что не стоит использовать повсюду интерфейсы, что их надо юзать когда есть больше чем 1 реализация, но что на счет интерфейсов - маркеров ? Так же можно было дать совет новичкам о принципе Interface Segregation который гласит разделять интерфейсы на маленькие сущности да бы наследник не был вынужден наследовать то что ему не надо, но это так к слову
спасибо за видос! Очень подробно всё описано! Вот только мне всё-равно не понятно( 12:42 "теперь вместо беспокойства о прокидывании зависимостей с каждой сцены, что очень неудобно, ешё можно просто забыть это сделать можно использовать зенжект" (в котором нужно будет дописать инициализацию чего-то, и добавив на сцену доп объект, в который таки надо будет прокинуть ссылку на то, на что "в начале мысли" мы могли забыть прокинуть ссылку ? Некоторое время назад мне не нравились события и подписка на них, а сейчас норм, втянулся)) Надеюсь функционал зенжекта и то, как его использовать до меня тоже дойдёт)
@@ruslan_yefimov А ты когда видео смотришь, тоже каждую секунду на паузу ставишь, не успевая послушать, что сказал автор, и увидеть, что он написал, из-за чего перепросмотры видео увеличиваются раз в 5? (А автор коммента написал про первый просмотр) Умойся, клоун
вопрос, что лучше(ну или что вы чаще используете), интерфейсы или абстрактные классы? например, оружие можно реализовать через интерфейс, а можно через абстрактный класс.
Очень круто объяснил, без воды, четко! Есть вопрос по DiContainerRef, который ты вписал в какой то класс с методом InstantiateIntoExistingPool(..). Это метод класса Zenject? Идея понятна,- так будут инжектиться поля в каждом созданном объекте в пуле. Но сам DiContainerRef - статика, а это уже несколько грязный прием.. Впрочем, DiContainer итак всегда один, так что зачет)
Очень интересный ролик. Я использую Zen. но ... , на пример я использую инсталлеры просто вешая их на обэкты , твой вариант намного интереснее - вешая их все в пустой обджект. Было бы ооочень интересно посмотреть туториал по структуре проекта на примере игры, или просто обзор твоей игры ., я находил только начальные туториалы по zen, а что дальше "разберитесь сами", Если тебе будет интересно сделать туториал по "сложной" игре =) 🙏
Что мешает сделать bootstrap и поочерёдно инициализировать синглтоны? Как-будто это единственная проблема которую решает Zenject, да ещё и к тому же он замедляет код.
Не совсем понял, что делает "QueueForInject". Можно немного разжевать? И еще такой вопрос назрел: Например, у меня "MononInstaller", который хранит в себе +100500 префабов, инстансы которых будут передаваться в виде инъекций. Я правильно понимаю, что все эти префабы хранятся в памяти как полноценные объекты? Если да, то можно ли как-то выгрузить этот "MononInstaller" после использования, что бы не занимал память или вообще убить "SceneContext"? И третий вопрос: Таже проблема с памятью, но для "ProjectContext".
QueueForInject в основном используется для тех классов, что уже есть на сцене и внедрение произойдет сразу после фазы установки Нет, это ссылочные типы. А если на сцену все +100500 добавишь, то прощай оперативка и всё остальное)
@@NightTrainCode "QueueForInject" оговаривается, что экземпляр инъектируется при запуске. А без него разве не при завпуске? Container.Bind.......; --- теперь если кто-то попросит у зенжекта "SomeClass", то он будет предоставлен. Container.QueueForInject(SomeClassInstance); --- класс по прежнему предоставляется, что изменилось не понятно...
Я рекомендую начинать с другого видео ruclips.net/video/IS2YUIb_w_M/видео.html (там есть целый плейлист) IMHO Здесь же попытка за одно видео все рассказать и несколько субмурно.
Привет. Не знаю, читаешь ли ты коммы под старыми видео, но все же напишу. 1) Спасибо за такое подробное и качественное видео. Внедрил Zenject в свой проект, параллельно пересмотрел видео несколько раз, чтобы полностью разобраться. Все очень емко и по делу 👍 2) Столкнулся со следующей проблемой: когда перезагружаю сцену с помощью SceneManager.LoadScene в поля инджектится непонятно что. Rider только показывает MissingReferenceException. Он же выбрасывается в консоль при попытке обращения к такому полю. Почему это происходит и можно ли как-то это исправить (без переноса в Project Context)? Заранее благодарю 🙏
Привет, спасибо, все читаю и практически на все отвечаю) MissingReferenceException и NullReferenceException, кстати, разные вещи и рекомендую почитать по поводу этого А так, проблема похожа на то, что со статикой ты где-то не доглядел. Она после смены сцен, скажем, не "перезагружается"
@@NightTrainCode не-не как раз таки статику я вообще не использую (все по заветам Сакутина). Для понимания: у меня в игре всего одна сцена, которую нужно перезагружать в конце каждого раунда. Протестировал сейчас на переносе одного независимого класса в ProjectContext, и вроде как это решает проблему. Но при перезагрузке все созданные из SceneContext объекты и так переносятся в DontDestroyOnLoad и, видимо, заново не создаются. Поэтому хотелось бы понять как это вообще работает. Про ексепшены - спасибо, почитаю про это)
Привет, как решить такую ситуацию. У меня есть объект ui который я создаю из префаб в runtime и в него внедряется зависимость, у которой есть события на который я подписываютсь в OnEnable и отписываюсь в OnDisable, но проблема в том что Zenject не успевает внедрять зависимость в метод конструктор из за чего когда я начинаю подписку выдаёт ошибку. Подскажи пожалуйста как это можно решить?
@@NightTrainCode Я так и делаю, но проблема в том что zenject сначала инстанциирует объект через юнити instantiate после чего юнити вызывает Awake, Start, OnEnable а уже после чего сам zenject внедряет зависимости.
Правильно ли я понимаю что Zenject юзают только для начальной установки зависимостей, а если мне в процессе игры нужно будет дать игроку автомат, вместо пистолета(который забинжен и заинжектен при старте сцены в псевдоконструкторе), то я просто в коде с помощью псевдоконструктора ставлю этот самый автомат?
А какая разница между NonLazy и QueueForInject? И для меня стало печально, что нельзя заинжектить без наследования от монобеха, по крайней мере я так и не выкупил как это сделать через создание экземпляра и конструктор
Не думаю, что в нём есть смысл, так как суть абсолютно такая же Просто в инициализаторе ECS вместо SerializeField с пробрасыванием ссылки в инспекторе пишешь атрибут Inject. Далее systems.Inject(класс, который внедрил);
Cпасибо за видео, очень полезный материал, так как документация ограмна, хотелось бы знать самые распространенные биндинги или базу того что будет чаще всего использоваться. Но остались вопросы касательно QueueForInject, не понятно что значит внедряет компонент при запуске, префаб ведь и так создается экземпляр из забинженного класса прокидывается, в документации тоже не особо понял. И на счет BindInterfacesTo и BindInterfacesAndSelfTo если в биндинге просто указать интерфейс как в примере, то выдаст ошибку.
QueueForInject в основном используется для тех классов, что уже есть на сцене и внедрение произойдет сразу после фазы установки А чтобы BindInterfaces заработали, надо будет так же прописать, например, FromInstance и AsSingle
Смотрю что у тебя, что у K-syndicate сначала инстанцируете игрока, потом его биндите в контейнер. Я так делаю, мне зенжект ворнинг выдает, что так делать не желательно. Я хочу например UI на другой сцене сделать, где мне нужно игрока взять, и не могу т.к. он на другой сцене. Мне посоветовали через контракт имен сделать, я сделал мне зенжект говорит что я не могу инжекты раскинуть т.к. ты преварительно не байндишь игрока, а создаешь его. Чет муть какая-то этот ваш зенжект. Либо я слушать не умею, либо не понимаю. Я еще не понимаю что вы под сервивами подразумеваете - как пример приводят InputService - но зачем там что-то шаманить, когда есть Input system, который сам разные реализации под разные системы. У меня после всех роликов такая каша в голове образовалась, я вообще без понятия как этим всем пользоваться (
Как ужасно сделано приближение в видео при вводе полей. Неуспеваешь осознать куда тыкнул в одном месте уже экран увеличивается в другом месте ставь паузу и делай покадровку назад. И так по кругу пока не соединишь воедино, что показывалось в двух местах на коротком промежутке времени. Также мучает вопрос... если это подробный урок, то почему многие вещи Zenject лишь упоминаются и никак не поясняются зачем они.
@@NightTrainCode в общем пришел к тому, что сделал референс для контейнера, и объекты которые спавнит миро в авэйке через референс контейнером инжектю. Хз насколько это норм...
@@nuciesto6917 Spawn Request'ов на сцене очень много, это точка, а которой заспавнится один конкретный юнит и инжектить каждый ну никак не получится 😄 Запихивать туда контейнер, как сделал я на видео - нелогично. Ему резонно находиться только в какой-то фабрике
@@NightTrainCode эту проблему можно решить, путем создания спец монобеха в котором будут хранится нужные данные о юните в данной точке. Создать поле в моноинсталлере игры, в которой будет массив этих спец монобехов, и этот массив биндить и в конструкторе спавнера получать. По моему вполне реальное решение
@@nuciesto6917 Реквест хранит ссылку на заготовленный и полностью настроенный префаб юнита. Также реквест самостоятельная вещь, которая в эвэйке реплейсит себя с префабом юнита и удаляется. Зачем их инжектить? Это просто какие-то точки для спавна конкретного, заготовленного противника. Я часто добавляю новые / меняю их / удаляю, расставляя противников по карте + На сцене много разоичных зон, юниты должны спавниться в основном только тогда, когда мы в неё заходим. На всех сценах их количество разное. Не вижу смысла применять здесь Zenject, только лишняя трата времени, так как инициализировать ничего не нужно раньше эвейка, да и пробрасывать зависимости тоже
@@nuciesto6917 Можно и через отдельный класс, ни от чего не наследованный юзать, просто вопрос уже встаёт о том, насколько это удобно будет. Если каждому вручную прописывать position в виде Vector3, то это выстрел в ногу сразу 😆 Да и вообще видос не об этом) А про то, как что-то зарегистрировать и внедрить Ну и как спавнить, чтобы атрибуты [Inject] не игнорировались 😉
Все что я понял, ты усложняешь код, но практической пользы я не вижу) Вместо 3 скриптов для персонажа ходьба, стрельба, жизни. Ты используешь 18319283 скриптов, в итоге трата времени, а игра с меньшим шансом увидит свет) Вместо 3 месяцев на весь код игры, уйдет пару лет)
Почитай про первый принцип SOLID и ради интереса смысл ECS, где тонны компонентов и системок на каждый чих, а этот паттерн всё больше набирает обороты Zenject - для того, чтобы забыть про нулл рефы из-за инициализаций в хрен пойми какой момент времени и головных болей с прокидываниями ссылок в инспекторе А разбиение на компоненты - для лёгкой читаемости кода, универсальности и гибкости в использовании. А также для лёгкого переиспользования в будущем Конечно, можно всё в один GameControllerManagerHandler запихать и наслаждаться одним скриптом) + в Rider недолго нажать Alt + Enter, чтобы вынести что-то в отдельный компонент
@@NightTrainCode причет тут один стрипт. Без всех этих хитростей хуитростей, можно писать модулями. Скрипт на стрельбу. Который будет работать и у врагов и у персонажа. Скрипт на движение, жизни и тд. Чтобы не делать помойку в коде и нужно ООП. Но люди хуярют PlayerScripts для всех механик связанных с персонажем и говорят ООП гавно.
@@SCEEFnight Train Code использует zenject неправильно, вот и кажется что херня получается, но можно сделать как ты и сказал писать модулями но на много проще
Так я не понял, сколько лет ты уже кодишь? Проблема статиков это не в очистки а как раз в то почему мы используем инжекторы -> глобальные переменные делает код менее понятным так как нет нормальной передачи того или иного класса Автор не понимает что делает и не умеет подать материал, для него zenject это не инжектор)
А ну у него и ответ в конце для чего zenject, решает проблемы синглтонов) Да автор не только про это говорит, и про забразсывания зависимостях, только автор понимает что это позволяет делать Расскажу в сущности для чего используется инжекторы. 1) У нас есть файл с конфигом проекта, при использования Zenject это installer, и то что мы используем интерфейсы мы можем очень просто менять их реализации только в конфиге, что позволяет не трогать код) 2) Решает проблемы с глобальной видимости -> синглтон антипатерн который делает код вредным и его использование это плохо, как раз вместо синглтонов которые обычно используем, мы делаем обычные классы и перекидываем 3) позволяет быть уверенным что до любого кода какой то сервис точно дойдет, а если сломается мы знаем где)
Вообще что я тут искал, искал гайд по тулу с его фишками, а получил непонятный ролик, для новичков слишком сложно будет понять это, для стариков быдет фейспалм
Тема хорошая, но автору лучше не снимать обучающие ролики - ну нет у него таланта объяснять что-то. Так ужасно раскрыть тему это еще нужно умудриться. То что на видео автор играет - уже само по себе отвлекает. Большой минус. Далее, слишком скомканные объяснения, автор куда-то торопится, не приводит примеров, прыгает то туда, то сюда. Такое впечатление что сам себе объясняет. Но автор может и знает, но тот кто не знает - ничего не поймет.
Слишком быстро обьясняешь, тот же код еще ускоряешь Я хочу вместе с обьяснением смотреть код, а выходит так что ты уже след класс делаешь. Да могу паузить, но я тогда не буду слушать паралельно
Как зарегистрировать префабы без создания объектов префабов? В дальнейшем буду создавать уже объекты через фабрику. Есть вот такой код с условными префабами заклинаний. Но при создании объекта зарегистрированного префаба ([Inject] private Fireball _fireball, например) получаю NullRef. Что я делаю не так? Подскажите, пожалуйста using UnityEngine; using Zenject; public class SpellsInstaller : MonoInstaller { [SerializeField] private Fireball _fireball; [SerializeField] private IceBlade _iceBlade; [SerializeField] private LightningBall _lightningBall; public override void InstallBindings() { Container.Bind().FromComponentInNewPrefab(_fireball).AsSingle().NonLazy(); Container.Bind().FromComponentInNewPrefab(_iceBlade).AsSingle().NonLazy(); Container.Bind().FromComponentInNewPrefab(_lightningBall).AsSingle().NonLazy(); Container.Bind().AsSingle(); } }
А можешь пожалуйста сделать по VContainer`у?Сейчас он назывется так и сделан как раз тем чуваком, который ушёл из Zenject`a. Говорят, что VContainer невероятно быстр и крут. Туторов по сети вообще нету практически, а те, что есть, просто ужасны.
АВТОР РОЛИКА НЕ ПОЗОРЬСЯ, ЕСЛИ ТЫ НЕ ШАРИШЬ ЗА API UNITY ТО НЕ НУЖНО ПОКАЗЫВАТЬ ПРИМЕР НА КОНСОЛЬНОМ ПРОЕКТЕ ТАК ЭТОТ ПРИМЕР НЕ ТОЖЕ САМОЕ ЧТО В РЕАЛЬНОМ ПРОЕКТЕ UNITY. В UNITY НЕЛЬЗЯ СОЗДАВАТЬ НОВЫЙ ЭКЗЕМПЛЯР КЛАССА И ПЕРЕДОВАТЬ ССЫЛКУ ЭТОГО ЭКЗЕМПЛЯРА, КАК В КОНСОЛЬНОМ ПРОЕКТЕ.
Пишем это. А потом пишем это. Смотрите как красиво у меня на сцене :) Если не понятно, не бойтесь, потом будет понятно. Видео заканчивается.
я тоже ждал того момента когда станет понятно и понял что после слово потом видео закончилось 🤣
😂😂😂
Хочу кое что сказать начинающим разработчикам, которые включили это видео. Посмотрите первый раз - да, возможно вы многое не поймете. Отдохните. Поизучайте документацию, или как я, поспрашивайте у GPT различные реальные примеры реализации Zenject. Посмотрите второй раз - вы увидите, что начинаете понимать, что к чему. Посмотрите третий раз - и вот вы уже в полном понимании происходящего.
Спасибо за ролик, капитан!
уже раз 10 посмотрел, кучу видосов ру и англ посмотрел, и нифига не понятно как с ним работать, в глобально плане понятно что он удобен, но как его использовать хз, в каких ситуациях? сделал как по туториалу, а мне пишет предупреждение зенжект, мол плохая идея так делать(( документация на мудренном написана(( дня 4 уже убил(( да написал игру которая работает на зенжект и решает все проблемы, но там 1 вариант решения, в основном биндим обычные классы, а как забиндить префаб игрока которого нет на сцене, который нужно создать как то, внутри префаба игрока допустим в классе Player есть псевдоконструктор который инжектит доступ к обычным классам забиндженным в инсталлере((
@@nickwilde5876 почитай про фабрики, там написано как инжектить в создаваемые в рантайме объекты, он и в этом ролике про это говорил
На какое бы обучающее видео я не знашёл, везде пишут "начинающим разработчикам".
Я: Начинаю учиться кодить.
Челы: "Начинающий разработчик".
Я: Написал свою первую игру.
Челы: "Начинающий разработчик".
Я: Сделал резюме и выучил основные паттерны, начинаю углубляться в более сложное проектирование.
Челы: "Начинающий разработчик".
Я: Устроился в компанию Junior-ом, уже даже не стажёр.
Челы: "Начинающий разработчик".
Мне кажется, у челов в принципе будет до самого конца мнение, что если он смог освоить что-то (даже не паттерн, а правило проектирования KISS, например)) ), то все, кто ещё этого не знают (или просто не слышали формулировку) - начинающие. Ору с самомнения))
@@Miketo_Sanso ну не зная DI из начинающий ты не вылезешь, а джуном будет очень тяжело устроиться
Как же часто я возвращаюсь на этот канал, ибо, чаще всего, поиск того, что мне нужно в данный момент, ведет, чуть ли не первой ссылкой в ютубе - сюда :D
Как раз препод наругал меня за то, что я слишком часто использую статику и свой "псевдосинглтон", и что пора бы уже задуматься об изучении Зенжекта и использовать пул, забыв о моем обычном Destroy :DDD (надо будет поглядеть ролик про Night pool)
Благодарю за чудесный контент)) Даже не смотря на то, что приходится часто жамкать паузу и прослушивать некоторые моменты несколько раз, чтобы пережевать информацию мозгом - ролики эти бесценны!..
Большое спасибо, очень приятно)
К моим ассетам в идеале читать документацию на GitHub, так как их я частенько обновляю, а ролики, к сожалению, нет
У меня есть классный синглтон на гитхабе. Пул и прочее тоже там, можешь код поизучать. Документация везде написана
красавчик.
Всё просто и понятно.
И почему твой канал я раньше не находил.
Спасибо)
Ну, чудеса случаются ахах
Вряд ли я в скором времени воспользуюсь такой штукой, но для общего развития будет оч неплохо)
Спасибо за видос
На здоровье)
Можно обойтись и синглтоном, но грамотным. У Сакутина есть видос про синглтон. Там, пожалуй, самая нормальная реализация, что я видел
Нереально выручил!!
Задолбался искать почему инъекция не проходит. (13:50)
Спасибо тебе огромное!
На здоровье)
Вау, супер! Всё чётко рассказано, и как раз то, что я искал!
Друг ты спас меня с спавном юнитов через контейнер, если бы когда то не посмотрел твое видео, не догадался бы в чем дело и не посмотрел у тебя решения
Всегда пожалуйста! 🔥
Я что, перестаю быть джуном?
Охренеть конечно. Вообще не удивлён, ибо на самообучении такую инфу не нуйдёшь, а без опыта работы в компании тем более, но тут нашёл, спасибо огромное!
Даже один концепт того что можно создать стек фреймворков для такой красивой реализации и убрать все NullRef`ы меня радует.
Я прям типичный пример самоучки - документация Юнити, GPT, гайды с Ютуба, работаем.
Результат - FindObjectOfType как единственное решение, которое заработало, но и проблем насыпало, а кто ж знал? В моём виденьи - в гайдах юзают, оно работает, вроде норм, чёт автоматизирую, подправлю под свои нужды и норм.
А оказывается можно и так. И мне нравится, это офигенный подход, но всю прелесть подобного решения такой как я может почувствовать только пройдя через говнокод.
Как считаете, надо ли проходить через период говнокода? Типа, в начале обучения даже говнокодить надо научиться, что бы хоть что-то создать рабочее, инфы больше, чем за 5 лет школьной программы по ощущениям. Мне нравится, но не дропнул потому что был опыт в том же DaVinchi, желание постигать сложное и ещё куча факторов.
Или пример с модовой террарией. Есть Ванилла с сундуками, в которых ничего не найдёшь, а пока рассортируешь красиво уйдёт 20 часов. А есть TModLoader, в котором MagicStorage даёт возможность искать айтем по тегу. Будешь ли ты ценить второе без опыта первого? Сложный вопрос. Сразу в голову приходит воспитание ребёнка. Давать ли ему то чего не было у тебя просто так и тем самым убрать потребность достигать того же стейта, когда ты не паришься о деньгах и можешь создавать что хочешь, но с риском того что он не будет хотеть ничего делать.
Либо же равномерно из грязи в князи вести, но с поправками?
Представьте как будет выглядеть обучение:
Язык (от 1 месяца до 3 месяцев, в зависимости от подхода к обучению и обучаемости).
Немного теории, IDE, Фреймворки, библиотеки (именно что они из себя представляют). Стек фреймворков обязательно сказать.
Unity (что само по себе огромный стек информации. Спустя полгода работы в нём я всё ещё мальком себя ощущаю).
И ко всему ещё другие фреймворки, облегчающие работу, безусловно, но и количество информации растёт конкретно.
Я ещё Draw.IO пару дней тестил и учил, дабы можно было учиться более наглядно и проектировать хотя бы базовое представление взаимодействия логики.
GPT тоже правильно вопросы надо ставить, дабы получать именно тот результат который нужен (будьте честны, рядовой пользователь ПК не умеет гуглить, что подводит к следующему пункту)
Умение искать информацию и скилл увидеть то что тебе нужно. У меня этот скилл наверное самый важный, он в принципе личность можен поменять, что думаете?
Ну и ещё бы хотел отметить умение менеджить время для такой работы, все же знают это ощущение когда процесс прям прёт, достигаешь безумного прогресса, а потом после столкновения с одной банальной ошибкой хернёй страдаешь и не заходить в проект неделю? У меня так было.
Многое применимо к любой профессии, но в программировании лично у меня больше проблем было, нежели в том же монтаже, пусть и не очень сложном. Мемы, переходы, базовые эффекты, что в прочем тоже при первом знакомстве может вводить в ступор. Например когда я подруге говорил о концепции секвенций в редакторе (по сути кусок видео на таймлайне) она не могла вдуплить. Когда показал даже не вдуплила.
Сразу выказываю уважение тем учителям, которые всё это понимают и умеют объяснить любому любую информацию.
Так что ещё раз спасибо! Удачи каждому кто дочитал жо конца :D
ты перестанешь быть джуном тогда когда сможешь создавать собственные удобные и полезные фреймворки 😎
@@Bushido_Cat Челы на позициях Senior, которые ни одного фреймворка не написали: Аааа... Ну, пойду, начальству скажу, чтобы мне платили не 250к, а 50, как нашим джунам, спасибо гению из интернета, глаза открыл!)
Я - без опыта работы, все время на самообучении, и чтобы ПОПАСТЬ на позицию джуна учу Dependency injection.
- Челы рядом, пытаясь найти те же знания: ООО, я уже не джун!)
Пздц, мы реально в разных мирах живём, или что это за бред?)))
гениальное видео, спасибо автору
Самое топовое объяснение
Спасибо! Наверное пригодится позже, а пока позалипал в твою игруху, мне она заходит)))
Ахах, на здоровье и спасибо)
спасибо большое, реально помог
На здоровье)
Очень полезный материал. Но все же нжект в поля это как-то грязновато. Получается кто-то из вне знает внутреннюю реализацию объекта к которому не относится? Вариант с псевдо конструктором куда как чище и аккуратнее. Но это тема для холивара, а на него времени нет, код писать надо !)))) з.ы. Да и как-то ты очень быстро пропаровозил тему фабрик, а это довольно важная часть возможностей иньекций.
Отличные темы на канале раскрываются! Что ECS, что DI, крайне полезно)
На работе тоже используем Zenject, но при первом взаимодействии мне там рассказали меньше, чем в этом видео!)
Привет, спасибо) Рад, что видосы помогают 😎
На работе точно никуда без Zenject'а, даже если делать прототип или Hello World 🤣
Блин, спасибо тебе самое большое. Самое понятное объяснение
Самое большое на здоровье)
Классное видео, честно. Вообще странно даже, что подписчиков у автора не так много )
Большое спасибо)
Пока нет видосов на широкую аудиторию, а в основном для тех, кто уже шарит или хочет шарить
Но, думаю, будущие видосы и время всё залечат)
Лул)
Для синглтона можно реализовать очень простую и незамысловатую конструкцию в getter, он тебе при первом общении создаёт объект, если его нет. Или префаб... Сути не меняет, синглтон, это не только инициализация в Start или Awake.
Так же не забываем про C# синглтон, можно юзать его даже без monoBeh-а
Про синглтон много можно придумать реализаций, а эта самая геморная. И не понятно для чего оно нужно, если честно 😅
Возможно подойдет тому, кто не умеет строить зависимости
Начал нормально объяснять, а когда дело коснулось кода, то "пиши это" без объяснения почему. Придется более подробно где-то в другом месте читать про все то, что ты там написал, чтобы переделать это под свой проект
Каким образом интерфейсы разорвали зависимости? С таким же успехом можно было сделать базовый класс Weapon и от него наследников. Пистолеты и шотганы..
Спасибо за видео! Я получил отличное представление по Zenject. Ещё ты сказал очень интересную фразу: что статические поля и свойства остаются после перехода между сценами. И теперь я понимаю почему статику критикуют при неумелом использовании. Если я правильно понял, то статические классы так-же остаются в оперативной памяти при переходе между сценами?
Привет, на здоровье, рад, что тебе пришло осознание Zenject'а и статики)
Да, статика на то и статика. Ещё есть интересная штучка - статический конструктор. В следующем видео я про него немного расскажу, надеюсь, до конца февраля его выпущу
@@NightTrainCode Спасибо за ответ! Рад узнать что ты готовишь новое видео! Успехов в этом :)
@@VADIM-SOLOV Спасибо большое)
Да давно готовлю (руки не доходили всё) и ютуб я забрасывать не собираюсь, канал только обороты набирает как раз
Спасибо за видос. Можно ли где-то найти исходники игры, показанной в видео? Мне удобней разбираться глядя в код, чем слушая объяснение.
Привет, спасибо за данный урок.
Но есть несколько вопросиков, ты говоришь что не стоит использовать повсюду интерфейсы, что их надо юзать когда есть больше чем 1 реализация, но что на счет интерфейсов - маркеров ?
Так же можно было дать совет новичкам о принципе Interface Segregation который гласит разделять интерфейсы на маленькие сущности да бы наследник не был вынужден наследовать то что ему не надо, но это так к слову
А что такое интерфейс-маркер?
срочно пояснительную бригаду, тут кому-то стало непонятно))) 16:12 Инсталер для ГО? Но там же есть какой-то пустой список для ГО и для СО в зенжекте?
Ты лучший
спасибо за видос! Очень подробно всё описано!
Вот только мне всё-равно не понятно(
12:42 "теперь вместо беспокойства о прокидывании зависимостей с каждой сцены, что очень неудобно, ешё можно просто забыть это сделать можно использовать зенжект" (в котором нужно будет дописать инициализацию чего-то, и добавив на сцену доп объект, в который таки надо будет прокинуть ссылку на то, на что "в начале мысли" мы могли забыть прокинуть ссылку ?
Некоторое время назад мне не нравились события и подписка на них, а сейчас норм, втянулся)) Надеюсь функционал зенжекта и то, как его использовать до меня тоже дойдёт)
Гайд крутой, но когда смотришь в первый раз, слишком уж быстро для нормального восприятия. Автору удачи в развитии канала.
А ты книгу когда хочешь прочитать, пролистываешь картинки и если не нравятся, не читаешь?)
@@ruslan_yefimov А ты когда видео смотришь, тоже каждую секунду на паузу ставишь, не успевая послушать, что сказал автор, и увидеть, что он написал, из-за чего перепросмотры видео увеличиваются раз в 5? (А автор коммента написал про первый просмотр)
Умойся, клоун
вопрос, что лучше(ну или что вы чаще используете), интерфейсы или абстрактные классы? например, оружие можно реализовать через интерфейс, а можно через абстрактный класс.
Избавляемся от зависимостей добавляя зависимости, гениально (нет)
Очень круто объяснил, без воды, четко!
Есть вопрос по DiContainerRef, который ты вписал в какой то класс с методом InstantiateIntoExistingPool(..). Это метод класса Zenject? Идея понятна,- так будут инжектиться поля в каждом созданном объекте в пуле. Но сам DiContainerRef - статика, а это уже несколько грязный прием.. Впрочем, DiContainer итак всегда один, так что зачет)
Спасибо :)
На здоровье
пока нихрена не понятно)) это можно использовать для любых типов игр и даже для мобилок?
А почему нет?
Очень интересный ролик. Я использую Zen. но ... , на пример я использую инсталлеры просто вешая их на обэкты , твой вариант намного интереснее - вешая их все в пустой обджект. Было бы ооочень интересно посмотреть туториал по структуре проекта на примере игры, или просто обзор твоей игры ., я находил только начальные туториалы по zen, а что дальше "разберитесь сами", Если тебе будет интересно сделать туториал по "сложной" игре =) 🙏
cool) thanks)
Что мешает сделать bootstrap и поочерёдно инициализировать синглтоны?
Как-будто это единственная проблема которую решает Zenject, да ещё и к тому же он замедляет код.
Не совсем понял, что делает "QueueForInject".
Можно немного разжевать?
И еще такой вопрос назрел:
Например, у меня "MononInstaller", который хранит в себе +100500 префабов, инстансы которых будут передаваться в виде инъекций.
Я правильно понимаю, что все эти префабы хранятся в памяти как полноценные объекты?
Если да, то можно ли как-то выгрузить этот "MononInstaller" после использования, что бы не занимал память или вообще убить "SceneContext"?
И третий вопрос:
Таже проблема с памятью, но для "ProjectContext".
QueueForInject в основном используется для тех классов, что уже есть на сцене и внедрение произойдет сразу после фазы установки
Нет, это ссылочные типы. А если на сцену все +100500 добавишь, то прощай оперативка и всё остальное)
@@NightTrainCode
"QueueForInject" оговаривается, что экземпляр инъектируется при запуске. А без него разве не при завпуске?
Container.Bind.......; --- теперь если кто-то попросит у зенжекта "SomeClass", то он будет предоставлен.
Container.QueueForInject(SomeClassInstance); --- класс по прежнему предоставляется, что изменилось не понятно...
Хорошее видео. Но тема очень сложная для понимания. Если раскрывать, то одним простым видосом не отделаться )))
Я рекомендую начинать с другого видео ruclips.net/video/IS2YUIb_w_M/видео.html (там есть целый плейлист)
IMHO Здесь же попытка за одно видео все рассказать и несколько субмурно.
Spasibo ()
Привет. Не знаю, читаешь ли ты коммы под старыми видео, но все же напишу.
1) Спасибо за такое подробное и качественное видео. Внедрил Zenject в свой проект, параллельно пересмотрел видео несколько раз, чтобы полностью разобраться. Все очень емко и по делу 👍
2) Столкнулся со следующей проблемой: когда перезагружаю сцену с помощью SceneManager.LoadScene в поля инджектится непонятно что. Rider только показывает MissingReferenceException. Он же выбрасывается в консоль при попытке обращения к такому полю. Почему это происходит и можно ли как-то это исправить (без переноса в Project Context)? Заранее благодарю 🙏
Привет, спасибо, все читаю и практически на все отвечаю)
MissingReferenceException и NullReferenceException, кстати, разные вещи и рекомендую почитать по поводу этого
А так, проблема похожа на то, что со статикой ты где-то не доглядел. Она после смены сцен, скажем, не "перезагружается"
@@NightTrainCode не-не как раз таки статику я вообще не использую (все по заветам Сакутина).
Для понимания: у меня в игре всего одна сцена, которую нужно перезагружать в конце каждого раунда.
Протестировал сейчас на переносе одного независимого класса в ProjectContext, и вроде как это решает проблему. Но при перезагрузке все созданные из SceneContext объекты и так переносятся в DontDestroyOnLoad и, видимо, заново не создаются. Поэтому хотелось бы понять как это вообще работает.
Про ексепшены - спасибо, почитаю про это)
годнота
Привет, как решить такую ситуацию. У меня есть объект ui который я создаю из префаб в runtime и в него внедряется зависимость, у которой есть события на который я подписываютсь в OnEnable и отписываюсь в OnDisable, но проблема в том что Zenject не успевает внедрять зависимость в метод конструктор из за чего когда я начинаю подписку выдаёт ошибку. Подскажи пожалуйста как это можно решить?
Префаб нужно спавнить через DiContainer, а не через Instantiate
@@NightTrainCode Я так и делаю, но проблема в том что zenject сначала инстанциирует объект через юнити instantiate после чего юнити вызывает Awake, Start, OnEnable а уже после чего сам zenject внедряет зависимости.
Правильно ли я понимаю что Zenject юзают только для начальной установки зависимостей, а если мне в процессе игры нужно будет дать игроку автомат, вместо пистолета(который забинжен и заинжектен при старте сцены в псевдоконструкторе), то я просто в коде с помощью псевдоконструктора ставлю этот самый автомат?
Проще такие вещи не заносить глубоко в код, а хранить в SO, либо в сериализованном поле
@@NightTrainCode Понял, спасибо за ответ.
А какая разница между NonLazy и QueueForInject?
И для меня стало печально, что нельзя заинжектить без наследования от монобеха, по крайней мере я так и не выкупил как это сделать через создание экземпляра и конструктор
Будет очень интересен ролик про совмещение ecs и zenject
Не думаю, что в нём есть смысл, так как суть абсолютно такая же
Просто в инициализаторе ECS вместо SerializeField с пробрасыванием ссылки в инспекторе пишешь атрибут Inject. Далее systems.Inject(класс, который внедрил);
Спасибо за гайд)
что за игра на фоне?
Cпасибо за видео, очень полезный материал, так как документация ограмна, хотелось бы знать самые распространенные биндинги или базу того что будет чаще всего использоваться. Но остались вопросы касательно QueueForInject, не понятно что значит внедряет компонент при запуске, префаб ведь и так создается экземпляр из забинженного класса прокидывается, в документации тоже не особо понял. И на счет
BindInterfacesTo и BindInterfacesAndSelfTo если в биндинге просто указать интерфейс как в примере, то выдаст ошибку.
QueueForInject в основном используется для тех классов, что уже есть на сцене и внедрение произойдет сразу после фазы установки
А чтобы BindInterfaces заработали, надо будет так же прописать, например, FromInstance и AsSingle
The type or namespace name 'PlayerUnit' could not be found
?
Слишком сжато, во второй половине вообще мало чего понятно.
Я сам программист, но очень сжато, перескок туда-сюда и нету приложенных примеров кода.
По zenject хватает материала, а вот по vcontainer ничего нету :(
Смотрю что у тебя, что у K-syndicate сначала инстанцируете игрока, потом его биндите в контейнер. Я так делаю, мне зенжект ворнинг выдает, что так делать не желательно. Я хочу например UI на другой сцене сделать, где мне нужно игрока взять, и не могу т.к. он на другой сцене. Мне посоветовали через контракт имен сделать, я сделал мне зенжект говорит что я не могу инжекты раскинуть т.к. ты преварительно не байндишь игрока, а создаешь его.
Чет муть какая-то этот ваш зенжект. Либо я слушать не умею, либо не понимаю.
Я еще не понимаю что вы под сервивами подразумеваете - как пример приводят InputService - но зачем там что-то шаманить, когда есть Input system, который сам разные реализации под разные системы.
У меня после всех роликов такая каша в голове образовалась, я вообще без понятия как этим всем пользоваться (
Как ужасно сделано приближение в видео при вводе полей. Неуспеваешь осознать куда тыкнул в одном месте уже экран увеличивается в другом месте ставь паузу и делай покадровку назад. И так по кругу пока не соединишь воедино, что показывалось в двух местах на коротком промежутке времени.
Также мучает вопрос... если это подробный урок, то почему многие вещи Zenject лишь упоминаются и никак не поясняются зачем они.
FIND OBJECT OF TYPE FOREVER
Что это за игра на видео?
Мой пет проект. Ещё не вышел)
@@NightTrainCode Круто! Очень круто выглядит!🔥 Обожаю игры где много природы и ничего лишнего!) Очень классно выглядит, я бы в такую игру поиграл)
@@NightTrainCode успехов в проектировании ✊
@@NightTrainCode а что такое пет?
@@bogdan9423 Спасибо, рад слышать!)
Хз, чет меня напрягает, что надо инстанс закидывать в сцене.
Его можно закинуть так, как тебе удобно
Об'ясніть мені що таке sealed class. Що це за клас
Модифікатор sealed забороняє успадкування чи перевизначення
@@NightTrainCode Дякую
@@domiurk На здоров'я
@@NightTrainCode ти з України(чи переводчиком користуєшся)
@@domiurk Я из России, але Украинську розумию трохи
Пытался подружить миррор с зенджектом. Це пэзда....
Ох
@@NightTrainCode в общем пришел к тому, что сделал референс для контейнера, и объекты которые спавнит миро в авэйке через референс контейнером инжектю. Хз насколько это норм...
Мне не нравится ваша реализация спавна,по моему лучше spawnrequest, сразу делать в бинд и убрать наследование от монобеха
А данные перекидывать через например класс data вложенный в spawnrequest
@@nuciesto6917 Spawn Request'ов на сцене очень много, это точка, а которой заспавнится один конкретный юнит и инжектить каждый ну никак не получится 😄
Запихивать туда контейнер, как сделал я на видео - нелогично. Ему резонно находиться только в какой-то фабрике
@@NightTrainCode эту проблему можно решить, путем создания спец монобеха в котором будут хранится нужные данные о юните в данной точке. Создать поле в моноинсталлере игры, в которой будет массив этих спец монобехов, и этот массив биндить и в конструкторе спавнера получать. По моему вполне реальное решение
@@nuciesto6917 Реквест хранит ссылку на заготовленный и полностью настроенный префаб юнита. Также реквест самостоятельная вещь, которая в эвэйке реплейсит себя с префабом юнита и удаляется. Зачем их инжектить? Это просто какие-то точки для спавна конкретного, заготовленного противника. Я часто добавляю новые / меняю их / удаляю, расставляя противников по карте
+ На сцене много разоичных зон, юниты должны спавниться в основном только тогда, когда мы в неё заходим. На всех сценах их количество разное. Не вижу смысла применять здесь Zenject, только лишняя трата времени, так как инициализировать ничего не нужно раньше эвейка, да и пробрасывать зависимости тоже
@@nuciesto6917 Можно и через отдельный класс, ни от чего не наследованный юзать, просто вопрос уже встаёт о том, насколько это удобно будет. Если каждому вручную прописывать position в виде Vector3, то это выстрел в ногу сразу 😆
Да и вообще видос не об этом)
А про то, как что-то зарегистрировать и внедрить
Ну и как спавнить, чтобы атрибуты [Inject] не игнорировались 😉
Все что я понял, ты усложняешь код, но практической пользы я не вижу) Вместо 3 скриптов для персонажа ходьба, стрельба, жизни. Ты используешь 18319283 скриптов, в итоге трата времени, а игра с меньшим шансом увидит свет) Вместо 3 месяцев на весь код игры, уйдет пару лет)
Почитай про первый принцип SOLID и ради интереса смысл ECS, где тонны компонентов и системок на каждый чих, а этот паттерн всё больше набирает обороты
Zenject - для того, чтобы забыть про нулл рефы из-за инициализаций в хрен пойми какой момент времени и головных болей с прокидываниями ссылок в инспекторе
А разбиение на компоненты - для лёгкой читаемости кода, универсальности и гибкости в использовании. А также для лёгкого переиспользования в будущем
Конечно, можно всё в один GameControllerManagerHandler запихать и наслаждаться одним скриптом)
+ в Rider недолго нажать Alt + Enter, чтобы вынести что-то в отдельный компонент
Лично мне zenject сэкономил массу времени и сил
@@NightTrainCode причет тут один стрипт. Без всех этих хитростей хуитростей, можно писать модулями. Скрипт на стрельбу. Который будет работать и у врагов и у персонажа. Скрипт на движение, жизни и тд. Чтобы не делать помойку в коде и нужно ООП. Но люди хуярют PlayerScripts для всех механик связанных с персонажем и говорят ООП гавно.
@@SCEEFnight Train Code использует zenject неправильно, вот и кажется что херня получается, но можно сделать как ты и сказал писать модулями но на много проще
Ну судя по тому что коммент начинается со слов "Всё что я понял...", ты не особо далеко в геймдеве продвинулся)
Так я не понял, сколько лет ты уже кодишь?
Проблема статиков это не в очистки а как раз в то почему мы используем инжекторы -> глобальные переменные делает код менее понятным так как нет нормальной передачи того или иного класса
Автор не понимает что делает и не умеет подать материал, для него zenject это не инжектор)
А ну у него и ответ в конце для чего zenject, решает проблемы синглтонов)
Да автор не только про это говорит, и про забразсывания зависимостях, только автор понимает что это позволяет делать
Расскажу в сущности для чего используется инжекторы.
1) У нас есть файл с конфигом проекта, при использования Zenject это installer, и то что мы используем интерфейсы мы можем очень просто менять их реализации только в конфиге, что позволяет не трогать код)
2) Решает проблемы с глобальной видимости -> синглтон антипатерн который делает код вредным и его использование это плохо, как раз вместо синглтонов которые обычно используем, мы делаем обычные классы и перекидываем
3) позволяет быть уверенным что до любого кода какой то сервис точно дойдет, а если сломается мы знаем где)
Вообще что я тут искал, искал гайд по тулу с его фишками, а получил непонятный ролик, для новичков слишком сложно будет понять это, для стариков быдет фейспалм
Тема хорошая, но автору лучше не снимать обучающие ролики - ну нет у него таланта объяснять что-то. Так ужасно раскрыть тему это еще нужно умудриться. То что на видео автор играет - уже само по себе отвлекает. Большой минус. Далее, слишком скомканные объяснения, автор куда-то торопится, не приводит примеров, прыгает то туда, то сюда. Такое впечатление что сам себе объясняет. Но автор может и знает, но тот кто не знает - ничего не поймет.
Как скажешь)
Слишком быстро обьясняешь, тот же код еще ускоряешь
Я хочу вместе с обьяснением смотреть код, а выходит так что ты уже след класс делаешь.
Да могу паузить, но я тогда не буду слушать паралельно
Ставь скорость видео на 0.8 и норм
Как зарегистрировать префабы без создания объектов префабов? В дальнейшем буду создавать уже объекты через фабрику.
Есть вот такой код с условными префабами заклинаний. Но при создании объекта зарегистрированного префаба ([Inject] private Fireball _fireball, например) получаю NullRef. Что я делаю не так? Подскажите, пожалуйста
using UnityEngine;
using Zenject;
public class SpellsInstaller : MonoInstaller
{
[SerializeField] private Fireball _fireball;
[SerializeField] private IceBlade _iceBlade;
[SerializeField] private LightningBall _lightningBall;
public override void InstallBindings()
{
Container.Bind().FromComponentInNewPrefab(_fireball).AsSingle().NonLazy();
Container.Bind().FromComponentInNewPrefab(_iceBlade).AsSingle().NonLazy();
Container.Bind().FromComponentInNewPrefab(_lightningBall).AsSingle().NonLazy();
Container.Bind().AsSingle();
}
}
Ссылка на Zenject для слабаков, согласен с автором))
Ничего не понятно, от слова ничего.
17 минут неработающей воды. Мне надо подключить сервис через интерфейс. Твоим способом в конце видео он не подключается.
А можешь пожалуйста сделать по VContainer`у?Сейчас он назывется так и сделан как раз тем чуваком, который ушёл из Zenject`a. Говорят, что VContainer невероятно быстр и крут. Туторов по сети вообще нету практически, а те, что есть, просто ужасны.
Да, урок будет)
АВТОР РОЛИКА НЕ ПОЗОРЬСЯ, ЕСЛИ ТЫ НЕ ШАРИШЬ ЗА API UNITY ТО НЕ НУЖНО ПОКАЗЫВАТЬ ПРИМЕР НА КОНСОЛЬНОМ ПРОЕКТЕ ТАК ЭТОТ ПРИМЕР НЕ ТОЖЕ САМОЕ ЧТО В РЕАЛЬНОМ ПРОЕКТЕ UNITY. В UNITY НЕЛЬЗЯ СОЗДАВАТЬ НОВЫЙ ЭКЗЕМПЛЯР КЛАССА И ПЕРЕДОВАТЬ ССЫЛКУ ЭТОГО ЭКЗЕМПЛЯРА, КАК В КОНСОЛЬНОМ ПРОЕКТЕ.
ЛАДНО.