Разработка Apple TV приложения (tvOS)
tvOS — это iOS с удалённым пультом вместо тачскрина. Звучит просто, но ломает большинство мобильных паттернов: нет прямого касания, навигация через Siri Remote, экран смотрят с 3 метров, а не с 30 см. Приложение, портированное с iPhone без адаптации, получит отказ на App Store review по HIG tvOS или просто окажется неудобным.
Фокус-навигация — главная сложность
На iOS пользователь тапает куда хочет. На tvOS — нажимает свайп на пульте, и система перемещает фокус между focusable элементами. Focusable — это UIButton, UITextField, кастомные UIView с canBecomeFocused = true.
Проблемы начинаются с кастомного UI. Если верстать через UIKit с кастомными View и не реализовать UIFocusEnvironment, фокус просто не доходит до ваших элементов. SwiftUI на tvOS работает лучше — focusable() модификатор и @FocusState из коробки управляют навигацией. Но LazyVGrid в tvOS требует явного focusSection(), иначе фокус при горизонтальном свайпе уходит не в соседний элемент сетки, а прыгает непредсказуемо.
Parallax effect. tvOS ожидает, что focusable изображения имеют эффект параллакса при фокусировке. Это не просто красота — пользователи привыкли к нему как визуальному индикатору. Реализуется через UIImageView с adjustsImageWhenAncestorFocused = true и слоистый LSR/LCR формат изображений (Layered Still/Animated Image). Для SwiftUI — через CardButtonStyle.
UIKit vs SwiftUI на tvOS
SwiftUI — предпочтительный путь для новых приложений. Декларативная верстка хорошо ложится на grid-навигацию tvOS. Но есть ограничения:
-
VideoPlayerв SwiftUI не поддерживает кастомные оверлеи транспортного управления — нуженAVPlayerViewControllerчерезUIViewControllerRepresentable - Кастомный
AVPlayerViewControllerDelegateдля управления жестами пульта — только UIKit -
TVTopShelfProviderдля контента на главном экране Apple TV — только UIKit/Info.plist, без SwiftUI API
Видеоплеер — ключевой компонент большинства tvOS-приложений. AVPlayerViewController даёт стандартный интерфейс с поддержкой пульта, субтитров (через AVMediaSelectionGroup), глав (через AVTimedMetadataGroup) и Picture-in-Picture (с tvOS 14). Кастомизация — через contentOverlayView и customInfoViewController.
Top Shelf Extension
Если приложение установлено в первом ряду главного экрана Apple TV, можно показывать динамический контент в «полке» сверху. Реализуется через TVTopShelfContentProvider в отдельном Extension target.
Два формата: TVTopShelfSectionedContent (секции с элементами) и TVTopShelfInsetContent (широкий баннер). Контент запрашивается системой периодически — deferredTopShelfContent(completionBlock:). Без реализации Top Shelf приложение показывает статичную иконку.
Процесс разработки
Анализ контентной модели и сценариев использования (VOD, игра, утилита). Проектирование навигации под пульт — обязательный этап, нельзя просто перенести мобильный флоу. Разработка на SwiftUI + UIKit где нужно. Интеграция Top Shelf, Siri Remote жестов (UISwipeGestureRecognizer + UITapGestureRecognizer на allowedPressTypes: [.playPause, .menu]). Тестирование с физическим пультом и с iPhone как пультом через Remote app.
Публикация в App Store через отдельный tvOS bundle target. tvOS-приложение может быть частью универсального приложения (iOS + tvOS в одном bundle) или отдельным продуктом.
Сроки
Простое информационное или VOD-приложение: 6–10 недель. Приложение с Top Shelf, кастомным плеером и авторизацией: 10–16 недель. Игра или интерактивный опыт — оценка индивидуально. Стоимость рассчитывается после анализа функциональных требований.







