Разработка CarPlay интеграции для iOS-приложения
CarPlay — это не отдельное приложение. Это расширение существующего iOS-приложения, которое отображается на экране мультимедийной системы автомобиля. Apple жёстко ограничивает категории приложений, которые могут работать в CarPlay: навигация, аудио, VoIP, мессенджеры, EV-зарядка, парковка, заправки, еда и напитки (с iOS 17), фитнес (с iOS 16). Всё остальное — отклонение на review.
Entitlement и категориальные ограничения
Первый шаг — запросить CarPlay entitlement у Apple. Без com.apple.developer.carplay-* entitlement приложение не запустится в CarPlay симуляторе, не говоря о реальном авто. Entitlement привязан к категории: com.apple.developer.carplay-audio, com.apple.developer.carplay-navigation, com.apple.developer.carplay-communication и т.д.
Категория определяет не только entitlement, но и доступные UI шаблоны. Навигация использует CPMapTemplate. Аудио — CPNowPlayingTemplate + CPTabBarTemplate. Мессенджеры — только CPMessageListItem в CPListTemplate. Рисовать произвольный UI в CarPlay нельзя — только шаблоны Apple.
CarPlay шаблоны и их ограничения
CPMapTemplate — для навигации. Карту рендерит само приложение через CPMapViewController, но на экран CarPlay она выводится через CPTemplateApplicationScene. Сложность в том, что карта должна работать корректно при разных соотношениях сторон — экраны CarPlay бывают 7", 8", 10" с разными aspect ratio. CPMapTemplate предоставляет guidanceBackgroundColor, mapButtons (максимум 4), panningInterface для управления картой.
CPListTemplate — универсальный список. Максимум 30 элементов в секции, максимум 40 секций. CPListItem поддерживает изображение, текст, детальный текст, accessoryImage. Асинхронная загрузка изображений — через CPListItem.handler с callback. Если не вернуть completion в listItemHandler — интерфейс зависает.
CPNowPlayingTemplate — синглтон, общий для всех аудио-приложений. Нельзя создать несколько экземпляров. MPNowPlayingInfoCenter.default() должен быть заполнен до того, как шаблон появится на экране, иначе CarPlay показывает пустой плеер.
Интеграция с основным приложением
CarPlay работает в отдельной UIWindowScene — CPTemplateApplicationScene. Приложение получает контроль через CPTemplateApplicationSceneDelegate. Это значит, что AppDelegate или SceneDelegate основного приложения работают параллельно.
Архитектурно правильно: CarPlay scene делегирует бизнес-логику тому же слою, что и основное приложение. Общий AudioPlayerService, общий NavigationRepository. CarPlay только отображает состояние и передаёт команды.
Типичная ошибка: инициализировать данные внутри CPTemplateApplicationSceneDelegate — это приводит к дублированию сессий, конфликтам воспроизведения и крашам при переключении между телефоном и CarPlay.
Тест без реального авто. Simulator → Features → CarPlay включает CarPlay-окно рядом с iPhone симулятором. Симулятор не воспроизводит все особенности реального экрана (разные размеры, OEM-специфику), но достаточен для базовой разработки. Финальное тестирование — в реальном автомобиле или через MirrorLink-адаптер.
Процесс
Запрос CarPlay entitlement (до 2 недель ожидания от Apple). Проектирование flow в рамках доступных шаблонов — без компромисса с требованиями Apple. Разработка CPTemplateApplicationSceneDelegate, интеграция с существующей бизнес-логикой. Тестирование в симуляторе и на реальном железе.
Сроки
Аудио-интеграция (плеер + очередь): 3–5 недель. Навигационная интеграция с картой: 6–10 недель. Мессенджер/VoIP: 4–7 недель. Стоимость рассчитывается после получения entitlement и анализа существующего приложения.







