Flutter Pulse
1.02K subscribers
627 photos
1 file
1.76K links
На канале будут новости про flutter с сайтов, информация об обновлении пакетов, а также авторский контент.
Download Telegram
Жизненный цикл виджета Flutter: от создания до уничтожения

Вы когда-нибудь задумывались, как Flutter управляет виджетами за кулисами? Понимание жизненного цикла виджета Flutter — один из наиболее важных концептов для создания эффективных, безошибочных и оптимизированных по производительности приложений.

В этой статье мы разберем полный цикл жизни виджетов Flutter, различия между жизненными циклами `StatelessWidget` и `StatefulWidget`, а также рассмотрим распространенные методы жизненного цикла, такие как initState(), build() и dispose(). Вы узнаете, как правильно управлять состоянием и ресурсами, и какие лучшие практики использовать при работе с виджетами.

Жизненный цикл виджета включает в себя несколько этапов: создание, монтирование, обновление и уничтожение.
🔹 `StatelessWidget имеет только один метод жизненного цикла — build()`, который вызывается только один раз, если только родительский виджет не перестраивает его.
🔹 StatefulWidget имеет динамический жизненный цикл, поскольку его состояние может меняться со временем.
👉 Основные методы жизненного цикла `StatefulWidget: createState(), initState(), didChangeDependencies(), build(), didUpdateWidget(), deactivate() и dispose()`.
⚙️ Правильное использование этих методов позволяет избежать утечек памяти и эффективно управлять состоянием.

🇷🇺 Читать статью на русском
🇬🇧 Read the article in English
🌐 Читать оригинал

Все подобные новости ищите по хэштегу #FlutterPulseMedium Напишите, чтобы подписчики оценили рубрику.

FlutterPulse — канал о мире Flutter!

#flutter #dart #flutterpulse #FlutterPulseMedium #mobiledevelopment #appdevelopment #programming #softwaredevelopment
Сжатие медиафайлов в Flutter: как уменьшить размер фотографий с 5 МБ до 500 КБ без потери качества

Вы когда-нибудь сталкивались с проблемой, когда пользователи загружают огромные фотографии в ваше Flutter-приложение, занимая слишком много места на сервере и замедляя работу приложения?

В новой статье рассматривается решение этой проблемы с помощью плагина media_compressor, который позволяет сжимать изображения и видео до 80-90% без потери качества.

В статье описываются приёмы и советы по сжатию медиафайлов, такие как:
Использование нативных платформенных API для максимальной производительности
Сохранение качества изображений при уменьшении размера файла
Обработка ошибок и исключений
Поддержка сжатия видео

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

🔹 Сжатие изображений до 80-90% без потери качества
🔹 Поддержка сжатия видео
🔹 Нативная производительность на Android и iOS
🔹 Простое использование и настройка

🇷🇺 Читать статью на русском
🇬🇧 Read the article in English
🌐 Читать оригинал

Все подобные новости ищите по хэштегу #FlutterPulseMedium Напишите, понравилась ли вам рубрика!

FlutterPulse — канал о мире Flutter!

#flutter #dart #flutterpulse #FlutterPulseMedium #mobiledevelopment #appdevelopment #mediacompression
Добавляем изображения в push-уведомления FCM на iOS с Flutter: пошаговое руководство

Вы когда-нибудь пытались добавить изображения в push-уведомления на iOS с Flutter, но сталкивались с неожиданными трудностями? В этой статье вы найдёте подробное руководство по реализации этой функциональности.

В статье рассматривается процесс добавления изображений в push-уведомления FCM на iOS с использованием Flutter. Автор делится своим опытом и описывает основные этапы настройки Notification Service Extension, который необходим для загрузки изображений в уведомления. Вы узнаете, как создать новый таргет в Xcode, настроить Bundle Identifier и добавить необходимый код в NotificationService.swift.

Основные темы, рассмотренные в статье:
👉 Как создать Notification Service Extension и настроить его для работы с push-уведомлениями
⚙️ Подробная инструкция по добавлению нового таргета в Xcode и настройке Bundle Identifier
📌 Как изменить код в NotificationService.swift для обработки изображений в push-уведомлениях
🔹 Решение возможных проблем, которые могут возникнуть при реализации

🇷🇺 Читать статью на русском
🇬🇧 Read the article in English
🌐 Читать оригинал

Все подобные новости ищите по хэштегу #FlutterPulseMedium Напишите, чтобы подписчики оценили рубрику.

FlutterPulse — канал о мире Flutter!

#flutter #dart #flutterpulse #FlutterPulseMedium #pushnotifications #iOS #FCM #Firebase #mobiledevelopment
Flutter Урок 5: Горячая перезагрузка, Отладка и DevTools

Продолжаем погружение в мир Flutter! В этом уроке мы рассмотрим инструменты, которые делают разработку быстрее, проще и интереснее.

В статье мы узнаем, как использовать Горячую перезагрузку (Hot Reload), чтобы мгновенно видеть изменения, как отладить распространенные ошибки и как использовать мощные Flutter DevTools для инспекции дерева виджетов, производительности и использования памяти.
Горячая перезагрузка (Hot Reload) обновляет код мгновенно, сохраняя состояние приложения
Горячий рестарт (Hot Restart) перезапускает приложение, сохраняя последние изменения кода
Полный рестарт (Full Restart) перестраивает приложение с нуля

Мы также рассмотрим, как использовать DevTools для визуальной отладки, инспекции дерева виджетов и анализа производительности.
👉 Полезные советы для отладки:
🔹 Используйте print() для быстрого отслеживания изменений
🔹 Установите точки останова в VS Code/Android Studio
🔹 Используйте DevTools для отладки макета и анализа производительности

🇷🇺 Читать статью на русском
🇬🇧 Read the article in English
🌐 Читать оригинал

Оцените рубрику! Все подобные новости ищите по хэштегу #FlutterPulseMedium

FlutterPulse — канал о мире Flutter!

#flutter #dart #flutterpulse #FlutterPulseMedium #devtools #hotreload #debugging #mobiledevelopment #appdevelopment
👍1
Async/await и Isolate в Flutter: не путайте ожидание с работой 🚀
Когда ваше приложение тормозит, первая мысль: «нужно вынести это в отдельный поток». В Flutter эта мысль часто выливается в async/await или Isolate. Но это не взаимозаменяемые вещи, а инструменты для разных задач 🤔. И если перепутать, можно получить либо бесполезный код, либо вечно зависающий UI 😱.

Главное заблуждение: async/await сам по себе не переносит выполнение в другой поток. Он просто дает удобный способ работать с асинхронными операциями, которые уже неблокирующие по своей природе: запросы к сети, чтение с диска, ожидание таймера 🕒.

Для операций ввода-вывода async/await достаточно 📁. Сеть, базы данных, файловая система - все это уже асинхронно на уровне платформы. Достаточно дождаться результата, и UI останется отзывчивым 📊.

Но как только появляются вычисления, которые грузят процессор - парсинг большого JSON, обработка изображений, сложные математические расчеты, - async/await перестает помогать 🤯. Здесь нужен настоящий параллелизм. Isolate запускает код в отдельном потоке (или даже ядре) и не трогает основной 💻.

Самый простой способ - compute(). Он берет функцию и данные, запускает их в изоляте и возвращает результат 📈. Идеально для разовых тяжелых задач.

Если нужно постоянное взаимодействие с фоновым процессом, например, обработка потока данных или долгая работа с промежуточными результатами - придется использовать Raw Isolate 📝. Там уже ручное управление портами и сообщениями, но зато полный контроль.

Итак, что выбрать?
🔵 Ждете ответ от сети или диска? async/await.
🔵 Нужно один раз обработать большой кусок данных? compute().
🔵 Есть долгий фоновый процесс с обменом сообщениями? Raw Isolate.
🔵 Пытаетесь ускорить вычисления, просто добавив async? Бесполезно, почитайте заново 📚.

Вывод: Async/await и Isolate не конкуренты, а партнеры 🤝. Первый отвечает за ожидание, второй - за параллельное выполнение. Смешивать их нужно осознанно, а не по принципу «чтоб не тормозило» 🚫.

Полную новость читайте здесь.

FlutterPulse — канал о мире Flutter!

#flutter #dart #FlutterPulse #FlutterPulseNews #hardworkerFlutter #asyncawait #isolate #mobiledevelopment #programming
Flutter: Удаление условных операторов из дерева виджетов

Представьте себе код Flutter-приложения, где логика и отображение разделены идеально. Это не просто мечта — это реальность, к которой стремятся многие разработчики!

В этой статье автор делится своим подходом к написанию чистого и поддерживаемого кода Flutter-приложений. Он рассказывает о том, как избавиться от условных операторов в дереве виджетов, используя виджет Visibility и другие подходы.

🔹 Автор начинает с объяснения своей строгой позиции по отношению к разделению логики и отображения в коде Flutter-приложений.
🔹 Он показывает, как использовать виджет Visibility, чтобы контролировать видимость различных состояний приложения.
🔹 Также рассматривается альтернативный подход, при котором виджеты создаются внутри ViewModel.
Основные преимущества и недостатки каждого подхода подробно обсуждаются.

👉 Читайте статью, чтобы узнать, как улучшить свой код и сделать его более чистым и поддерживаемым.

🇷🇺 Читать статью на русском
🇬🇧 Read the article in English
🌐 Читать оригинал

Все подобные новости ищите по хэштегу #FlutterPulseMedium Напишите, чтобы подписчики оценили рубрику.

FlutterPulse — канал о мире Flutter!

#flutter #dart #flutterpulse #FlutterPulseMedium #mobiledevelopment #appdevelopment #programming #softwaredevelopment
👎4👍2
Получение местоположения на Wear OS с помощью Flutter и Native Android: полное руководство

Хотите получать данные о местоположении напрямую с часов Wear OS в вашем Flutter-приложении? В этой статье вы найдёте подробное руководство о том, как это сделать.

В статье рассматривается процесс получения местоположения на Wear OS с помощью Flutter и Native Android. Вы узнаете, как запрашивать разрешение на доступ к местоположению, как передавать данные о местоположении из Native Android в Flutter и как отображать эти данные в пользовательском интерфейсе. Кроме того, в статье рассматриваются вопросы оптимизации энергопотребления и производительности.

Основные темы, затронутые в статье:
👉 Запрос разрешения на доступ к местоположению на Wear OS с помощью MethodChannel
⚙️ Передача данных о местоположении из Native Android в Flutter с помощью EventChannel
📌 Отображение данных о местоположении в пользовательском интерфейсе Flutter
🔹 Оптимизация энергопотребления и производительности

🇷🇺 Читать статью на русском
🇬🇧 Read the article in English
🌐 Читать оригинал

Все подобные новости ищите по хэштегу #FlutterPulseMedium Напишите, чтобы подписчики оценили рубрику.

FlutterPulse — канал о мире Flutter!

#flutter #dart #wearos #flutterpulse #FlutterPulseMedium #mobiledevelopment #wearabletechnology
Flutter Урок 8: От Статического UI к Взаимодействию с Пользователем

Вы готовы превратить свои Flutter-приложения из статических в интерактивные? В этом уроке вы узнаете, как добавить взаимодействие с пользователем, используя виджеты ввода, кнопки и управление состоянием.

В статье вы научитесь создавать приложения, которые могут принимать ввод от пользователя, реагировать на нажатия кнопок и обновлять интерфейс в реальном времени. Вы узнаете о виджетах ввода, таких как TextField, и о том, как использовать TextEditingController для чтения пользовательского ввода. Также вы поймёте, как работают кнопки в Flutter и как использовать setState для обновления интерфейса.

TextField: виджет для ввода текста пользователем
TextEditingController: контроллер для чтения и управления пользовательским вводом
ElevatedButton: кнопка для выполнения действий
setState: функция для обновления интерфейса

Вы увидите полный пример создания простого приложения, которое принимает имя пользователя, генерирует приветственное сообщение и отображает его на экране.

🇷🇺 Читать статью на русском
🇬🇧 Read the article in English
🌐 Читать оригинал

Все подобные новости ищите по хэштегу #FlutterPulseMedium Напишите, чтобы подписчики оценили рубрику.

FlutterPulse — канал о мире Flutter!

#flutter #dart #flutterpulse #FlutterPulseMedium #mobiledevelopment #appdevelopment #programming #softwaredevelopment
👍1
Flutter Flavors: Как правильно настроить окружения для разработки, staging и production

Вы разрабатываете профессиональное Flutter-приложение и сталкиваетесь с необходимостью управления разными окружениями? Теперь вы можете легко переключаться между Dev, Staging и Production средами!

В этой статье вы узнаете, как настроить и управлять Flavors в Flutter, чтобы изолировать конфигурации, создать уникальные идентификаторы приложений и предотвратить случайное попадание dev-кода в production. Вы научитесь создавать разные конфигурации для Android и iOS, использовать переменные окружения и автоматизировать сборку с помощью CI/CD pipelines.

Основные концепции Flavors и их преимущества
⚙️ Пошаговая настройка Flavors для Dev, Staging и Production
🔹 Создание отдельных конфигурационных файлов для каждого окружения
👉 Использование разных иконок приложений для каждого Flavor
Лучшие практики по управлению Flavors и безопасностью приложения

🇷🇺 Читать статью на русском
🇬🇧 Read the article in English
🌐 Читать оригинал

Все подобные новости ищите по хэштегу #FlutterPulseMedium Напишите, чтобы подписчики оценили рубрику.

FlutterPulse — канал о мире Flutter!

#flutter #dart #flutterpulse #FlutterPulseMedium #mobiledevelopment #appdevelopment #programming #softwaredevelopment
Эффект мерцания в Flutter: улучшение пользовательского опыта

Современные мобильные приложения требуют плавного и информативного опыта загрузки, чтобы удерживать пользователей и снижать количество отказов. Одним из популярных UI-приемов для обработки состояний загрузки является эффект мерцания.

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

Эффект мерцания — это анимированный плейсхолдер, имитирующий "мерцание" или "движущийся свет" над виджетами, пока фактические данные загружаются в фоновом режиме.
👉 Преимущества эффекта мерцания:
Улучшает пользовательский опыт
Делает экраны загрузки более быстрыми
Придает профессиональный и отполированный вид интерфейсу
Снижает разочарование пользователей во время вызовов API
Идеален для скелетных экранов

⚙️ Для реализации эффекта мерцания в Flutter существует популярный пакет shimmer. В статье показано, как добавить зависимость, обернуть виджет с Shimmer.fromColors и создать скелетный UI.

🔹 Основные шаги реализации:
👉 Шаг 1: Добавьте зависимость shimmer в pubspec.yaml
👉 Шаг 2: Оберните виджет с Shimmer.fromColors
👉 Пример скелетного UI с карточками и текстом

Лучшие практики использования эффекта мерцания:
🔹 Используйте мерцание только во время фактических состояний загрузки
🔹 Избегайте чрезмерных анимаций мерцания
🔹 Сохраняйте формы плейсхолдеров похожими на реальный контент
🔹 Используйте более легкие цвета для плавного UX
🔹 Используйте ListView.builder для длинных списков

🇷🇺 Читать статью на русском
🇬🇧 Read the article in English
🌐 Читать оригинал

Все подобные новости ищите по хэштегу #FlutterPulseMedium Напишите, чтобы подписчики оценили рубрику.

FlutterPulse — канал о мире Flutter!

#flutter #dart #flutterpulse #FlutterPulseMedium #mobiledevelopment #ui #ux #shimmer #loadinganimation
👍2