Oh, my Flutter
4.96K subscribers
1.18K photos
6 videos
1.11K links
Всё о Flutter-разработке. Новости, статьи, анонсы, вакансии и многое другое. Disclaimer: все публикуемое является частным мнением, свободно распростаняемой информацией, и не содержит рекламных интеграций.

Автор канала - Михаил Зотьев (@mbixjkee).
Download Telegram
Одним из вариантов E2E тестирования является тестирование роботом. При нем программно воспроизводятся различные варианты взаимодействия пользователя с приложением. Для реализации необходимо написать «классы-роботы», описывающие нужные действия. Во Flutter для этого можно использовать библиотеку flutter_driver, предоставляющую API тестирования приложений на реальных устройствах и эмуляторах.

📌 О том, как можно организовать робот тестирование вашего приложения, читайте в статье от Jorge Coca и Paulina Grigonis.

#статья
На днях состоялась церемония награждения Tagline Awards 2020-2021 — высшая российская награда за интерактивные проекты.

Сразу несколько приложений моих коллег из Surf получили в нем награды, в том числе и написанные на Flutter. К одному из них я тоже приложил свои ручонки 😃, но речь пойдет не про него, а про приложение Росбанк Бизнес. Чем же оно так примечательно:

👉 первое в России и второе в мире (бразильский Nubank вышел в релиз чуть раньше) банковское приложение на Flutter;
👉 это был вызов и смелое решение для Surf и Росбанка - на момент старта разработки, банков на Flutter не было;
👉 лучшее мобильное приложений в категории «Банки, финансы и страхование» по версии Tagline Awards 2020-2021.

О том, как же проходила разработка и с какими вызовами сталкивалась команда, пока делала Росбанк Бизнес, читайте в статье от Surf.

#статья
Уведомления - хороший способ взаимодействия с пользователем. C их помощью можно обратить внимание на что-то, вернуть в приложение. Нотификации в мобильных приложениях можно разделить на два типа:

👉 локальные;
👉 push-уведомления.

📌 Если вы захотите добавить в свое приложение локальные уведомления, то разобраться с нюансами поможет статья от tomerpacific.

#статья
А наша постоянная рубрика главных тем в мире Flutter за месяц продолжается, не смотря на то, что немного запоздала с майскими праздниками.

Итак апрель нам запомнится:
👉 конференцией Mobius;
👉 прошел митап КРОК и Лига Ставок;
👉 Tagline Awards 2020-2021 и Flutter приложения 💪;
👉 разрешена проблема с прекомпиляцией шейдеров на Metal.

Ну и конечно совсем не удивительно, что самый популярный пост месяца, уже упомянутый выше:
❤️ разрешена проблема с прекомпиляцией шейдеров на Metal.

#главное
Всем привет! Небольшой опрос, интересно ваше мнение. Я заметил, что бот с помощью которого я оформляю посты, не очень корректно работает с комментариями. Например, о февральских комментах мне пришло уведомление лишь на прошлой неделе. Да и в целом, функционал комментариев в этом боте не очень удобный. И мне хочется улучшить этот момент.

Из вариантов: не пользоваться ботом, но тогда поменяется формат постов — не будет реакций и удобных ссылок. Можно оставить бота, но не пользоваться его комментариями, а создать отдельный чат, в котором все желающие также смогут обсудить опубликованное и просто пообщаться.

Итак опрос:

1️⃣ оставить все как есть, комментарии мне все равно не нужны;
2️⃣ менять формат постинга, чтобы использовать комментарии Telegram;
3️⃣ оставить нынешний формат и создать чат для обсуждения.
Поле для ввода пин-кода в приложении может потребоваться во множестве случаев. Для легкого добавления в приложение такого поля можно использовать библиотеку flutter_pin_code_fields_package. С ее помощью можно:

👉 гибко настроить внешний вид;
👉 использовать скрытие вводимых символов;
👉 использовать предустановленные анимации для появления символов.

📌 Почитать подробнее про использование этой библиотеки можно в статье от Naveen Srivastava.

P.S. Спасибо за ответы на вчерашний опрос, в ближайшее время постараюсь опробовать новый формат.

#статья
Переключатели - важная часть пользовательского интерфейса. Они позволяют пользователю выставлять значения параметров, выбирая из 2 вариантов. Некоторые из переключателей имеют большую смысловую нагрузку, например смена тёмной и светлой темы, и их нужно выделить особенно. Для них можно реализовать нестандартную анимацию переключения. Или воспользоваться готовым решением - lite_rolling_switch. Эта библиотека позволяет использовать переключатели с анимацией перекатывания, а также имеет множество настроек кастомизации.

📌 Воспользоваться библиотекой можно по ссылке.
Сейчас во многих приложениях, которые хотя бы косвенно затрагивают социальное взаимодействие, имеются истории пользователей. Для реализации во Flutter существует библиотека story_view, которая включает:

👉 отображение истории в виде текста, изображений, gif и видео;
👉 добавление жестов для управления просмотром: предыдущая, следующая история, пауза;
👉 анимированный индикатор для каждой истории.

📌 Прочитать подробнее про использование библиотеки можно в статье от Shaiq khan.

#библиотека
Сейчас команда Flutter проводит второй ежеквартальный опрос. С их помощью разработчики собирают актуальный фидбек о работе фреймворка и выбирают направления развития.
В этот раз были в основном затронуты вопросы удовлетворенности самим фреймворком и окружением вокруг него.

📌 Вы можете лично поучаствовать в улучшении Flutter, пройдя опрос по ссылке.
Необычные механизмы взаимодействия с пользователем, могут добавить вашему приложению изюминку. Например круговое меню, появляющееся при нажатии на кнопку. Реализовать его можно с помощью плагина circular_menu. Добавленный виджет имеет различные настройки отображения и анимацию из коробки.

📌 Воспользоваться библиотекой можно по ссылке.

#библиотека
На днях в Твиттере Flutter появилось очередное весьма интересное видео, посвященное предстоящему Google IO.
Анонсы c подсказками спрятанными в видео входят в моду у Flutter команды, или просто совпадение?

#события
Команда Google опубликовала результаты опроса за первый квартал 2021 года.

В нем были собраны отзывы по темам:
👉 насколько разработчики удовлетворены работой Flutter и Dart;
👉 факторы, повлиявшие на выбор Flutter;
👉 популярные в комьюнити облачные сервисы.

📌 Ознакомиться с результатами опроса можно в статье.

#статья
Уже совсем немного времени осталось до начала Google IO 2021, одной из самых важных и интересных конференций в году, в том числе и для нас - мобильных разработчиков.

📌 Не пропустите трансляцию.

#события
Google IO идет полным ходом, и уже потихоньку появляются новости, которые касаются Flutter, хотя наша секция еще и не началась. Что же мы уже знаем:

👉 Flutter 2.2.0 в stable;
👉 многозначительное “Release notes are on their way pending some I/O announcements this week. Stay tuned!” в группе анонсов;
👉 интересный пример приложения под web на Flutter - фотобудка.

Ждем начала Flutter-секции и большего количества новинок.

#события
Google IO продолжается, и уже прошел первый день Flutter-секции. И если честно, то пока выглядит весьма скудненько. Похоже, что на Engage выбросили все новинки, а до IO особо ничего “вау” и не сделали. Среди того, что выделяет в важное сама Flutter команда:

👉 Flutter 2.2.0;
👉 NullSafety по умолчанию;
👉 улучшения для desktop;
👉 улучшения в DevTools;
👉 плагин для платежей;
👉 интеграции с различным сервисами Google.

📌 Узнать подробнее, можно в видео от Andrew Fitz Gibbon.

#события
Касаемо Dart появилось сразу два анонса. В одном из них рассказывается, что же нового в версии 2.13:

👉 алиасы типов;
👉 FFI улучшения;
👉 изменения, нацеленные на производительность;
👉 новые образы для Docker;
👉 Dart для Google Cloud;

Второй же анонс посвящен не техническим изменениям, а организационным. В ней Tim Sneath рассказал о том, как они будут вести политику развития касаемо Angular, AngularDart и поддержку web Flutter.

#обновления
Мы с коллегами из Surf решили провести небольшое мероприятие. Возьмём свой же пример к библиотеке и разберем почему как пример он пойдёт, а вот в прод так писать точно не стоит. Покажем как написать тоже самое, но уже правильно, а также как покрыть код:

👉 unit-тестами;
👉 widget-тестами;
👉 интеграционными тестами;
👉 golden-тестами.

📌 Зарегистрироваться можно по ссылке.
Вышел очередной выпуск Flutter Dev Podcast. На этот раз тема была весьма хардкорная - как именно строится UI во Flutter. Я тоже поучаствовал в записи этого выпуска вместе с Евгением Сатуровым (Surf), Александром Денисовым (EPAM) и Андреем Смирновым (Inspector Cloud). Мы затронули множество аспектов, от самого устройства, до влияния на производительность.

🎧 Послушать подкаст можно в Apple Podcasts, Яндекс.Музыка, Google Podcasts, Spotify.

#подкасты
Как мобильному разработчику зарабатывать еще больше?

По шагам:

1. Зарулить на Мир.Труд.Мобайл 27 мая. Free🔥
2. Послушать спикеров из разработки и UI/UX про тренды в мобайле (Sberbank, Instagram, Surf, Redmadrobot, hh и тд)
3. Познакомиться с другими разрабами и дизайнерами в виртуальном чате
4. Узнать последние тренды, фичи, секретные секретики про рынок мобильных приложений, платформы, языки и интерфейсы
5. Объявить себя самым умным, прозорливым и дорогим специалистом

Регистрируйся тут.

Будет много интересных и полезных докладов, в том числе мой коллега Евгений Сатуров расскажет про типы модульных тестов на Flutter.

🏕 Если хочешь вживую поболтать со спикерами и потусить на даче в Иннополисе — горит 200 билетов от 5 тыщ рублей. Забирай здесь. Промокод на скидку 5%: ohmyflutter
После перерыва в предыдущем году, конференция Secon возвращается, еще и в офлайн формате. Она пройдет 19-20 июня в Пензе и уже сейчас заявлено огромное количество докладов по различным темам: от Digital Art до ML. Мобильная разработка тоже будет, более того будет и Flutter 💪. Я тоже решил съездить и выступить там с докладом, так что приглашаю всех желающих послушать, обсуждать и пообщаться.

📌 Узнать подробнее о конференции и купить билеты можно по ссылке.
Компания Google наконец выпустила Fuchsia OS. Правда в стиле известного персонажа - только я вам ее не отдам, потому что у вас Nest Hub нет.

Обновление с Fuchsia будет поставляться постепенно в течении ближайших месяцев, обладателям колонок Nest Hub первого поколения. Будем ждать более широкого покрытия устройств, чтобы опробовать.

📌 Почитать подробнее можно по ссылке.

#события