Реализация мини-плеера (Mini Player) в мобильном приложении

TRUETECH занимается разработкой, поддержкой и обслуживанием мобильных приложений iOS, Android, PWA. Имеем большой опыт и экспертизу для публикации мобильных приложений в популярные маркеты Google Play, App Store, Amazon, AppGallery и другие.

Разработка и поддержка любых видов мобильных приложений:

Информационные и развлекательные мобильные приложения
Новостные приложения, игры, справочники, онлайн-каталоги, погодные, фитнес и здоровье, туристические, образовательные, социальные сети и мессенджеры, квиз, блоги и подкасты, форумы, агрегаторы
Мобильные приложения электронной коммерции
Интернет-магазины, B2B-приложения, маркетплейсы, онлайн-обменники, кэшбэк-сервисы, биржи, дропшиппинг-платформы, программы лояльности, доставка еды и товаров, платежные системы
Мобильные приложения для управления бизнес-процессами
CRM-системы, ERP-системы, управление проектами, инструменты для команды продаж, учет финансов, управление производством, логистика и доставка, управление персоналом, системы мониторинга данных
Мобильные приложения электронных услуг
Доски объявлений, онлайн-школы, онлайн-кинотеатры, платформы предоставления электронных услуг, платформы кешбека, видеохостинги, тематические порталы, платформы онлайн-бронирования и записи, платформы онлайн-торговли

Это лишь некоторые из типы мобильных приложений, с которыми мы работаем, и каждый из них может иметь свои специфические особенности и функциональность, а также быть адаптированным под конкретные потребности и цели клиента.

Услуги, которые мы предлагаем
Показано 1 из 1Все 1735 услуг
Реализация мини-плеера (Mini Player) в мобильном приложении
Средний
от 1 дня до 3 дней
Часто задаваемые вопросы

Наши компетенции:

Этапы разработки

Последние работы

  • image_mobile-applications_feedme_467_0.webp
    Разработка мобильного приложения для компании FEEDME
    792
  • image_mobile-applications_xoomer_471_0.webp
    Разработка мобильного приложения для компании XOOMER
    671
  • image_mobile-applications_rhl_428_0.webp
    Разработка мобильного приложения для компании RHL
    1097
  • image_mobile-applications_zippy_411_0.webp
    Разработка мобильного приложения для компании ZIPPY
    969
  • image_mobile-applications_affhome_429_0.webp
    Разработка мобильного приложения для компании Affhome
    914
  • image_mobile-applications_flavors_409_0.webp
    Разработка мобильного приложения для компании FLAVORS
    495

Реализация мини-плеера (Mini Player) в мобильном приложении

Мини-плеер — полоска с названием трека, кнопками play/pause и прогресс-баром, которая остаётся видимой при навигации между экранами. Выглядит просто, но технически упирается в архитектуру навигации: плеер должен жить вне конкретного экрана и не пересоздаваться при переходах.

Архитектурное решение

Мини-плеер — не экран, а persistented overlay поверх всего приложения. Способ размещения зависит от навигационной системы.

iOS (UIKit). Добавляем мини-плеер в UITabBarController или UIWindow — он живёт на уровне контейнера, не конкретного ViewController. Ограничение: UITabBar занимает нижнюю часть, мини-плеер размещаем прямо над ним, сдвигая additionalSafeAreaInsets.bottom у всех VC в табе.

// В кастомном UITabBarController
override func viewDidLoad() {
    super.viewDidLoad()
    miniPlayerView = MiniPlayerView()
    view.addSubview(miniPlayerView)
    NSLayoutConstraint.activate([
        miniPlayerView.bottomAnchor.constraint(equalTo: tabBar.topAnchor),
        miniPlayerView.leadingAnchor.constraint(equalTo: view.leadingAnchor),
        miniPlayerView.trailingAnchor.constraint(equalTo: view.trailingAnchor),
        miniPlayerView.heightAnchor.constraint(equalToConstant: 64)
    ])
    // Сдвигаем safe area для дочерних VC
    additionalSafeAreaInsets.bottom = 64
}

iOS (SwiftUI). ZStack в корневом ContentView с TabView внизу и мини-плеером поверх через .overlay(alignment: .bottom). Состояние плеера — @EnvironmentObject или @ObservedObject синглтон.

Android (Jetpack Compose). Мини-плеер в корневом Scaffold как bottomBar, или через Box поверх NavHost. Состояние через ViewModel в NavGraph-уровне — переживает навигацию между экранами.

React Native. Компонент мини-плеера в корневом App.tsx поверх навигатора. position: 'absolute', bottom: tabBarHeight + жест свайпа вверх для разворачивания.

Expand/Collapse анимация

Мини-плеер должен разворачиваться в полноэкранный плеер по тапу или свайпу вверх.

iOS. UIPanGestureRecognizer + UIViewPropertyAnimator с interruptibleAnimator. При промежуточных состояниях — fractionComplete анимируется пропорционально смещению пальца. Apple Music делает именно так: полноэкранный плеер — это sheet с detents, мини-плеер — кастомный presentationController.

Android Compose. BottomSheetScaffold или ModalBottomSheet с кастомными sheetPeekHeight и sheetContent. При peekHeight — мини-плеер, при развёрнутом состоянии — полный.

Синхронизация состояния

Прогресс-бар, название трека, обложка — всё это должно обновляться в реальном времени вне зависимости от того, на каком экране пользователь. Единый источник правды — PlayerViewModel / AudioPlayerManager как синглтон с @Published (iOS) или StateFlow (Android). Мини-плеер подписывается на него, не хранит локального состояния.

Жесты и доступность

Свайп вниз на развёрнутом плеере — закрыть/свернуть в мини. Реализуем через UIPanGestureRecognizer (iOS) с пороговым значением translation.y > 100 для подтверждения действия. При неполном свайпе — UIViewPropertyAnimator возвращает в исходное состояние.

На Android Compose — swipeable (из accompanist) или anchoredDraggable (Compose 1.6+) с якорями COLLAPSED / EXPANDED. При скорости жеста > 1000 dp/s — немедленный переход без анимации.

VoiceOver/TalkBack: мини-плеер должен иметь accessibilityLabel с текущим треком и accessibilityHint «Нажмите для открытия полного плеера». Кнопка паузы в мини-плеере — отдельный accessibilityElement.

Сроки

Мини-плеер с expand-анимацией на одной платформе — 2–3 дня. Обе платформы с жестовым управлением — 3–4 дня.