Jetpack Compose - будущее Android UI и убийца Fragment

  Рет қаралды 37,969

Android Broadcast. Все об Андроид разработке

Android Broadcast. Все об Андроид разработке

Күн бұрын

Пікірлер: 220
@AndroidBroadcast
@AndroidBroadcast 3 жыл бұрын
🔗 Avito.Tech avito.tech/ 💰 Поддержать проект на Boosty bit.ly/3sratqQ или Patreon patreon.com/android_broadcast 🔗 Telegram канал "Android Broadcast" ttttt.me/android_broadcast
@НадяБондаренко-ъ3э
@НадяБондаренко-ъ3э 3 жыл бұрын
0ке
@vladk3524
@vladk3524 3 жыл бұрын
Дождался) Жду гайдов. Особенно интересно как анимировать все. Спасибо!
@AndroidBroadcast
@AndroidBroadcast 3 жыл бұрын
Часть анимаций была значительно упрощена, но вот жду появления MotionLayout для Compose.
@maksonic_official
@maksonic_official 3 жыл бұрын
@@AndroidBroadcast во во) это была моя первая мысль, что будет с моушн лейаут, ведь штука годная!
@AndroidBroadcast
@AndroidBroadcast 3 жыл бұрын
@@maksonic_official Основная ее ценность - визуальный редактор анимаций. Без него библиотека просто еще один способ работы с анимацией в Android
@maksonic_official
@maksonic_official 3 жыл бұрын
@@AndroidBroadcast я всегда моушн сцену создавал через xml, точнее описывал поведение анимации, через дизайн только смотрел как анимация работает) не знал что и через дизайн можно создавать анимации) в любом случае motion layout очень полезная вещь!
@alexandersafonov3350
@alexandersafonov3350 3 жыл бұрын
Комментарий в поддержку канала Поставил в своём проетке api 21 (повысил с 16 версии) и теперь пробую Compose для простых экранов, пока что очень нравится.
@AndroidBroadcast
@AndroidBroadcast 3 жыл бұрын
Потом и уходить не захочется!
@DmitryY-t8o
@DmitryY-t8o 15 күн бұрын
Jetpack Compose классный. мне нравится это изменение ;)
@ankudinova
@ankudinova 3 жыл бұрын
очень интересно, спасибо 🙏💕
@ch1pkavarenychenko84
@ch1pkavarenychenko84 3 жыл бұрын
как всегда отличная подача информации, ждём больше видео по композ🔥👍
@AndroidBroadcast
@AndroidBroadcast 3 жыл бұрын
Будет, только надо самому начать туда погружаться
@vasyavasya6823
@vasyavasya6823 3 жыл бұрын
Благодарю за отличный, современный контент !)
@SergSab12
@SergSab12 3 жыл бұрын
Через годик можно будет пробовать:)
@AndroidBroadcast
@AndroidBroadcast 3 жыл бұрын
Можно уже смело тянуть в прод
@robin839168
@robin839168 3 жыл бұрын
Про Recycler мега круто
@AndroidBroadcast
@AndroidBroadcast 3 жыл бұрын
Там не всё так радужно, но самая обычная реализация делается в разы быстрее
@dmytromarchuk3023
@dmytromarchuk3023 3 жыл бұрын
Отличнейшее видео. Кратко, по сути. Идеально. Спасибо!
@st.libertos
@st.libertos 3 жыл бұрын
Открыл для себя ваш канал, всё круто!
@AndroidBroadcast
@AndroidBroadcast 3 жыл бұрын
Как нашел? Знакомые, реклама или поиск ?
@st.libertos
@st.libertos 3 жыл бұрын
Просто рекомендации. Как раз учил фрагменты (я новачок) и тут "Убийца Fragment" 👍
@ОлегТимофеев-щ3ш
@ОлегТимофеев-щ3ш 3 жыл бұрын
Так то xml это максимальная декларативность - там надо потрудится чтобы всунуть императив. Пример с каунтером как я понял так же "устанавливает атрибуту text тек значение каунтера" или это не изменение стейта, а своего рода связывание? То что из коробки можно прям в ide "тестить" представление в связке с логикой(обработки событий) скорее всего останется невостребованной так как это тестирование сломается на первом же обращении к серверу или каком то композите который включает в себя чуть больше чем 1 текстовое поле и 2 кнопки. разрабы чаще всего будут продолжать "экономить" на создании инструментов тестирования разрабатываемого функционала чтобы при разработке можно было в несколько инструкций создавать фейковые состояния для проверки своего представления(под разные разрешения, с в разных позициях и прочее)... Кто вот прям сейчас работая в "паттерне" mvvm мешает создать тестовый билдер для подделки контракта viewmodel и проверить в досконально все интересующие вариации рендеринга разрабатываемой view? При этом технической проблемы в этом нет - сама студия как раз отлично этим пользуется для первичного превью при создании так надоевшего xml. Так же никто не мешает прям сейчас сделать фейковые реализации всяких репозиториев и прочего DAL, с удобным API первичной инициализации оптимизированного под удобную инициализацию тестовыми данными. Это даст возможность не переходя на специальные технологии оттестить в изолированном окружении вьюху вместе с состоянием презентационного слоя(view + viewmodel). те самые щелчки на + и -, только не прям из idea, а запустив разрабатываемое activity в фейковыми зависимостями. Но полагаю что все эти возможности остаются только в виде потенциальных из-за "экономии". ведь зачем писать лишний код, его же надо поддерживать, а у нас не такое сложное приложение, и времени на это нет - нам бы очередную фичу запилить нащелкивая в ui и в лучшем случае постоянно подкручивая заглушки в какой нить WireMock, SoapUI или своего очень обобщённого велосипеда
@ПавелЗубко-ц8ч
@ПавелЗубко-ц8ч 3 жыл бұрын
Спасибо за выпуск . Очень жду видео про него
@beginnercoding1089
@beginnercoding1089 3 жыл бұрын
Кирилл, благодарю за качественный контент! Не могу понять почему у Вас так мало просмотров. У Вас отличные видео. Продолжайте в том же духе)
@AndroidBroadcast
@AndroidBroadcast 3 жыл бұрын
Малая ниша, поэтому всегда будет так. Со временем придут новые и просмотры вырастут. Спасибо за поддержку
@vitalyzolkin5046
@vitalyzolkin5046 3 жыл бұрын
На новом проекте начали использовать Compose. Это можно сравнить как пересесть с Java на Kotlin. Прикольные анимации можно делать в 100 строк кода )
@AndroidBroadcast
@AndroidBroadcast 3 жыл бұрын
100 строк я считаю много. Хочется компактнее, хотя зависит от сложности хореографии элементов
@vitalyzolkin5046
@vitalyzolkin5046 3 жыл бұрын
@@AndroidBroadcast возможно можно будет оптимизировать, но все равно гораздо проще чем по старинке ☺️
@rewegate
@rewegate 3 жыл бұрын
А что с Flutter? Пишу на нем больше года, все устраивает кроме запоздалых обновлений UI виджетов. С выходом Compose задумался, стоит ли полностью перейти с Flutter на него. Flutter - тоже проект Гугла, получается некая конкуренция внутри компании. Есть страх, что Flutter закроют и сосредоточатся на Compose. Есть мысли на этот счёт?
@AndroidBroadcast
@AndroidBroadcast 3 жыл бұрын
Jetpck Compose - решение чисто для Android. Compose Multiplatform делает JetBrains и вот это уже угроза Flutter
@atamyratbabayev9295
@atamyratbabayev9295 3 жыл бұрын
Мне кажется, что Flutter в ближайшем времени закрывать не собираются, почитайте про фуксию (если фуксия, как система будет жива) . Также у Flutter быстрорастущая комьюнити, так как Dart имеет низкий порог входа, в принципе как и у Flutter. Кроме того, Flutter активно развивается, да достаточно полазить на их канале.
@AndroidBroadcast
@AndroidBroadcast 3 жыл бұрын
Flutter уже занял свои нишу и растет. Будущее точно есть, но какой объем узнаем только ты будущем
@illyaevseev312
@illyaevseev312 3 жыл бұрын
Видео зацепило названием. Хоть сразу и было понятно, что у этого убийцы пока силенок маловато что бы просто заменить все, что уже есть, но все-же любопытство взяло верх. Лично мне Compose импонирует. Даже несмотря на все имеющиеся косяки на сегодняшний день. Да и простота того же lazyColumn подкупает. И на простых примерах все работает отлично. Но как часто мы сталкивается с простыми случаями? Обычно это ежик с id-шниками, в который входят другие ежики со своими зависимостями и все это нужно динамически подгружать. И хорошо если с бэкэндом все замечательно. А если нет? И вот тут уже простой пример вдруг превращается в не очень-то и понятного монстра. И, заметьте, это не самый сложный случай.
@backoff6776
@backoff6776 Жыл бұрын
1. Ежик с IDшками ушел в туман с распостранением ViewBinding. 2. От чего помимо Presenter, или VM еще должен быть зависим ежик с ID-шками? Если на практике у вас имплементация БЭ влияет на View - возможно, вам стоит освежить в памяти SOLID.
@illyaevseev312
@illyaevseev312 Жыл бұрын
@@backoff6776 Вы абсолютно ничего не поняли. Давайте на примере. Вам нужно показать список фирм-клиентов. Для каждой фирмы дополнительно нужно отображать менеджера со стороны компании и менеджера компании помимо других полей. Так же для каждого из менеджеров нужно получить его состояние на SIP сервере и аватар. Т.е. у клиента есть managerId, а у менеджера есть avatarId. Пользователь приложения в настройках указывает какие поля нужно отображать и в каком порядке для каждого из типов фирм-клиентов. И теперь самое вкусное. Фирм-клиентов десятки тысяч. Как несложно понять загрузить все на телефон это отельная непростая задача. Поэтому это сразу отпадает. Только тотальная динамическая подгрузка маленькими порциями в зависимости от того, что отображается в конкретный момент времени. Любое изменение тут-же приводит к перестроению списка. И если все сделать по-простому, то анимация хорошо если вообще когда-то закончится. А ведь есть еще поиск и фильтрация. Как без них если элементов много? И по хорошему нужно не просто показать то, что нашел, а как-то выделить текст из-за которого сейчас каждый из элементов отображается.
@backoff6776
@backoff6776 Жыл бұрын
​@@illyaevseev312 , окей, допустим. Не понял, как это: "отображать менеджера со стороны компании и менеджера компании". Я не большой спец в классификации менеджеров. Это очепятка, или два разных человека?) Исходя из задачи, у меня будет несколько задействованных Getaway: - REST сервер - SIP сервер - SPrefs 1. Fragment подписывается на VM. Вот здесь момент: мой это проект, или коммерческий? Если коммерческий - ViewModel будет содержать LiveData, который будет излучать полный(на текущий момент) список клиентов, который с помощью DiffUtils будет скармливаться адаптеру. Так бысттрее. Если это мой проект - я буду играться с обновлением списка сам, т.к. мне не нравится идея сравнивать изменения внутри вью. Во фрагменте к списку прикручена прослушка scrollLIstener. Когда позиция N становится видимой - Fragment дергает вью-модель: loadNext(). Упустим обработку ошибки, лоадера. В VM есть соответствующие LiveData и фрагмент на них подписан. Все. Помимо VM никаких других зависимостей у фрагмента нет. Ну может быть еще фрагмент контейнера, если мы используем SharedLiveData для передачи внешнего VM вложенным вьюшкам. 2. VM имеет зависимость от UseCase(или Repository, или где мы там Bussines Logic обрабатываем), возможно каких-нибудь мапперов и прочей вспомагательной мишуры. В loadClients VM запускает соответстующий UseCase(допустим, у нас UseCase-ы), меняет свое состояние и подписывается на результат. 3. Use case идет на SIPGateway, потом параллельно на REST и в SPrefs. Полученные результаты агрегируются в соответствующий DTO и отправляются, как результат, в обсервер, переданный View-моделью. 4. Вью модель получает опповещение о новой порции данных и обновляет LiveData. Fragment получает новый список и отдает его в адаптер через DiffUtil. Список обновляется. По тому же принципу через соответствующие UseCase ViewModel подписывается на изменения на стороне SIP сервера и изменения настроек в SPrefs. При получении оповещения от них, LiveData так же обновляется, adapter рендерит соответствующий ViewHolder в зависимости от настроек и усттанавливает состояние клиента на SIP сервере. Вроде все. Тут задача скорее объемная, чем сложная. Ах да и аватарка грузиться каким-нибудь Glide, или Picasso. Вот тут возникает та же архитектурная лажа, что c DiffUtil(а именно запрос изображения самой на стороне View, ее кеширование, обработка результата и т.д. в обход бизнесс логики приложения), но опять же.. это реалии дроид разработки. В пет-проекте, я бы отказался от Glide, или пробовал бы использовать его в Geteway, но в коммерческой разработке поступил бы стандартно. Вроде все. Fragment не зависит не от чего кроме VM и утилит типа Glide, DiffUtil, данные во вью обновляются ViewBinding.. Никаких ежиков. Никакихлишних зависимостей кроме вышеупомянутых библиотек. Вроде все. Где я неправ?
@illyaevseev312
@illyaevseev312 Жыл бұрын
@@backoff6776 Ну не поняли о чем я хотел сказать так не поняли.
@backoff6776
@backoff6776 Жыл бұрын
@@illyaevseev312 , ну да. Видимо я что-то не понял в указанном примере. Потому собсно я и спросил: "где я неправ?". Не вижу связи между описанной задачей и необходимостью клепать елки из ID-шек, или скармливать множество зависимостей фрагменту(активности). ID-шки останутся под капотом ViewBinder, а вью будет зависима только от ViewModel, утилит и, возможно внешней вью-модели контейнера. Какая бы крививая не была реализация БЭ, все необходимые костыли будут спрятаны в реализации Gateway, за фасадом и вью слою будет вообще на них плевать. Сложность агрегирования ответтов от разных серверов и синхронизации запросов будет инкапсулирована в UseCase и тоже закрыта за фасадом: OutPort. В чем собсно беда, которую я не учел?
@heroachilles
@heroachilles 3 жыл бұрын
Очень интересный контент! Спасибо.
@dmitriymitroshin7525
@dmitriymitroshin7525 3 жыл бұрын
Спасибо большое. Интересно, что там с диалогами и ботомшитами.
@AndroidBroadcast
@AndroidBroadcast 3 жыл бұрын
BottomSheet уже поддерживает из коробки, как и диалоги
@pavlosoia
@pavlosoia 3 жыл бұрын
так что, компоуз функции таки с большой буквы писать?
@AndroidBroadcast
@AndroidBroadcast 3 жыл бұрын
Да
@vladislavm2447
@vladislavm2447 2 жыл бұрын
Спасибо за ваши видео Кирилл - интересно\полезно! Может подскажете - какой ни будь (лучше какие то) хороший средне\большой проект с открытым исходным кодом где вью на Compose. Очень интересно как влияет на архитектуру, какую делают структуру каталогов… Также если бы было с удовольствием посмотрел бы видео с разбором
@AndroidBroadcast
@AndroidBroadcast 2 жыл бұрын
Стандартные примеры Compose. Ещё посмотри TiVi
@vladislavm2447
@vladislavm2447 2 жыл бұрын
Спасибо! просмотрю@@AndroidBroadcast
@Espanamia
@Espanamia 3 жыл бұрын
спасибо, лайк!
@ilyaponomarenko5354
@ilyaponomarenko5354 3 жыл бұрын
Отличный выпуск! Спасибо :)
@AndroidBroadcast
@AndroidBroadcast 3 жыл бұрын
И вам спасибо, что не прошли мимо и оставили комментарий
@ВиталийЗарубин-ц3я
@ВиталийЗарубин-ц3я 3 жыл бұрын
Супер. Спасибо!
@ГеоргийГ-р2н
@ГеоргийГ-р2н 3 жыл бұрын
28 июля произошло 2 великих события - я родился и вышел stable jetpack compose
@ВладыкаВселенной-х8т
@ВладыкаВселенной-х8т 2 жыл бұрын
если я правильно понял то котлин это просто "обёртка" для явы? код на котлине преобразуется в код на яве и выполняется? нафига оно надо, не проще ли без посредников обойтись..
@AndroidBroadcast
@AndroidBroadcast 2 жыл бұрын
Не так.Java и Kotlin компилируются в байт-код, только kapt генериь Java классы для совместимости с Java Annotation Processing
@luckystrike91
@luckystrike91 3 жыл бұрын
меня очень сильно смущает все эти магические аннотации в котлине... да сам по себе view очень жирный класс, но зато я в любой момент могу открыть исходники и понять , что там и как работает. это касается и короутин. не нравится мне эта тенденция... в любом случае кастомные вью писать надо будет всегда, и насколько легко (и вообще возможно ли??) это сделать на компоуз? очень много вопросов.
@dmitriismirnov6769
@dmitriismirnov6769 3 жыл бұрын
в любой момент открыть исходники и изучить 30000 строк вью и наследников с делегатами по цепочке?)) а насчёт кастом вью Кирилл упомянул - все стало только проще
@luckystrike91
@luckystrike91 3 жыл бұрын
@@dmitriismirnov6769 да, приходилось не раз ковырять исходники когда кастомные вью писал. конечно прям изучить в любой момент не получится, но в иде найти методы, которые тебе нужны и посмотреть логику достаточно легко. чего не скажешь о компиляторе и куче вспомогательных костылей вокруг него.
@AndroidBroadcast
@AndroidBroadcast 3 жыл бұрын
Даже сейчас можно посмотреть и увидеть как рисуются компоненты, фактически от нас спрятали механизм обновления UI в зависимости от состояния
@СергейПанов-з3ц
@СергейПанов-з3ц 3 жыл бұрын
Что по кнопке платного комментария? Почему на твоём канале её нет? Хочется протестировать её на твоём канале. Про бусти, патреоны знаю, но я хочу кнопку.
@AndroidBroadcast
@AndroidBroadcast 3 жыл бұрын
Я не могу включить монетизацию, так как Google не присылает мне письмо с проверкой физического адреса. Так что грустно ( Да и комиссия там конская - 30% + за вывод. Хочешь поддержать - воспользуйся donate.stream/android_broadcast
@ВадимСорокин-х4е
@ВадимСорокин-х4е 3 жыл бұрын
Здравствуйте! Очень странный вопрос, а где Вы нашли этот флажок Котлин, который на заднем плане?))
@AndroidBroadcast
@AndroidBroadcast 3 жыл бұрын
Его раздавала JB как мерч свои Kotlin User Groupd и на конференциях давали
@deadchannal
@deadchannal 3 жыл бұрын
Круто!
@bolnoi8
@bolnoi8 3 жыл бұрын
Как по мне, компоуз ещё сыроват, хотя на реддите говорят что уже используют в продакшене. Список строится круто (Про repeat, кстати, не знал, делал через for), но когда я его трогал мне показалось, что он подлагивал. Из плюшек - стики хидер из коробки. Ну и теперь нам нужна новая архитектура, новые подходы, новый способ взаимодействия с DI фреймворками, нужен ли нам теперь ViewModel в принципе и т.д.
@AndroidBroadcast
@AndroidBroadcast 3 жыл бұрын
В первых Beta было ещё не очень, но стал лучше к релизу
@AndroidBroadcast
@AndroidBroadcast 3 жыл бұрын
MVVM вполне жизнеспособен
@miralirafiyev4646
@miralirafiyev4646 3 жыл бұрын
На мой взгляд слишком похожий на react Composable - это компонент который рисует ui Можно пасавать пропсы между компонентами У каждого компонента свой стейт или общий у родителя Ну блин язык Kotlin а дальше react =) Круто, и автору огромное спасибо!
@AndroidBroadcast
@AndroidBroadcast 3 жыл бұрын
Это общее движение разработки UI в приложениях, поэтому и языки адаптируются. Как и фреймворки. Задача языка - позволять эффективно решать задачи разработчиков на нем
@Andoctorey
@Andoctorey 3 жыл бұрын
Спасибо! 🔥
@renatkhakimov5378
@renatkhakimov5378 3 жыл бұрын
Спасибо большое за работу, благодаря Вам в первую очередь обратил внимание на android. Написал первое приложения на классическом view, если так можно выразиться. Подскажите, если не затруднит, извините заранее за возможно нубский вопрос. На compose уже можно смело писать приложения для android ? Я имею ввиду нет ли проблем корректной работой compose с другими инструментами экосистемы Аndroid, или может есть подводные камни ? Из видео мне лично показалось, что это уже по настоящему production решение.
@AndroidBroadcast
@AndroidBroadcast 3 жыл бұрын
Костяк инструментов работает без проблем, но есть то что может отставать по продвинутым возможностя. Если вы только начинаете, я рекомендую вам разобраться в старой системе и потом уже браться за новую, но просто потрогать точно стоит чтобы увидеть как поменялась система. P.S. надеюсь вы рады своему выбору Android
@renatkhakimov5378
@renatkhakimov5378 3 жыл бұрын
Кирилл, спасибо большое за ответ
@renatkhakimov5378
@renatkhakimov5378 3 жыл бұрын
Да, android класс, хорошо, что увидел ваш канал, приложение под andoid я писал быстрее, чем для ios. Экосистема android мне показалось более понятной и понравилась больше. Еще больше мне нравится идея фулстека, но пока делать решил упор больше на какую-то одну платформу)
@AndroidBroadcast
@AndroidBroadcast 3 жыл бұрын
Верно. На старте надо окрепнуть в одной технологии и уже затем смотреть по сторонам. Так и проще будет разбираться, особенно если первой технологией получится зарабатывать на жизнь
@Polite_person_
@Polite_person_ Жыл бұрын
С момента выхода видео прошло немало времени, что думаешь о компоуз сейчас? На сколько он стал востребован, на сколько стал стабильнее и много ли проблем еще нужно решить? По моим личным опросам, кто-то пробует переписывать отдельные экраны на него, но никто не стартует с ним с нуля. Создается ощущения что сейчас в 2023 он еще сыроват, а все хотят стабильности, и судя по вакансиям спроса на эту технологию на рынке практически нет, но всем интересно.
@AndroidBroadcast
@AndroidBroadcast Жыл бұрын
Все стало лучше, много приложений написали с нуля, а другие перешли. Программисты с кривыми руками всегда жалуются и не хотят ничего не учить
@Polite_person_
@Polite_person_ Жыл бұрын
​@@AndroidBroadcast Думаю да, многие не хотят перестраиваться и много староверов с джавой, которых не загонишь на компоуз. И конечно тонны приложений уже готовых нужно поддерживать.
@zaur4094
@zaur4094 Жыл бұрын
@@Polite_person_ а зачем переписывать с Java если все работает, DI настроен, чистая архитектура грамотно спроектирована? Все приложение оттестировано вдоль и поперек, таски выполняются.... Никакое руководство не даст времени и старт на переписывание. Я в продуктовой компании, вот какие аргументы для менеджера и тех директора предоставить?)
@Polite_person_
@Polite_person_ Жыл бұрын
@@zaur4094 Я имел ввиду, что есть кто до сих пор стартует на Java.
@coffemilk652
@coffemilk652 2 жыл бұрын
У меня вопрос насчет существующего приложения, хотелось бы новые экраны уже описывать компосом, прочитал что есть MdcTheme, вопрос как долго он будет существовать и поддерживаться? У нас проект крупный, и быстро перевести все невозможно
@AndroidBroadcast
@AndroidBroadcast 2 жыл бұрын
Думаю достаточно пока актуальна View, а это ещё долгие годы
@Bleser022
@Bleser022 3 жыл бұрын
А чего так редко зум меняется? Сделал бы изменение зума каждую секунду.
@AndroidBroadcast
@AndroidBroadcast 3 жыл бұрын
Я был молод и неопытен, не судите строго ведь я не профессионал съемки и монтажа
@d.mertsalov
@d.mertsalov 3 жыл бұрын
Спасибо!
@ВладимирВованович-к3ч
@ВладимирВованович-к3ч Жыл бұрын
Как я понял compose актуален для тех, кто массово разрабатывает прилы на аутсорсе (скорость разработки). А если я работаю над одним проектом, какой в нем смысл?
@AndroidBroadcast
@AndroidBroadcast Жыл бұрын
Вам не важна скорость разработки даже для одного проекта? Вопрос в том что за единицу времени вы доставите больше фичей пользователю
@АлексейРодионов-ы8о
@АлексейРодионов-ы8о 3 жыл бұрын
Большое спасибо за овервью
@malchikovma
@malchikovma 3 жыл бұрын
Вот будет реализация под ios, тогда и поговорим про кроссплатформенность.
@AndroidBroadcast
@AndroidBroadcast 3 жыл бұрын
Зачем думать о Compose только как мультиплатформенном решение для iOS и Android? К SwiftUI те же требования?
@dmitrymukhin9050
@dmitrymukhin9050 3 жыл бұрын
Все еще нужно достаточно много RAM для нормальной работы превью (на моем стареньком маке так и не запустилось)
@AndroidBroadcast
@AndroidBroadcast 3 жыл бұрын
Да, жду Mac на ARM и вкачать туда 32 гига оперативывы
@sergey30027
@sergey30027 3 жыл бұрын
надеюсь виджеты будут добавлять так же как команда флаттера
@AndroidBroadcast
@AndroidBroadcast 3 жыл бұрын
В Roadmap поддержка Material You и виджетов один из основных пунктов
@igoryazovtsev942
@igoryazovtsev942 3 жыл бұрын
Спасибо за видео :) Compose лучше использовать в новых проектах, а старые делать по старинке, иначе со временем будет каша
@RomanTokarenko
@RomanTokarenko 2 жыл бұрын
Если модульность занесена, можно новые фичи на композе пробовать писать
@1nCube
@1nCube 3 жыл бұрын
А нормальное кастом вью на нем реально сделать или нет?
@AndroidBroadcast
@AndroidBroadcast 3 жыл бұрын
Да, есть доступ к Canvas и обработки разных событий. Всё компоненты сейчас так сделаны
@ArtemSukhov-q5n
@ArtemSukhov-q5n 3 жыл бұрын
С realtime preview все очень плохо?
@AndroidBroadcast
@AndroidBroadcast 3 жыл бұрын
Что именно вы подразумеваете под этим? Интерактивные режим (можно нажимать на кнопки) или статический предпросмотр Compostable функций?
@AndroidBroadcast
@AndroidBroadcast 3 жыл бұрын
Я не поучаствовал проблем со статикой в превью, а вот интерактивный режим ещё требует доработки
@MS-xz4yk
@MS-xz4yk 2 жыл бұрын
молодец обзорчик зачетный
@johnsnow4108
@johnsnow4108 3 жыл бұрын
до начала 2021 года поддерживал минимальное апи 15, но позже понял, что смысла уже особого нету, надеюсь compose решит многие проблемы)
@AndroidBroadcast
@AndroidBroadcast 3 жыл бұрын
По статистике GP уже мало смысла имеет поддерживать что-то ниже 6.0
@voicetv9048
@voicetv9048 3 жыл бұрын
@@AndroidBroadcast Согласен, не думаю что остались люди использующие андроид
@ВладимирМонахов-в6у
@ВладимирМонахов-в6у 3 жыл бұрын
Спасибо
@putinstop5940
@putinstop5940 3 жыл бұрын
Но как нам теперь верстать сложные экраны? Закругленые вьюшки, зависимости вьюшек друг от друга,...
@AndroidBroadcast
@AndroidBroadcast 3 жыл бұрын
Все также есть различные Layout, можно реализовать собственный виджет через Compose, где будет своя отрисовка, обработка событий и прочее. Также можно сделать свой Layout
@putinstop5940
@putinstop5940 3 жыл бұрын
@@AndroidBroadcast ого супер, честно сказать я не нашёл расширенных туториалов, везде только и показывают как helloworld вбить, спасибо за ответ
@AndroidBroadcast
@AndroidBroadcast 3 жыл бұрын
На сайте Google много документации, примеры в GitHub, видео и Codelab
@putinstop5940
@putinstop5940 3 жыл бұрын
@@AndroidBroadcast спасибо, а как на счет паттренов проектирования? mvp mvvm с композом как работает? как вьюшки подписываются на viewModel? Я начал писать HelloWorld на компосе и уже ощутил всю силу и превосходства, но я себя чувствую утенком среди акул
@AndroidBroadcast
@AndroidBroadcast 3 жыл бұрын
@@putinstop5940 Надо просто освоиться с новой идеологией вокруг состояния и всё сойдется
@GarcianSmt
@GarcianSmt 3 жыл бұрын
Классный мерч!)
@AndroidBroadcast
@AndroidBroadcast 3 жыл бұрын
Жду не дождусь уже дать вам возможность заполучить его себе
@ДарьяНикифорова-с5х
@ДарьяНикифорова-с5х 2 жыл бұрын
познавательно)
@pavlosoia
@pavlosoia 3 жыл бұрын
как по мне, то еще рано в прод заводить компоуз. Может разве что какие-то отдельные скрины, но полностью пилить апку на компоузе я бы не рисковал прямо сейчас. Периодически мониторю примеры приложений на компоузе и очень всё неаккуратно написано. Нету каких-то красивых подходов. Потому подожду еще наверное годик, пока всё устаканится. А если в нынешнем виде так и останется, то уж лучше компоуз вообще не взлетел.
@AndroidBroadcast
@AndroidBroadcast 3 жыл бұрын
Какие критерии принятия решения в прод?
@pavlosoia
@pavlosoia 3 жыл бұрын
@@AndroidBroadcast как минимум сейчас не найдешь специалистов на рынке, которые уже умеют в компоуз. То есть уже надо людям дать время на изучение. Дальше - это всякие тулзы и апдейты. Я уверен, что хоть глобальных изменений в компоузе уже не будет, но всё же куча мелочей еще изменится. Ну и компоух хоть и релизнулся, но тот же констрейнт с ним еще не в релизе. Так что по моим планам - до следующего лета я на компоуз не перейду. PS. Попробовал немного компоуз в пет проекте - много вопросов по читабильности кода. В гитхабе смотришь примеры проектов и вообще не понимаешь что сверстано на экране. Приходится грузить проект и в студии в превью уже смотреть.
@shibabasensei6219
@shibabasensei6219 3 жыл бұрын
мы уже используем
@AndroidBroadcast
@AndroidBroadcast 3 жыл бұрын
Кто мы? Что за продукт и приложение?
@sergeyo.1512
@sergeyo.1512 3 жыл бұрын
Кажется что лучшим решением был бы flutter на kotlin , остальное в топку )
@SivkaDaBurka
@SivkaDaBurka 3 жыл бұрын
Почему же compose не нативный? На главной странице написано "Jetpack Compose is Android’s modern toolkit for building native UI."
@SivkaDaBurka
@SivkaDaBurka 3 жыл бұрын
Да и вообще что такое нативное? Для меня нативное - это то, что оптимизируется и затачивается под определенную платформу для большего быстродействия и стабильности. Т.е. флаттер не нативный, т.к. он про многоплатформенность и разработчикам приходится искать компромиссы. А вот компоуз вроде пока не лезет в другие платформы, значит затачивается чисто под андроид и является нативным. Или я не прав?
@AndroidBroadcast
@AndroidBroadcast 3 жыл бұрын
По мне нативный - это Android View, которые часть системы. Вот Compose повторяет их внешний вид и где-то расходится
@AndroidBroadcast
@AndroidBroadcast 3 жыл бұрын
Compose - официально мультиплатформенное решение, поддерживающее Desktop, Android, Web
@badadinfanti4553
@badadinfanti4553 3 жыл бұрын
Кирилл, ты же говорил, что больше не планируешь работать на дядю? А в этом видео сказал, что работаешь в Surf 🤨🤔
@AndroidBroadcast
@AndroidBroadcast 3 жыл бұрын
Я не планировал возвращаться работать в программирование. В Surf я занимаюсь тех. пиаром и это вынужденный компромисс из-за интересной задачи в компании для меня как специалиста по личному бренду, так и финансова сторона вопроса играет важную роль.
@show-xp4ct
@show-xp4ct 3 жыл бұрын
Очень плачевно что нет и не будет, скорей всего, поддержки для явы. Можешь сказать, что и "слава богу" =) но есть много людей, которые недолюбливают котлин, в их числе я. Поигрались с другом с компоусом - пока что сыровато, в большие проекты внедрять рановато, читается код, как по мне, непривычно. Время покажет. Огромное спасибо за контент! Много чего нового подчерпываю от тебя
@AndroidBroadcast
@AndroidBroadcast 3 жыл бұрын
Это эволюция. Одни технологии уходят, другие приходят им на замену. Вы можете придерживаться старых принципов, но рынок и выгода бизнеса помешают за вас. Вполне возможно, на работе вы пишите на Kotlin, потому что за Android разработку на Java уже не готовы платить, или не меняете работу, просто потому что "хочу быть на Java"
@МиколаБихкало
@МиколаБихкало 3 жыл бұрын
Очень сомнительная технология этот Compose. За его интеграцию в КММ однозначно лайк. Но есть много непонятного лично для меня. Хоть убей но ничего принципиально нового, кроме как асинхронщины в построении UI и новых не нативных + сырых View элементов я там не вижу. Точно так же как в Compose только без него и без HotReload можно было всегда строить экраны в коде. Разница лишь в кол-ве кода. Compose даёт удобные обёртки для этого. Убийца фрагментов ? Я наверно что-то не понимаю но фрагмент это не только кучка группированных вьюшек но ещё и масса логики в рамках конкретной задачи, которая задаёт алгоритм поведения для их всех. Поведение ведь так же нуждается в декомпозиции, разбиении на микрозадачи. Этот код нужно где-то прописывать. Как в Compose правильно прописать всю UI логику для "фрагмента" ? Я не пробовал Compose ещё но базируясь на первом впечатлении с обзоров - используя Compose мы просто начнём засирать код. Раньше у нас была отдельно вёрстка UI и отдельно UI логика (DataBinding не рассматриваем). А в Compose всё будет слито в один файл. Да, мы можем выносить общую логику в отдельные файлы но это не избавляет от увеличения кол-ва кода в файле Activity/Fragment. Про композитные View так же довольно сомнительно. ничто нам раньше не мешало сделать код аля viewBinding.root.addView( TextView(context).apply{ text = getString(R.id.some_text) //Other attrs... } ) Я в этом деле ещё не разбираюсь. Если написал что-то глупое - прошу меня простить. Просто есть масса вопросов ответы на которые нагуглить мешает моя лень программиста. А тут прям идеальное место, что бы найти их все разом в качестве ответа на мой комментарий.
@AndroidBroadcast
@AndroidBroadcast 3 жыл бұрын
Compose не имеет отношение к View и по другому всё отрисовывает. Никто не мешает вам также организовать отдельные Kotlin файлы и там делать только UI. Рекомендую попробовать и тогда поймёте в чём разница, если весь доклад воспринялся скепсисом
@jojomajo
@jojomajo 3 жыл бұрын
круть
@complexity7032
@complexity7032 Жыл бұрын
короче, коин юзаем для мелких проектов, хилт для среднего уровня сложности и даггер для огромных проектиков с сложной логикой и архитектурой
@AndroidBroadcast
@AndroidBroadcast Жыл бұрын
Для огромных Dagger - проблема из-за кодогенрации. Там ручной DI
@complexity7032
@complexity7032 Жыл бұрын
@@AndroidBroadcast понял, спасибо) кстати, то ли это ютуб баганул, то ли у меня что-то случилось, но коммент должен был быть в видео про DI(почему вы с Koina перешел на другую библиотеку).. странненько) а видос про компоуз в планах на сегодня был ахах. Но еще раз спасибо за ответ :))
@voicetv9048
@voicetv9048 Жыл бұрын
Обидно конечно,😌 не успеваешь выучить существующие подходы и технологии и БАТС новая технология, новые прицепы, другая архитектура и другие паттерны 😏
@AndroidBroadcast
@AndroidBroadcast Жыл бұрын
Программирование всегда было про то что постоянно надо учиться, расширять взгляды и применять новые популярные подходы
@voicetv9048
@voicetv9048 Жыл бұрын
@@AndroidBroadcast В этом то и дело что не успеваешь применять одного, появляется другой, получается тратишь время на так называемые deprecated features начать с новыми сложно, так как не хватает материала или они находятся в бета версия
@AndroidBroadcast
@AndroidBroadcast Жыл бұрын
Меняется все не так быстро, новые подходы внедряются постепенно, а такие технологии как Compose выходят редко, интегрируются неспешно и живут очень долго
@badadinfanti4553
@badadinfanti4553 3 жыл бұрын
Для меня кастом вью, о котором говорит Кирилл в этом видео - это что-то свое полностью нарисованное на канвасе. Таких вьюшек я очень много написал, довольно сложных (можно сказать, хобби у меня такое). Но я-то думал, что люди это и имеют в виду, и тоже удивился, что так много народу этим занимается. А когда узнал, что под кастомом больше понимается просто какие-то стандартные вью, сгруппированные под свои какие-то правила - ну это детский сад, а не кастом вью)
@МаксимВасин-я8ъ
@МаксимВасин-я8ъ 3 жыл бұрын
теоретически конечно эти сгруппированные вью тоже являются подвидом кастом вью, и у них есть название - Compound Controls, но если сравнивать по сложности разработки, да, компаунды на уровне детсада ;)
@AndroidBroadcast
@AndroidBroadcast 3 жыл бұрын
Мир Custom View огромен )
@МаксимВасин-я8ъ
@МаксимВасин-я8ъ 3 жыл бұрын
Кирилл, большое спасибо! К Compose присматривался давно, после просмотра этого видео сразу, вот прямо сейчас, опробую его в пет проекте. Есть, конечно, вопросы/сомнения, как это взлетит на сложных списках со множественными типами айтемов, а также придется еще перенастроить мозги в плане отказа от фрагментов (SingleActivity, Navigation), может ты уже опробовал на практике подобное решение?
@dmitriismirnov6769
@dmitriismirnov6769 3 жыл бұрын
Взлетит отлично - код станет проще и понятнее.
@AndroidBroadcast
@AndroidBroadcast 3 жыл бұрын
Я попробовал его немного, но планирую писать на нём полностью проект и показывать вам результаты
@SanyaNapalm
@SanyaNapalm 3 жыл бұрын
Я Fragments только пытаюсь осилить, а они уже устарели )))
@AndroidBroadcast
@AndroidBroadcast 3 жыл бұрын
Нет, они точно еще будут в разработке долго, так как они плотно осели в кодовой базе за 10 лет ) Больше чем RxJava даже, так что не переживайте. В новых приложениях подход начнет отмирать, но пока он живее всех живых!
@АнтонИцкович-х7у
@АнтонИцкович-х7у 3 жыл бұрын
Зачем ты ведёшь этот канал когда есть flutter...
@AndroidBroadcast
@AndroidBroadcast 3 жыл бұрын
Потому что Flutter мне не нравится и как видишь практически 8000 тыс людей тоже смотрят что я делаю
@АнтонИцкович-х7у
@АнтонИцкович-х7у 3 жыл бұрын
@@AndroidBroadcast сделай видео почему не нравится флаттер и почему тебе нравится ждать компиляцию 2мин и не нравится хотрелоад))
@AndroidBroadcast
@AndroidBroadcast 3 жыл бұрын
Раньше хватались декларативным UI и hot reload. Первое пропало. Что будете делать когда и второго не станет? Если разработка хватает тем что их приложение можно быстрее пересобрать, то что-то вы не то делаете
@triihart
@triihart 2 жыл бұрын
Compose выглядит уродливо, старый вариант по ощущениям лучше
@quverr
@quverr 3 жыл бұрын
Вы как-то не учли большие легаси проэкты где Java это за 60-80% кода и таких проектов очень много. Так что это совсем не "узкая категория"...
@AndroidBroadcast
@AndroidBroadcast 3 жыл бұрын
java проекты это вымирающие динозавры, которые застряли в прошлом из-за чего упорства или упрямства не хотят идти вперёд. Проекты на основе AOSP не считаются
@sanek1985t
@sanek1985t 3 жыл бұрын
@@AndroidBroadcast а как же телеграм? Отлично работает, руки растут у людей из правильного места
@AndroidBroadcast
@AndroidBroadcast 3 жыл бұрын
Это тоже исключение из правил. Самое обидное что разработчики Telegram отказываются пообщаться про свои технологии и рассказать почему так.
@sanek1985t
@sanek1985t 3 жыл бұрын
@@AndroidBroadcast попробуй найти Григория клюшникова, он разработчик ВК бывший и телеги. Я с ним общался. Может прольет свет. Но как мне показалось он сам по хардкору - бизнес логика во фрагментах итд. А ответ Я думаю простой - просто так быстрее разработать приложение. Если над ним работает 2-5 человек, то легко будет разобраться что к чему и не нужны все эти дополнительные слои абстракции, обертки, инфекции зависимостей итд - это по сути инфраструктура и она не имеет отношения к фичам. Иногда код в виде простыни реально легче и быстрее понять когда он в одном файле)
@AndroidBroadcast
@AndroidBroadcast 3 жыл бұрын
Гришу знаю по чатам. Он ярый писец только на Android SDK и никаких Jetpack. Тоже отказывается давать интервью. Но тут возможно я такой ещё человек что со мной говорить не хотят
@Chernov1984
@Chernov1984 3 жыл бұрын
+
@meseendev
@meseendev 3 жыл бұрын
Раздражает бешеный фанатизм. Раньше у нас был xml в котором мы декларировали , теперь делаем тоже в compose но чтобы увидеть изменения нужно билдить , просерать время ....
@AndroidBroadcast
@AndroidBroadcast 3 жыл бұрын
Даже с XML нужно было делатт, чтобы увидеть виджеты не из Android SDK. Compose - это не альтернатива XML. ,Это совсем другой принцип показа UI, но никто не мешает остаться на XML
@krokenstiv8777
@krokenstiv8777 3 жыл бұрын
flutter всех убьет
@ИгорьМакухин-к5д
@ИгорьМакухин-к5д 2 жыл бұрын
А мы за Java))
@ivankvych8182
@ivankvych8182 3 жыл бұрын
Спасибо за выпуск . Очень жду видео про него
@AndroidBroadcast
@AndroidBroadcast 3 жыл бұрын
Обязательно будут, а пока кинул все силы на восстановление моего голоса. Пока не могу записывать ролики вовсе
@PryankoBoy
@PryankoBoy 3 жыл бұрын
Спасибо!
@ramilskl
@ramilskl 3 жыл бұрын
Спасибо!
Зачем нужна многомодульная архитектура. Плюсы и минусы
10:59
Android Broadcast. Все об Андроид разработке
Рет қаралды 12 М.
На что способен Jetpack Compose, Алексей Гладков @MobileDeveloper
15:45
Android Broadcast. Все об Андроид разработке
Рет қаралды 17 М.
Каха и дочка
00:28
К-Media
Рет қаралды 3,4 МЛН
Леон киллер и Оля Полякова 😹
00:42
Канал Смеха
Рет қаралды 4,7 МЛН
Арыстанның айқасы, Тәуіржанның шайқасы!
25:51
QosLike / ҚосЛайк / Косылайық
Рет қаралды 700 М.
Google Play становится открытым | Новости мобильной разработки 2024.10
20:26
Android Broadcast. Все об Андроид разработке
Рет қаралды 3,9 М.
Full Guide to Jetpack Compose Effect Handlers
24:56
Philipp Lackner
Рет қаралды 100 М.
5 СЕКРЕТНЫХ преимуществ Android эмулятора которые вы не знали!
26:44
Android Broadcast. Все об Андроид разработке
Рет қаралды 4,8 М.
Image Caching with Coil Compose - Everything You Need to Know
21:28
Philipp Lackner
Рет қаралды 20 М.
Визитка программиста
19:40
Александр Красников
Рет қаралды 224 М.
Type-Safe Navigation with the OFFICIAL Compose Navigation Library
10:03