Flutter Pulse
525 subscribers
343 photos
754 links
На канале будут новости про flutter с сайтов, информация об обновлении пакетов, а также авторский контент.
Download Telegram
🔥 РАСШИРЯЕМ ВОЗМОЖНОСТИ FLUTTER С ПОМОЩЬЮ FFI! 🔥

Привет, Flutter-энтузиасты! Сегодня делимся крутым видео, которое откроет вам мир нативной интеграции в Dart. Автор подробно разбирает, как заставить Flutter общаться с кодом на C через FFI — и это только начало!

🎯 Что внутри?
👉 Автор начинает с основ: создание простой функции на C (сложение/умножение), её компиляция в динамическую библиотеку (.so) и вызов из Dart через dart:ffi. Никакой магии — только чёткие шаги!

⚙️ Главные фишки выпуска:
🔹 Зачем нужна кодогенерация ffigen и как она упрощает работу с заголовочными файлами (.h)
🔹 Как избежать ручного создания биндингов: автоматическая генерация Dart-интерфейсов для C-кода
🔹 Подробный разбор типов данных: почему int в Dart ≠ int в C и как это обойти
🔹 Рабочие примеры с репозиторием, где можно потрогать код руками

🚀 А вот что ждёт в следующих сериях:
▫️ Работа со строками — самые частые подводные камни!
▫️ Скрипты для автоматизации рутины
▫️ Вызов кода из Go, Rust, Python и C++

👉 Обязательно посмотрите, если хотите:
• Ускорить критичные операции через нативный код
• Интегрировать legacy-библиотеки в Flutter
• Понять, как устроен FFI изнутри

📹 Видео: Расширяем возможности Flutter с помощью FFI

#Flutter #Dart #FlutterPulse #FlutterPulseTips #FlutterPulseYoutube #FFI #CleanCode #FlutterArchitecture
👉 Больше крутых туториалов ищите по тегу #FlutterPulseYoutube!
OverflowBar или Wrap?
В чем основные различия между этими двумя виджетами Flutter? 🤔

При создании адаптивных интерфейсов в Flutter часто возникает вопрос о том, какой виджет использовать для размещения дочерних элементов: OverflowBar или Wrap? Давайте разберемся в их основных различиях. 🔍



_buildTestA(BuildContext context) => OverflowBar(
children: [
Container(width: 300, height: 100, color: Colors.blue),
const Card(
margin: EdgeInsets.all(32),
child: Text('My Title lorem lorem lorem'),
),
Expanded(child: Container(height: 100, color: Colors.red)),
],
);

_buildTestB(BuildContext context) => Wrap(
children: [
Container(width: 300, height: 100, color: Colors.blue),
const Card(
margin: EdgeInsets.all(32),
child: Text('My Title lorem lorem lorem'),
),
Expanded(child: Container(height: 100, color: Colors.red)),
],
);



OverflowBar и Wrap имеют разные подходы к размещению дочерних элементов. OverflowBar предназначен для размещения элементов в одной строке и не переносит их на новую строку, если они не помещаются. Wrap, наоборот, переносит элементы на новую строку, если они не помещаются в доступное пространство. 🌟

Оцените новую рубрику и напишите в комментариях, насколько она вам полезна! 👍💬

Все подобные новости можно найти по хэштегу #FlutterPulseTips. 🔍

#flutter #dart #flutterpulse #FlutterPulseTips #mobiledevelopment #appdevelopment #uiux #programmingtips
👍2🔥2
Обзор пакетов на тему Геолокация и Карты 🗺️

Google Maps for Flutter 📍️
Плагин для добавления виджета Google Maps в ваши Flutter-приложения. Поддерживает Android, iOS и Web.
👍 Лайки: 4490, 📥 Скачиваний: 698К
Последнее обновление 📅: 55 дней назад
https://pub.dev/packages/google_maps_flutter

location 📍️
Пакет для получения местоположения устройства на Android и iOS, а также получения callbacks при изменении местоположения.
👍 Лайки: 3170, 📥 Скачиваний: 223К
Последнее обновление 📅: 54 дня назад
https://pub.dev/packages/location

google_maps 🗺️
Библиотека для использования Google Maps JavaScript API v3 в Dart-скриптах. Используется для создания интерактивных карт на веб-страницах.
👍 Лайки: 123, 📥 Скачиваний: 668К
Последнее обновление 📅: 10 месяцев назад
https://pub.dev/packages/google_maps

Geolocator Plugin 📍️
Пакет для получения доступа к сервисам геолокации на платформах Android и iOS.
👍 Лайки: 5920, 📥 Скачиваний: 1.21М
Последнее обновление 📅: 41 день назад
https://pub.dev/packages/geolocator

Map Launcher 🗺️
Пакет для нахождения установленных карт на устройстве и запуска их с маркером или показа направлений.
👍 Лайки: 918, 📥 Скачиваний: 153К
Последнее обновление 📅: 16 дней назад
https://pub.dev/packages/map_launcher

Flutter Map 🗺️
Пакет для создания кроссплатформенных карт без привязки к конкретным поставщикам.
👍 Лайки: 2040, 📥 Скачиваний: 236К
Последнее обновление 📅: 31 день назад
https://pub.dev/packages/flutter_map

#flutter #dart #pubdev #flutterpulse #flutterpulsethemedpackages #google_maps_flutter #location #google_maps #geolocator #map_launcher #flutter_map
👍1
Самые лучшие обновлённые пакеты за последние 24 часа

flutter_hooks 0.8.0+1 - плагин для Flutter, который позволяет упростить код и повысить его повторное использование. В новой версии исправлена ссылка на "Existing hooks" в README.md.
👍 Лайки: 2350, 📥 Скачиваний: 687К
https://pub.dev/packages/flutter_hooks

protobuf 4.2.0 - пакет для поддержки runtime библиотеки protobuf в Dart. В новой версии проведена внутренняя рефакторинг для разделения пакета на библиотеки.
👍 Лайки: 238, 📥 Скачиваний: 1.2М
https://pub.dev/packages/protobuf

speech_to_text 7.3.0 - плагин для распознавания речи на устройствах Android, iOS, MacOS, Web, Linux и Windows. В новой версии добавлена частичная поддержка распознавания речи на Windows.
👍 Лайки: 1510, 📥 Скачиваний: 330К
https://pub.dev/packages/speech_to_text

at_contacts_flutter 4.1.0 - пакет для добавления функциональности управления контактами в приложения на платформе atPlatform. В обновлении были обновлены зависимости at_commons_flutter, at_client и at_client_mobile.
👍 Лайки: 303, 📥 Скачиваний: 674
https://pub.dev/packages/at_contacts_flutter

file_picker 10.3.1 - плагин для выбора одного или нескольких файлов с поддержкой фильтрации по расширениям. В новой версии исправлен обработчик onFileLoading.
👍 Лайки: 4770, 📥 Скачиваний: 2.0М
https://pub.dev/packages/file_picker

wechat_assets_picker 9.7.0 - пакет для выбора изображений, видео и аудио в приложениях Flutter. В новой версии добавлена возможность указать fallback текстовый делегат через assetPickerTextDelegateFromLocale.
👍 Лайки: 829, 📥 Скачиваний: 35.6К
https://pub.dev/packages/wechat_assets_picker

#flutter #dart #pubdev #FlutterPulse #FlutterPulseBestPackages #flutter_hooks #protobuf #speech_to_text #at_contacts_flutter #file_picker #wechat_assets_picker
🔥 Запускаем код C, Rust или GO через FFI в Flutter! // Демо-занятие курса

Привет, Flutter-разработчики! Готовы вывести свои приложения на новый уровень производительности? 🚀 Сегодня делимся крутым видео, которое покажет, как интегрировать низкоуровневые языки в ваши проекты с помощью FFI (Foreign Function Interface).

👉 Смотреть демо-занятие от курса «Flutter Mobile Developer»

💡 Что внутри?
- Написание функций на C, Rust и GO для вызова из Dart/Flutter.
- Работа со сторонними библиотеками и FFI-плагинами.
- Компиляция кода под разные архитектуры процессоров (ARM, x86 и др.).
- Автоматизация сборки через Makefile и скрипты.
- Реальные кейсы: оптимизация обработки изображений, криптография и даже запуск Python-кода!

🎯 Результаты:
После просмотра вы научитесь:
- Компилировать C/Rust/Go под любые платформы.
- Вызывать нативный код из Flutter-приложений.
- Писать скрипты для упрощения сборки.
- Обходить подводные камни FFI.

👨‍🏫 Эксперт: Руслан Цицер — практикующий разработчик, который разжёвывает сложные темы на понятных примерах.

💬 P.S. Уже пробовали FFI? Делитесь опытом в комментариях! 👇
Если кому интересен Go могу порекомендовать курсы MadTeacher, который также является крутым flutter-разработчиком

#Flutter #Dart #FlutterPulse #FlutterPulseTips #FlutterPulseYoutube
1
Как протестировать дизайн виджета?

Обеспечьте, чтобы обновления не влияли на то, как ваш виджет отображается для пользователя.

Используйте метод golden file. Это проверит, что дизайн остался таким же, как и на изображении.

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



testWidgets('Golden test', (WidgetTester tester) async {
await tester.pumpWidget(MyApp());
await expectLater(
find.byType(MyCard),
matchesGoldenFile('card.png')
);
});



Теперь запуск ваших тестов обеспечит неизменность дизайна. Например, вы создаете карту, используя некоторые аватары и другие виджеты. Если один из дочерних элементов будет изменен, ваша карта не останется прежней, и вы узнаете об этом.

Как сгенерировать Golden файлы?



flutter test --update-goldens



Это сгенерирует golden файлы для каждого вызова matchesGoldenFile в ваших тестах.

Оцените новую рубрику и напишите своё мнение! 👍💬

Все подобные новости можно найти по хэштегу #FlutterPulseTips

#flutter #dart #flutterpulse #FlutterPulseTips #MobileDevelopment #WidgetTesting #GoldenFiles #FlutterTips #DevelopmentTips
Обзор пакетов на тему "Редактирование, сохранение и сжатие мультимедиа"

📸 flutter_image_compress - Пакет для сжатия изображений в форматах JPEG, PNG, WebP и HEIF на платформах Android, iOS, macOS, Web и OpenHarmony. Сжатие изображений происходит на уровне нативного кода, что обеспечивает высокую скорость и эффективность.
👍 Лайки: 1710, 📥 Скачиваний: 527К
Последнее обновление 📅: 7 месяцев назад
https://pub.dev/packages/flutter_image_compress

📸 ProImageEditor - Пакет для интеграции редактора изображений в ваше приложение. Он включает в себя множество функций, таких как рисование, редактирование текста, обрезка и поворот изображений, применение фильтров и многое другое.
👍 Лайки: 443, 📥 Скачиваний: 25.4К
Последнее обновление 📅: 2 часа назад
https://pub.dev/packages/pro_image_editor

📸 image_editor - Пакет для редактирования изображений в Flutter, позволяющий обрезать, поворачивать, масштабировать и применять различные эффекты к изображениям.
👍 Лайки: 362, 📥 Скачиваний: 28.3К
Последнее обновление 📅: 8 месяцев назад
https://pub.dev/packages/image_editor

📹 Gal - Пакет для сохранения изображений и видео в галерею на различных платформах, включая Android, iOS, macOS, Windows и Linux.
👍 Лайки: 483, 📥 Скачиваний: 131К
Последнее обновление 📅: 22 дня назад
https://pub.dev/packages/gal

📹 video_trimmer - Пакет для обрезки видео в Flutter, позволяющий обрезать видео, конвертировать в GIF и управлять воспроизведением.
👍 Лайки: 489, 📥 Скачиваний: 4.7К
Последнее обновление 📅: 3 месяца назад
https://pub.dev/packages/video_trimmer

📹 video_compress - Пакет для сжатия видео, удаления аудио, манипулирования миниатюрами и делания видео совместимым со всеми платформами.
👍 Лайки: 717, 📥 Скачиваний: 105К
Последнее обновление 📅: 6 месяцев назад
https://pub.dev/packages/video_compress

#flutter #dart #pubdev #flutterpulse #flutterpulsethemedpackages #flutter_image_compress #ProImageEditor #image_editor #Gal #video_trimmer #video_compress
🔥1
Привет, друзья! 🤩 Сегодня у нас супер-интересная тема: распознавание лиц на Flutter! 🤖 Это не только крутая фича для твоего приложения, но и важный инструмент для безопасности и идентификации. 🔒

Почему нам нужно распознавание лиц? 🤔
✔️ Безопасность: контроль доступа по лицу
✔️ Идентификация: определение пользователя среди базы данных
✔️ Интерактивные приложения: фильтры, маски и другие AR-фичи
✔️ Автоматизация: распознавание посетителей в системе учета

Как добавить распознавание лиц в свое приложение на Flutter? 🤔
Мы будем использовать пакет google_mlkit_face_detection и image_picker. Добавляем их в pubspec.yaml и настраиваем все необходимое. 📝

Логика распознавания: 🔍
Мы создаем метод для получения и обработки изображения, используя FaceDetector и InputImage. Результат отображаем с помощью CustomPaint и FacePainter. 🎨

Хочешь узнать больше? 🤓 Читай полную статью по ссылке

Не забудь подписаться на наш канал flutterpulse, чтобы быть в курсе всех последних новостей и обновлений в мире Flutter! 📱 #flutter #dart #flutterpulse 🚀
Самые лучшие обновлённые пакеты за последние 24 часа

analyzer_plugin 0.13.7 - плагин для создания плагинов для сервера анализа, написанных на Dart. Теперь требуется версия 8.1.1 пакета analyzer. Более 2.4М скачиваний и 44 лайка! 👍 Лайки: 44, 📥 Скачиваний: 2.4М https://pub.dev/packages/analyzer_plugin

syncfusion_flutter_gauges 30.2.5 - пакет для создания современных и интерактивных индикаторов в приложениях Flutter. Обновлена совместимая версия пакета до Flutter SDK 3.32.0, исправлена ошибка с позицией WidgetPointer в Radial Gauge. Пакет имеет более 169К скачиваний и 1.1К лайков. 👍 Лайки: 1.1К, 📥 Скачиваний: 169К https://pub.dev/packages/syncfusion_flutter_gauges

syncfusion_flutter_datepicker 29.1.39 - пакет для создания календарей в приложениях Flutter. Минимальная версия Dart обновлена до 3.7. Пакет имеет 1590 лайков и более 182К скачиваний. 👍 Лайки: 1590, 📥 Скачиваний: 182К https://pub.dev/packages/syncfusion_flutter_datepicker

syncfusion_flutter_charts 30.2.6 - библиотека визуализации данных для создания красивых и высокопроизводительных графиков в приложениях Flutter. Исправлены ошибки: устранен крах макета при отображении SfCartesianChart в очень маленьких контейнерах, исправлена проблема с обновлением оси при изменении только одного предела видимого диапазона. Пакет имеет 3530 лайков и более 272К скачиваний! 👍 Лайки: 3530, 📥 Скачиваний: 272К https://pub.dev/packages/syncfusion_flutter_charts

syncfusion_flutter_core 30.2.5 - пакет необходим для работы с виджетами Syncfusion Flutter. Свойство assistThemeData в SfThemeData было переименовано в aiAssistViewThemeData. Пакет имеет 243 лайка и более 656К скачиваний. 👍 Лайки: 243, 📥 Скачиваний: 656К https://pub.dev/packages/syncfusion_flutter_core

syncfusion_flutter_calendar 30.2.5 - пакет для создания календарей в приложениях Flutter с различными представлениями: день, неделя, рабочая неделя, месяц и т.д. Обновлен пакет timezone до версии 0.10.1 и улучшена совместимость с Flutter SDK 3.32.0. Пакет имеет 1520 лайков и более 57К скачиваний! 👍 Лайки: 1520, 📥 Скачиваний: 57К https://pub.dev/packages/syncfusion_flutter_calendar

#Flutter #Dart #PubDev #FlutterPulse #FlutterPulseBestPackages #syncfusion_flutter_gauges #syncfusion_flutter_datepicker #syncfusion_flutter_charts #syncfusion_flutter_core #syncfusion_flutter_calendar #analyzer_plugin
2
Волнующие новости для всех разработчиков на Flutter и Dart! 🚀💻
Только что вышла новая версия Dart 3.9.0! 🎉 И она приносит с собой целый ряд интересных обновлений:
👉 Ускорение работы анализатора - ваш код будет проверяться еще быстрее! 🚀
👉 Полный null safety теперь включен по умолчанию в местах, где его раньше не было, что делает ваш код еще более точным и безопасным! 🛡
👉 Поддержка tag-pattern для git тегов в pubspec зависимостях - управление зависимостями стало еще проще! 📈
👉 Отмена Future после hot restart, если она была создана в другом "поколении" приложения - еще один шаг к более стабильному и предсказуемому коду! 🔥

Хотите узнать больше о всех этих обновлениях? 🤔 Тогда переходите по ссылке и читайте полный changelog! 📌

И не забудьте подписаться на канал flutterpulse, чтобы быть всегда в курсе последних новостей и обновлений из мира Flutter и Dart! 📱 #flutter #dart #flutterpulse 💻👍