車輛應用程式

建構適用於 Android Auto 和 Android Automotive OS 的範本應用程式。
最近更新時間 穩定版 候選版 Beta 版 Alpha 版
2024 年 11 月 13 日 1.4.0 - 1.7.0-beta03 -

宣告依附元件

如要為車輛應用程式程式庫新增依附元件,您必須為專案新增 Google Maven 存放區。詳情請參閱 Google 的 Maven 存放區

在應用程式或模組的 build.gradle 檔案中,新增所需構件的依附元件:

Groovy

dependencies {
    implementation "androidx.car.app:app:1.4.0"

    // For Android Auto specific functionality
    implementation "androidx.car.app:app-projected:1.4.0"

    // For Android Automotive specific functionality
    implementation "androidx.car.app:app-automotive:1.4.0"

    // For testing
    testImplementation "androidx.car.app:app-testing:1.4.0"
}

Kotlin

dependencies {
    implementation("androidx.car.app:app:1.4.0")

    // For Android Auto specific functionality
    implementation("androidx.car.app:app-projected:1.4.0")

    // For Android Automotive specific functionality
    implementation("androidx.car.app:app-automotive:1.4.0")

    // For testing
    testImplementation("androidx.car.app:app-testing:1.4.0")
}

如要進一步瞭解依附元件,請參閱「新增建構依附元件」一文。

意見回饋

您的意見可協助我們改善 Jetpack。如果您發現新問題,或是有改進這個程式庫的建議,請告訴我們。回報新問題前,請先查看這個程式庫的現有問題。只要按一下星號按鈕,即可投票給現有的問題。

建立新問題

詳情請參閱 Issue Tracker 說明文件

1.7 版

1.7.0-beta03 版

2024 年 11 月 13 日

修正安全漏洞和其他一般錯誤。如果您使用的是較舊版本,請更新至這個版本

發布 androidx.car.app:app-*:1.7.0-beta03。1.7.0-beta03 版包含這些修訂項目

API 變更

  • 更新 CAL 序列化 / 反序列化程式碼,只處理宣告了 @CarProtocol 註解的物件。(Ic730e)。
  • CarAppExtender 現在可以用來擴充架構 Notification.Builder,而非只擴充 NotificationCompat.Builder。(Id3ad7)
  • 新增 KEY_EXCLUDE_MEDIA_ITEM_FROM_MIXED_APP_LIST extra。(I201f9)
  • 淘汰 ConversationItem 上的空白 Builder 建構函式,並以採用必要參數的建構函式取代。此外,還會加入檢查機制,以防範空值訊息。(Ic8221)

修正錯誤

  • 請確認 PlaceList 對應項目使用字串 (僅文字) 標頭標題。(Ic992f)。
  • 這個程式庫現在使用 JSpecify 空值註解,這是類型用法。Kotlin 開發人員應使用下列編譯器引數,確保正確使用 -Xjspecify-annotations=strict, -Xtype-enhancement-improvements-strict-mode。(Ib5367b/326456246)

1.7.0-beta02 版

2024 年 9 月 18 日

發布 androidx.car.app:app-*:1.7.0-beta02。1.7.0-beta02 版包含這些修訂項目

API 變更

  • 新增 KEY_ROOT_HINT_MEDIA_HOST_VERSION 額外項目 (I8796b)
  • TabContents.Builder 類別中,將 TabContents.Api8Builder 類別替換為 @ExperimentalCarApi 建構函式 (I26fbe)
  • CarMediaApp 新增意圖動作和額外項目 (I50782)
  • 將訊息 API 標示為非實驗性 (I0b070)
  • 將遠端項目載入作業新增至 SectionedItemTemplate (可讓長清單載入時不會當機) (I0d122)
  • 在 API 8 中,將 SectionedItemTemplate 新增至 TabTemplate 內的支援範本清單。(Idc5d6)。

修正錯誤

  • 移除新平台 API 存取權的手動設定,因為在使用 AGP 7.3 以上版本 (例如 R8 3.3 版) 的 R8 時,以及在使用 AGP 8.1 以上版本 (例如 D8 8.1 版) 的所有版本時,系統會透過 API 模擬功能自動執行此操作。建議未使用 AGP 的用戶端更新至 D8 8.1 以上版本。詳情請參閱這篇文章。(I9496cb/345472586)。

1.7.0-beta01 版

2024 年 6 月 26 日

發布 androidx.car.app:app-*:1.7.0-beta01。1.7.0-beta01 版包含這些修訂版本。功能與 alpha01 版本相同,請參閱下方說明:

新功能

  • 含有內容的地圖:新範本包含地圖畫布和內容範本,目前可選範本為清單、格線、窗格和訊息。
    • RoutePreviewPlaceListNavigationMapTemplate 現已淘汰。範本會照常運作。
    • 範例應用程式已更新,以便顯示 MapWithContent 用法,而非已淘汰的範本
  • 對話項目:新的 API,可在車內顯示對話 (即時通訊、簡訊) 和 Google 助理朗讀內容。
  • 車輛尺寸:用於擷取車輛尺寸的新 API (目前在 AAOS 上提供資料)。

API 變更

  • @ExperimentalCarApi 標記新增至 MediaPlaybackTemplate.Builder。(Ic1957)
  • 在實驗功能中新增 SectionedItemTemplate。(I5958a)。
  • 推出 CarAppApiLevel 8 (I3fa22)
  • 新增 MediaPlaybackTemplate,以便在 Car App Library 中顯示媒體播放內容。(I3c10d)
  • 新增 API,讓應用程式偵測系統是否支援在駕駛時播放背景音訊 (I0f868)

修正錯誤

  • 修正 CAL 用戶端程式碼和 CAL 導覽範例應用程式中特定記憶體流失和當機的情況。(I55e04)
  • 請將 BaseCarAppActivityonDestroy 方法中的 requireNotNull instances 替換為 if-null 檢查,以免發生當機情形。(Iec676)。

1.7.0-alpha02 版

2024 年 4 月 17 日

發布 androidx.car.app:app-*:1.7.0-alpha02。1.7.0-alpha02 版包含這些修訂項目

新功能

  • 為地圖式範本新增已淘汰的標記,MapWithContent 範本日後將支援這些標記。

API 變更

  • 淘汰舊版 MapTemplateRoutePreviewNavigationTemplatePlaceListNavigationTemplate,並鼓勵使用新版 MapWithContentTemplate (Ib0a08)

1.7.0-alpha01 版

2024 年 4 月 3 日

發布 androidx.car.app:app-*:1.7.0-alpha01。我們已將程式庫版本編號系統改為與目前的 CarApi 版本相符。這項做法是根據開發人員的意見回饋,以減少命名慣例的混淆情形。因此,我們會略過 1.5 / 1.6 版,直接改為 1.7 版。1.7.0-alpha01 版包含這些修訂項目

新功能

  • 含有內容的地圖:新範本名為 MapWithContent,可在地圖中支援清單 / 格狀 / 窗格 / 訊息做為內容。
    • RoutePreviewPlaceListNavigation、地圖範本現已淘汰。
    • 範例應用程式已更新,可顯示使用 MapWithContent 的已淘汰範本功能。
  • 對話項目:新的 API,可在車內顯示對話 (即時通訊、簡訊) 和 Google 助理朗讀內容。
  • 車輛尺寸:用於擷取車輛尺寸的新 API (目前在 AAOS 上的資料)。

API 變更

  • 將額外的小型資料列圖片類型標示為實驗性質 (I5184b)
  • 新增 CarInfo#fetchExteriorDimensions API,可存取車輛外部尺寸資訊,例如高度、寬度等 (Ia40c5)
  • MapWithContentTemplate 移除 ExperimentalAPI 標記 (I66db8)
  • 請將 GridItem#setTitle 參數更新為可為空的參數。(I3d610)。
  • GetHeader API 不需要 API 7,因為它具有回溯相容性 (I8c812)
  • ListTemplate 中新增對 Header 的支援,淘汰 headerActionheaderTitleactionStrip (I7ae01)
  • 淘汰 GridTemplate 中的 titleheaderActionactionStrip,並新增對 Header 的支援 (I41a9c)
  • 移除實驗 API 的 7 級規定:徽章、GridTemplate 項目大小和圖片形狀 getter/setter、GridItem 用於取得/設定徽章的方法。(Id71eb)
  • 淘汰 PaneTemplate 中的 titleheaderActionactionStrip,新增 Header 支援 (I23154)
  • 將 Media Center 追蹤資料從 BroadcastReceiver 變更為 Browse Custom Action。(I4185f)。
  • MessageTemplate 新增 Header 屬性支援。已淘汰對 ActionStripheaderActiontitle 的支援。(Ie2de8)
  • 修改警示常數的瀏覽權限 (Icf8a8)
  • 從父項範本中移除 isLoading 屬性 (I651e6)
  • 新增額外項目,向媒體應用程式告知主要 UI 參數 (I85ca2)
  • MediaExtensions 中新增媒體中心分析功能 (I7ce28)
  • 新增資料列上超小圖片的選項。(I72c03)。

修正錯誤

  • 更新 ConversationItem 上的 javadoc,指出訊息應按最舊到最新的順序排序。(I77a2a)。
  • 更新 ListTemplate 截斷邏輯,從 ConversationItem 中移除最舊的訊息 (Ie0a61)

1.4 版

1.4.0 版本

2024 年 5 月 29 日

發布 androidx.car.app:app-*:1.4.0。1.4.0 版是 1.4.0-rc02 的升級版。

自 1.3.0 版以來的重要異動

  • 為導航應用程式提供儀錶板地圖算繪
  • 全新分頁範本,可改善應用程式的版面配置 / 可用性
  • 支援自適應工作限制
  • 清單元素的次要動作

1.4.0-rc02 版

2023 年 12 月 13 日

發布 androidx.car.app:app-*:1.4.0-rc021.4.0-rc02 版包含以下修訂項目。僅修正小錯誤

修正錯誤

  • 更新 ConversationItem 的 javadoc,指出訊息應按時間順序從最舊到最新排序 (I77a2a)
  • 更新 ListTemplate 截斷邏輯,從 ConversationItem 中移除最舊的訊息 (Ie0a61)

1.4.0-rc01 版本

2023 年 11 月 1 日

已發布「androidx.car.app:app-*:1.4.0-rc01」,目前沒有任何重大異動。1.4.0-rc01 版包含以下修訂項目。

1.4.0-beta02 版本

2023 年 9 月 20 日

發布 androidx.car.app:app-*:1.4.0-beta021.4.0-beta02 版包含以下修訂項目。這幾乎與 beta01 相同,但將 compileSdk 需求降至 33。

修正錯誤

  • 修正分頁無法正確顯示載入畫面的錯誤。(cae860)。

1.4.0-beta01 版本

2023 年 8 月 9 日

發布 androidx.car.app:app-*:1.4.0-beta011.4.0-beta01 版包含以下修訂項目。

注意:1.4-beta01 需要 compileSdk34,但後者仍處於開發狀態。1.4-beta02 會修正這個問題。或者,您也可以在專案的 settings.gradle 檔案中新增 android.suppressUnsupportedCompileSdk=34,暫時安全地抑制警告。

新功能

API 變更

  • 請參閱 alpha02

1.4.0-alpha02 版

2023 年 7 月 26 日

發布 androidx.car.app:app-*:1.4.0-alpha02查看 1.4.0-alpha02 版的修訂項目

  • Alpha02 版本的發布,是為了即將推出的 beta01 版本做準備。

新功能

  • 支援導航應用程式在儀錶板上轉譯地圖
  • 新增應用程式分頁,改善版面配置體驗
  • 新增清單 / 格狀範本轉譯選項
  • 新增天氣和通訊類別
  • 將多個 API 移至下一個 CarApi 7 版本

API 變更

  • 將多媒體欄位新增至 CarMessage (I5aaf6)
  • 在 Car App Library 中新增自訂動作至 ConversationItem (Ie5ed6)
  • 新增額外項目,指出媒體項目是以沉浸式音訊格式播放,並顯示內容格式標誌 (Icb5bb)
  • 新增 Action 類型,ActionsConstraints API 可支援 Compose 按鈕。(I31661)
  • set/getTemplate 設為 set/get ContentTemplate (Ica036)
  • 範本參數現在會是 @NonNull。已更新 MapWithContentTemplate API 說明文件 (I0f8ed)
  • 移除 CAL 1.4 啟動時,ListTemplate 中動作的 @ExperimentalCarApi 標記 (I2cfcb)
  • 移除 TabTemplate@ExperimentalCarApi 標記 (Ifcb82)
  • 從資料列次要動作和裝飾中移除 @ExperimentalCarApi 註解 (I8487e)
  • 將有效分頁內容 ID 新增至 TabTemplate,並淘汰分頁的有效狀態 (I96932)
  • GridTemplate 中新增 ItemImageShape 屬性 (Ibf431)
  • ItemSize 屬性新增至 GridTemplate,以便根據相對較小、中等和大型值區控制格狀項目大小。(Icdb3b)。
  • 開放 API 存取權,讓開發人員取得目前畫面堆疊的副本。(I48107)。
  • 在 Car App Library 中新增天氣應用程式類別 (I2be44)
  • 在 Car App Library 中新增呼叫應用程式類別 (Icab33)
  • 已將 GridItem.Builder#setBadge() 替換為已過載的 setImage() 方法 (Id2000)
  • 為 Badge 新增圖示屬性 (I629b2)
  • 新增方法,用於設定圓點徽章的背景顏色 (I6411c)
  • 將徽章屬性新增至 GridItem,讓徽章顯示在 GridItem 圖片上方。(I95de7)。
  • 新增實驗性徽章物件,代表在圖片上顯示的徽章。(I9878d)。

1.4.0-alpha01 版

2023 年 2 月 22 日

發布 androidx.car.app:app-*:1.4.0-alpha01查看 1.4.0-alpha01 版的修訂項目

API 變更

  • 在 Car App Library 中新增頂層動作至 GridTemplate (Id0191)
  • 在 Car App Library 中新增頂層動作至 ListTemplate (I9efab)
  • 新增額外項目,以連結媒體項目的字幕或其他媒體項目的說明 (Ic84bf)
  • 將資料列動作的 API 級別更新為級別 6。(Ie0a69)
  • 新增訊息回呼至 A4C (Ie3986)

修正錯誤

  • CarMessage 新增缺少的 Java 文件參照。(I5db1c)。
  • 覆寫 ConversationItemCarMessageequals()hashCode() (I6fd10)
  • 改善 ConversationItem.mMessages 驗證 (需要非空值、非空白) (Iafc51)
  • @Keep 註解新增至 ConversationItem 欄位 (I5d250)
  • 更新 java 文件,以便使用列裝飾和次要動作。(I000b6)

1.3 版本

1.3.0-rc01 版本

2022 年 12 月 7 日

發布 androidx.car.app:app-*:1.3.0-rc01查看 1.3.0-rc01 版的修訂項

  • beta01 的小修正錯誤。沒有重大變更。

1.3.0-beta01 版本

2022 年 9 月 7 日

發布了 androidx.car.app:app:1.3.0-beta01androidx.car.app:app-projected:1.3.0-beta01androidx.car.app:app-automotive:1.3.0-beta01androidx.car.app:app-testing:1.3.0-beta011.3.0-beta01 版本包含以下修訂項目。

新功能

除了 Car App Library 1.3.0-alpha01 中添加的功能外,下列功能已成為 Beta01 的一部分 (這裡的所有功能都涉及主機端變更,而不含任何 API 變更):

  • 即使使用者位於 PlaceListNavigationTemplateRoutePreviewNavigationTemplateMapTemplate 中的地圖式選取畫面中,浮動導覽列仍會繼續顯示。方法是透過 NavigationManager.updateTrip() 更新導航資訊。
  • 啟用含有 FLAG_DEFAULT 的動作按鈕,即可設定逾時動畫。逾時後,系統將根據預設點擊這個按鈕。([API 5 - All Templates])
  • 當車輛停放時,Row 的子文字不會遭到截斷,但開車時會截斷成 2 行。([API 5 - All Templates])
  • 支援 ActionToggleRow ([API 5 - All Templates]) 的停用狀態

API 變更

  • 放寬 MapTemplate 清單中的限制,以支援可選取的清單 (I961ed)
  • 移除標頭動作的限制條件來允許自訂圖示。(Iad28f)
  • 將限制 setOnClickListenerAllowed() 新增至 ActionsConstraints。允許 ActionOnClickDelegate() 設為標準圖示類型以外的動作。(TYPE_APP_ICONTYPE_BACKTYPE_PAN) (I3c745)

修正錯誤

1.3.0-alpha01 版本

2022 年 7 月 27 日

發布了 androidx.car.app:app:1.3.0-alpha01androidx.car.app:app-projected:1.3.0-alpha01androidx.car.app:app-automotive:1.3.0-alpha01androidx.car.app:app-testing:1.3.0-alpha011.3.0-alpha01 版包含以下修訂項目。

加上 API 級別 5 註解的功能可相容於 Android Auto 7.9 以上版本。

新功能

  • API 級別 5:導航應用程式可以使用新的 MapTemplate 在地圖旁顯示窗格或清單內容 (If5826If44b8)
  • API 級別 5:新的 CarAudioRecord API 可透過主機車輛的麥克風錄製音訊輸入內容 (I5e71a)
  • API 級別 5:新的 SuggestionManager API 可讓應用程式為主機使用者提供建議事項 (I5c103)
  • API 級別 5:新的 Alert API 可在 NavigationTemplate 按照內容顯示通知 (I163a7I5ad70)
  • API 級別 5:新的 HeaderMapController 元件可橫跨多個範本重新使用內容 (If5826)
  • 新增 androidx.car.app.category.POI 做為啟用搜尋點應用程式用的類別 (並淘汰 androidx.car.app.category.PARKINGandroidx.car.app.category.CHARGING) (I59da1)

API 變更

  • API 級別 5:SurfaceCallback 介面提供新的 onClick 方法,可讓使用者輕觸地圖進行互動 (Ia9777)
  • API 級別 5:新的旗標 Action.FLAG_IS_PERSISTENTAction.FLAG_DEFAULT 可用來描述 Action (I96318I5ad70)
  • API 級別 5:ActionRowToggle 元件可使用新的啟用/停用狀態 (主機支援約可在 1.3.0-beta01 左右的程式庫版本提供) (Id8a09)
  • API 級別 5:偏好使用 setHeaderPlaceListNavigationTemplate.BuilderRoutePreviewNavigationTemplate.Builder 提供的新 Header 元件,並淘汰現有的 setTitlesetHeaderAction 方法 (I30e6a)
  • API 級別 5:PlaceListMapTemplate.BuilderPlaceListNavigationTemplate.Builder 上的新 setOnContentRefreshListner 方法,可搭配新的 OnContentRefreshListner 介面實作使用。
  • API 級別 5:TravelEstimate.Builder 新的 setTripTextsetTripIcon 可用來自訂預估交通資訊卡片內容 (Idcc6dIc620d)
  • PaneTemplate 名稱中加入 CarIconSpan 的支援 (Ia1ee0)
  • Row 名稱及文字中加入 CarIconSpan 的支援 (Ic1e3c)
  • 地圖 ActionStrip 現在最多可以設定四個操作 (If3522)
  • 將 Car App API 級別更新至 5 (I26b8e)
  • PlaceListMapTemplatePlaceListNavigationTemplateRoutePreviewNavigationTemplateGridTemplateListTemplateLongMessageTemplateMessageTemplatePaneTemplateSignInTemplate 的標頭/名稱已變為選填內容 (I2078dIcadde)

修正錯誤

  • 更新 PaneTemplate 圖片大小大小規則為正方形定界框 (Idd72e)
  • 修正在 State.DESTROYED 之後修改畫面堆疊時發生的例外狀況 (I3c8eb)。
  • 新增了接收應用程式圖示的空值檢查 (I3f710)
  • 更新 Car Hardware API,使其預設使用 STATUS_UNKNOWN 而非 STATUS_UNAVAILABLE (Ic9444)
  • 在建立途徑前檢查是否有螢幕 (Ice027a)
  • 修正與 STATUS_UNIMPLEMENTED 相關的 CarValue.equals() 錯誤 (I24451)

1.2 版本

1.2.0 版本

2022 年 11 月 9 日

發布 androidx.car.app:app-*:1.2.01.2.0 版包含此連結所列的修訂項目。

  • 這是穩定版,與 v1.2.0-rc01 相比沒有任何異動。

1.2.0-rc01 版本

2022 年 3 月 23 日

發布 androidx.car.app:app-*:1.2.0-rc01查看 1.2.0-rc01 版的修訂項目

  • 這是穩定版,與 v1.2.0-beta02 相比沒有任何 API 變更。新增實驗功能 (API 級別 5),預計在 Android Auto 和 Android Automotive 的未來版本中推出。

修正錯誤

  • 修正在 State.DESTROYED 之後修改畫面堆疊時發生的例外狀況 (I3c8eb)。
  • 更新 CarSensors API,表示 AAOS 並未導入這些 API (Idd57b)
  • 更新 PlaceListMapTempalte.Builder#setCurrentLocationEnabled,表示 ACCESS_COARSE_LOCATION 已可滿足未來的需求 (I510c2)
  • 讓有指定角度的環島路駕駛方式可自選出口號碼 (Ife7d1)

1.2.0-beta02 版

2022 年 1 月 26 日

發布 androidx.car.app:app-*:1.2.0-beta021.2.0-beta02 版包含此連結所列的修訂項目。

凡是使用這個程式庫版本建立並指定 Android Automotive OS 平台的車輛應用程式,現在都可以發布到 Play 商店公開測試管道了。詳情請參閱開發指南

加上 API 級別 4 以下註解的功能可相容於 Android Auto 7.2 以上和新的 Android Automotive OS 平台。請參閱下方的 Known Issues 一節,瞭解注意事項。

API 變更

  • 已將實驗性 setOnContentRefreshListener API 新增到搜尋點範本 (I6bf22)

修正錯誤

  • 修正了車輛主機解除繫結時,CarAppService 中的記憶體流失問題。(I5c9cab/203594731)。
  • 更新 CarAppActivity javadoc,為 singleTask 啟動模式納入相關規定 (Id2f95)
  • 減少繼續使用時的視覺故障。(Iff7e0)

已知問題

  • PlaceListNavigationTemplateRoutePreviewNavigateTemplate 中的地圖 ActionStrip 將於下一個 Android AutoAndroid Automotive OS 版本中推出。

1.2.0-alpha02 版本

2021 年 12 月 15 日

發布 androidx.car.app:app-*:1.2.0-alpha021.2.0-alpha02 版包含此連結所列的修訂項目。

加上 API 級別 4 註解的功能已從實驗版升級為穩定版,包括 PlaceListNavigationTemplateRoutePreviewNavigateTemplate 中的地圖 ActionStripPane 中的 CarIcon 圖片、QRCodeSignInMethod 和在 Action 中設定算繪提示的功能 (例如旗標)。

新功能

  • 在 Android Auto 7.1 以上版本中,Pane 的項目上限已從 2 個增加到 4 個。

API 變更

  • 已將實驗性的 toString() 方法新增至 CarUnit(I36a3b)

修正錯誤

  • 修正了回呼失敗時 CarAppPermissionActivity 中發生的當機問題 (If9823)
  • 已將 Pane 預設清單上限變更為 4 (I0068b)

1.2.0-alpha01 版本

2021 年 11 月 3 日

發布 androidx.car.app:app-*:1.2.0-alpha011.2.0-alpha01 版包含以下修訂項目。

所有新的 v1.2.0 功能 (API 4+) 目前都在實驗階段,目標是在未來的 Android Auto 和 Android Automotive OS 版本中推出。詳情請參閱開發指南

API 變更

  • AutomotiveCarInfo API 進入實驗階段 (Ia13e5)
  • 新增了 Car App Library API 級別 4 (I2a2e7)
  • API 級別 4:新增了在 Pane 中設定 CarIcon 的支援功能 (Ifcc12)
  • API 級別 4:新增了 QR 圖碼登入方法 (Ib623e)
  • API 級別 4:在 Action 中新增了設定/getFlags (Ic03ab)
  • API 級別 4:新增了在 PlaceListNavigationTemplateRoutePreviewNavigationTemplate 中支援平移和縮放的功能 (I9d8a3)

修正錯誤

  • API 級別 4:新增了允許應用程式將位置更新通知傳送至車輛主機的機制 (I3bad3)
  • 修正主機驗證邏輯無法正確尋找 TEMPLATE_RENDERER 權限的問題 (I62618)

1.1.0 版本

1.1.0 版本

2021 年 12 月 15 日

發布 androidx.car.app:app-*:1.1.0查看 1.1.0 版的修訂項

這是穩定版,與 v1.1.0-rc01 相比沒有任何異動。另請參閱 v1.2.0-alpha02 的版本資訊,進一步瞭解車輛應用程式程式庫的新功能。

自 1.0.0 版以來的重要變更

  • API 級別 2:車輛停放時可用於登入流程的 SignInTemplateLongMessageTemplate
  • API 級別 2:NavigationTemplate 中的地圖互動支援
  • API 級別 2:支援多重長度文字,讓應用程式能根據車輛螢幕尺寸提供多個版本的字串以供顯示。
  • API 級別 3:可用來查詢車輛硬體資料 (例如型號和品牌、油量和其他感應器) 的 CarHardwareManager

1.1.0-rc01 版本

2021 年 11 月 3 日

發布 androidx.car.app:app-*:1.1.0-rc011.1.0-rc01 版包含此連結所列的修訂項目。

這是穩定版,與 v1.1.0-beta01 相比沒有任何 API 變更。已新增實驗性功能 (API 級別 4),可望在 Android Auto 未來的版本中推出。如要進一步瞭解實驗性 API,請參閱 v1.2.0-alpha01 的版本資訊。

1.1.0-beta01 版本

2021 年 9 月 1 日

發布 androidx.car.app:app-*:1.1.0-beta011.1.0-beta01 版包含此連結所列的修訂項目。

所有 v1.1.0 功能 (API 2+) 都完全相容於 Android Auto 6.7 以上版本。詳情請參閱開發指南

API 變更

  • 不再以 Manager 做為公開介面 (Ie381b)
  • 新增了為權限要求設定自訂品牌背景的功能 (I74b76)
  • 新增了 ScreenManager.getStackSize (I0b16a)
  • 移除了會明確採用 TestCarContextScreenController 建構函式 (Iefebc)

修正錯誤

  • 新增了建立 CarHardwareManager 時的 API 級別檢查 (I48f9b)
  • 針對整個 API 的無效 CarSpan 用途新增檢查作業 (I65ae6)
  • 修正了以下問題:如果 Screen 在建立期間標示為完成,會使堆疊處於損毀狀態 (I81b13)
  • 修正以下問題:如果 CarAppExtender 中有含圖示的動作,則 CarNotificationManager.notify 會為 AutomotiveOS 記錄一次錯誤 (I3633d)
  • 為應用程式和主機新增握手方法,以建立 API 版本 (I7d6f8)

1.1.0-alpha02 版本

2021 年 7 月 21 日

發布 androidx.car.app:app-*:1.1.0-alpha02查看 1.1.0-alpha02 版的修訂項

新功能

  • API 級別 3:新增了 CarHardwareManager,可用來查詢車輛硬體資料,例如型號和品牌、油量和其他感應器。這項功能目前只開放 Android Auto 6.7 以上版本在公開測試頻道中使用。如要在電腦環境中測試這項功能,則需要使用新版 Desktop Head Unit (將另行發布)。請密切關注測試 Android 車輛應用程式網頁,掌握關於新版本推出時間的詳細資訊。
  • 請參閱開發指南和程式庫參考資料瞭解詳情;設計指南則可協助您瞭解如何使用這些相容於 API 級別 3 的車輛主機中的功能。

API 變更

  • SessionControllerScreenController 生命週期方法合併至單一 moveToState 方法 (I1ed00)
  • 新增了 CarContext#getHostInfo() (I8977e)
  • 移除已淘汰的欄位 (I67168)
  • 更新 SessionControllerScreenController 以直接顯示建構函式 (Iabf22)
  • 移除 PinSignInMethod.BuilderProviderSignInMethod.Builder (I9f0cb)
  • 新增了「setCarAppResult()」以啟用在 AAOS 中使用範本應用程式「for result」的功能 (I37741)
  • @MainThreadCarHardware 介面加註。(Ib2f85)
  • OnCarDataListener 已重新命名為 OnCarDataAvailableListener (I518ca)
  • 更新 CarInfoSpeedMileage 方法名稱和 javadoc (I86672)
  • Toll 已重新命名為 TollCard (I3e7c8)
  • 移除已淘汰的 PinSignInMethod.getPin,替換成 PinSignInMethod.getPinCode (I996ce)
  • 移除 OnInputCompletedListener,替換成 InputCallback (Ib5be1)
  • PinSignInMethod 改為採用 CharSequence 而非 String (I275d5)

修正錯誤

  • 為車輛硬體修正 Javadoc (I2abbc)

外部貢獻

已知問題

  • SignInTemplate 中,使用 InputSignInMethod 可能會在車輛主機中造成 NullPointerException。我們會在下一個程式庫版本中解決這個問題。如要暫時繞過這個問題,請在您應用程式的 ProGuard 設定中納入這一行:-keep class androidx.car.app.model.signin.InputSignInMethod { *; }

1.1.0-alpha01 版本

2021 年 6 月 16 日

發布 androidx.car.app:app:1.1.0-alpha01androidx.car.app:app-automotive:1.1.0-alpha01androidx.car.app:app-testing:1.1.0-alpha011.1.0-alpha01 版包含此連結所列的修訂項目。

新功能

  • API 級別 2:車輛停放時可用於登入流程的新 SignInTemplateLongMessageTemplate
  • API 級別 2:NavigationTemplate 中的新地圖互動支援
  • API 級別 2:支援新的多重長度文字,讓應用程式能根據車輛螢幕尺寸提供多個版本的字串以供顯示。
  • 請參閱開發指南和程式庫 Javadoc 瞭解詳情;設計指南則可協助您瞭解如何使用這些相容於 API 級別 2 的車輛主機中的功能。

API 變更

  • 將所有 *Callback 介面方法設為預設,並將 OnRequestPermissionsCallback 重新命名為 OnRequestPermissionsListener (Ib3ec9)
  • 更新 androidx.car.app.hardware 類別以移除不必要的建構工具和參數類別 (I67beb)
  • 新增了 androidx.car.app.hardware 類別,以存取車輛專屬資料,例如燃料、電池和速度 (Iff3c9)
  • MessageTemplate 上新增了 ActionStrip 支援 (Ida657)
  • setLoading 新增至 MessageTemplate (I2a4b5)
  • ConnectionToCar 已重新命名為 CarConnection (Ife9bd)
  • NavigationTemplate 變更為會傳回明確的 PanModeDelegate (I13877)
  • 更新 CarContext.requestPermissions 的參數順序 (Ib890a)
  • 更新中繼資料金鑰,將最低車輛 API 級別定義為 androidx.car.api.minCarApiLevel (Ib0d41)
  • 建立允許觀察車輛連線狀態的 API (Ifc935)
  • 新增了可為 Action 設定切換開關的功能,並新增了平移模式 Action 類型 (Ica6af)
  • 建立了 CarNotificationManager 以支援在車上傳送通知的功能 (I10d7a)
  • 新增了 ConstraintManager,以提供主機的清單限制 (I8690e)
  • NavigationTemplate 中新增了平移模式和 Google 地圖動作清除 API (I77aa6)
  • SurfaceCallback 中為導航應用程式新增了平移和縮放 API (Id5e9d)
  • CarAppApiLevel 更新為 2 (Ic1540)
  • 新增了可向 CarAppService 要求權限的功能 (I5421e)
  • RequiresCarApi(2) 註解新增至多重文字 API (Iacb62)
  • 在半清單範本標題中允許多種文字變化版本 (Ib8df7)
  • 新增了 LongMessageTemplate (需要 Car API 級別 2) (Ic5cee)

修正錯誤

  • 更新圖片大小規定,以配合較大的車輛螢幕 (I116dc)
  • 不允許在範本內文中加入超過 2 個動作 (I32157)
  • 已確保車輛應用程式程式庫中所有的 PendingIntent 建立作業都會設定旗標。(If84feb/186394900)
  • 更新 javadoc,允許 Row 的文字在重新整理時變更 (If3f9c)
  • androidx.activity:activity:1.2.0 現在是 API 依附元件 (Id1cb9)
  • SignInTemplateLongMessageTemplate 設為在內文中要求僅限停車狀態動作,並更新說明文件,指明只有在車子停好時,才會顯示這兩者 (Iddaa9)
  • 修正了啟動期間彈出 Screen 時發生的例外狀況 (Ifcf40b/184664896)
  • 允許在 ForegroundCarColorSpan 中自訂文字顏色 (I69e59)
  • 修正了在某個 ScreenON_DESTROY 之後,還會看到 Session 上的 ON_DESTROY 的問題 (I52e01b/183696617)
  • 更新 javadoc,說明何時允許將 TravelEstimate 的剩餘時間設為不明的時間。(I99610b/183632456)。
  • 更新 Action,以支援標題中的 ForegroundColorSpan 以及任何自訂背景色彩 (I578e4)
  • 如果在執行工具執行前已清除回呼,就不執行 NavigationManagerCallback#onStopNavigation (I7fc5eb/181143772)
  • 修正了以下問題:要求應用程式必須在 lifecycle-common-java8 上明確採用依附元件 (I8b8c8)

已知問題

  • SignInTemplate 中,當使用者想要確認輸入內容時,螢幕小鍵盤會顯示「搜尋」圖示,而不是「輸入」圖示。輸入欄位成為焦點時,系統會啟動手機鍵盤,使用者可以存取這個鍵盤,當做暫時的因應方法。
  • 在 Android Auto 6.5 版中,某些觸控手勢可能會錯誤叫用 SurfaceCallback 中的平移和縮放回呼。

車輛應用程式 1.0.0 測試版

1.0.0-alpha01 版

2021 年 3 月 24 日

發布 androidx.car.app:app-testing:1.0.0-alpha011.0.0-alpha01 版本包含以下修訂項目。

這是先前關閉的原始碼測試程式庫的第一個 Jetpack 版本。請參閱範例,瞭解如何在測試中使用這個程式庫。

新功能

  • 已移除模型類別的控制器。模型 getter 現已併入公用 API 介面,可供驗證在建構工具中設定的值。
  • 先前的 CarAppServiceController 已由新的 SessionController 取代,用來測試與熱點連線生命週期相關的邏輯。

1.0.0 版本

1.0.0 版本

2021 年 4 月 21 日

發布了 androidx.car.app:app:1.0.01.0.0 版包含此連結所列的修訂項目。

1.0.0 的主要功能

  • 我們在 4 月初宣布過,應用程式可以開始使用 androidx.car.app:app:1.0.0-rc01 發布到正式版頻道。車輛應用程式程式庫 v1.0.0 版現已穩定,與 Android Auto 6.1 以上版本完全相容。
  • 請參閱開發指南,進一步瞭解如何使用程式庫為 Android Auto 建構導覽、停車位和充電應用程式。

修正錯誤

  • 修正了啟動期間彈出 Screen 時發生的例外狀況 (70aae1b/184664896)
  • 修正了在某個 ScreenON_DESTROY 之後,還會看到 Session 上的 ON_DESTROY 的問題 (0ceecbb/183696617)

1.0.0-rc01 版

2021 年 3 月 24 日

發布 androidx.car.app:app:1.0.0-rc011.0.0-rc01 版包含以下修訂項目。

修正錯誤

  • 修正了系統清除回呼後會呼叫 NavigationManagerCallback#onStopNavigation 的競爭狀況錯誤。如果在回呼執行工具實際運作之前,回呼已經清除,則會發生這種狀況 (I7fc5eb/181143772)
  • 修正了以下問題:要求應用程式必須在 lifecycle-common-java8 上明確採用依附元件 (I8b8c8)
  • 修正了以下問題:應用程式在已經移除回呼的情況下收到 stopNavigation 時,系統擲回 NullPointerException (Ib8b89b/181143772)
  • 改善以下狀況:如果應用程式生命週期未處於至少 CREATED 狀態,就不調派呼叫給應用程式 (I86965b/179800224b/177921120)
  • 修正了以下問題:系統會擲回應用程式的資訊清單中指定的無效最低 API,造成主機上發生 ANR (Iffeddb/174231592)。

1.0.0-beta01 版

2021 年 2 月 24 日

發布 androidx.car.app:app:1.0.0-beta011.0.0-beta01 版包含此連結所列的修訂項目。

這是先前關閉的原始碼程式庫的第一個 Jetpack 版本,相容於 Android Auto 6.1 以上版本。請參閱開發指南,進一步瞭解如何使用程式庫建構車輛應用程式。

新功能

修正錯誤

  • 修正了以下問題:連續彈出螢幕時,系統會恢復使用錯誤的 Screen (b/177590791)