tv

  
Menyediakan fungsi Compose dan Desain material kepada developer agar dapat menulis aplikasi untuk TV
Update Terbaru Rilis Stabil Kandidat Rilis Rilis Beta Rilis Alfa
1 Mei 2024 - - 1.0.0-beta01 -

Mendeklarasikan dependensi

Untuk menambahkan dependensi pada tv-foundation dan tv-material, Anda harus menambahkan repositori Maven Google ke project Anda. Baca repositori Maven Google untuk mengetahui informasi selengkapnya.

Tambahkan dependensi untuk artefak yang diperlukan dalam file build.gradle bagi aplikasi atau modul Anda:

Groovy

dependencies {
    implementation "androidx.tv:tv-foundation:1.0.0-alpha10"
    implementation "androidx.tv:tv-material:1.0.0-beta01"
}

Kotlin

dependencies {
    implementation("androidx.tv:tv-foundation:1.0.0-alpha10")
    implementation("androidx.tv:tv-material:1.0.0-beta01")
}

Untuk informasi dependensi selengkapnya, lihat Menambahkan dependensi build.

Masukan

Masukan Anda membantu meningkatkan kualitas Jetpack. Beri tahu kami jika Anda menemukan masalah baru atau mempunyai masukan untuk meningkatkan kualitas library ini. Harap periksa masalah yang sudah diketahui dalam library ini sebelum membuat laporan baru. Anda dapat memberikan suara untuk masalah yang sudah diketahui dengan mengklik tombol bintang.

Laporkan masalah baru

Lihat dokumentasi Issue Tracker untuk informasi selengkapnya.

Tidak ada catatan rilis untuk artefak ini.

Tv-Material Versi 1.0

Versi 1.0.0-beta01

1 Mei 2024

androidx.tv:tv-material:1.0.0-beta01 dirilis. Versi 1.0.0-beta01 berisi commit ini.

Perubahan API

  • ColorScheme dan fungsi utilitasnya kini stabil. (If34fa)
  • LocalContentColor sekarang stabil (I60ee2)
  • Typography API kini stabil (I088d6)
  • Shapes API kini stabil (I0f5f4)
  • Border API kini stabil (I69281)
  • Glow API kini stabil (Iea5f1)
  • Komponen ikon kini stabil (I62c2d)
  • LocalTextStyles API kini stabil (Iaded8)
  • MaterialTheme API kini stabil (I2f541)
  • Komponen Teks kini stabil (Ib9e31)
  • Komponen RadioButton kini stabil (Ia03c8)
  • Komponen tombol akses kini stabil (I6cea3)
  • Komponen Checkbox kini stabil (I7eafc)
  • Komponen permukaan kini stabil (I58758, I04aca)
  • Mengganti nama NonInteractiveSurfaceDefaults menjadi SurfaceDefaults, dan NonInteractiveSurfaceColors menjadi SurfaceColors (I0812e)
  • Selectable Surface kini menggunakan terminologi “select”, bukan “check” karena keduanya memiliki arti semantik yang berbeda (I5a206)
  • NavigationDrawer dan NavigationDrawerScope kini stabil (I249c1)
  • Komponen NavigationDrawerItem kini stabil (Id6986)
  • Komponen tab dan TabRow kini stabil (I92d92)
  • Komponen Button, OutlinedButton, IconButton, OutlinedIconButton, dan WideButton kini stabil (Ib4de8)
  • Komponen Card, ClassicCard, CompactCard, WideClassicCard, StandardCardContainer & WideCardContainer kini stabil (I34390)
  • Mengganti nama StandardCardLayout menjadi StandardCardContainer, dan WideCardLayout menjadi WideCardContainer (I08883)
  • Menghapus CardContainerDefaults.ImageCard dan mengganti nama CardDefaults.ContainerGradient menjadi CardDefaults.ScrimBrush (I6adfe)
  • ListItem dan DenseListItem kini stabil (Idebd9)
  • ListItemDefaults.ListItemShape, ListItemDefaults.FocusedDisabledBorder & ListItemDefaults.SelectedContainerColorOpacity kini bersifat pribadi (I5d533)
  • Mengatur ulang parameter ListItem & mengganti nama ListItemDefaults.ListItemElevation menjadi ListItemDefaults.TonalElevation (Id6841)
  • LocalAbsoluteTonalElevation kini menjadi internal (Ibfc65)
  • Komponen ImmersiveList telah dihapus. Lihat contoh ini untuk mempelajari cara membuatnya sendiri. Id48da
  • komponen material tv yang mengekspos MutableInteractionSource dalam API-nya telah diupdate untuk kini mengekspos MutableInteractionSource nullable yang secara default menampilkan null. Tidak ada perubahan semantik di sini: meneruskan null berarti Anda tidak ingin mengangkat MutableInteractionSource, dan kode akan dibuat di dalam komponen jika diperlukan. Mengubah ke null memungkinkan beberapa komponen untuk tidak pernah mengalokasikan MutableInteractionSource, dan memungkinkan komponen lain untuk hanya membuat instance secara lambat saat diperlukan, sehingga meningkatkan performa di seluruh komponen ini. Jika Anda tidak menggunakan MutableInteractionSource yang diteruskan ke komponen ini, sebaiknya Anda meneruskan null sebagai gantinya. Sebaiknya Anda juga membuat perubahan yang serupa pada komponen Anda sendiri. (I309b4, b/298048146)
  • Parameter TextAlign komponen Teks TV kini non-null (Ib73b1, b/299490814)
  • Memperkenalkan nilai khusus yang Tidak Ditentukan untuk kolom TextAlign, TextDirection, Hyphens, dan LineBreak dari ParagraphTextStyle yang akan diganti (I4197e, b/299490814)

Versi 1.0.0

Versi 1.0.0-alpha10

4 Oktober 2023

androidx.tv:tv-foundation:1.0.0-alpha10 dan androidx.tv:tv-material:1.0.0-alpha10 dirilis. Versi 1.0.0-alpha10 berisi commit ini.

Fitur Baru

  • Memperkenalkan NavigationDrawerItem untuk digunakan dalam NavigationDrawer dan ModalNavigationDrawer. (I4b491)
  • Menambahkan profil dasar pengukuran ke library dasar tv. (2b57fd7)
  • Menambahkan profil dasar pengukuran ke library materi tv. (1711ff5)

Perubahan API

  • Mengganti nama NavigationDrawerScope.doesTabRowHaveFocus menjadi NavigationDrawerScope.hasFocus. (I8286b)
  • Mengganti nama TabRowScope.isActivated menjadi TabRowScope.hasFocus. (IC4273)

Perbaikan Bug

  • Memperbaiki kompatibilitas Carousel dengan item di dekatnya yang menggunakan API pemulih fokus. (7b2a7a4)
  • Nonaktifkan indikasi glow untuk API_LEVEL di bawah 28 karena tidak didukung oleh OS. (6d3616f)
  • Memperbaiki error ANR yang disebabkan oleh penempatan item yang tidak tepat dalam penampung lambat saat scroll cepat dalam arah terbalik. (642d65c)
  • Menghapus padding latar belakang di Panel Navigasi Modal. (69965b2)
  • Memperbaiki Scrim di Panel Navigasi agar digambar di atas konten latar belakang, bukan di belakangnya. (d4bbefb)

Versi 1.0.0-alpha09

6 September 2023

androidx.tv:tv-foundation:1.0.0-alpha09 dan androidx.tv:tv-material:1.0.0-alpha09 dirilis. Versi 1.0.0-alpha09 berisi commit berikut ini.

Perubahan API

  • Menambahkan antarmuka ReusableComposition untuk mengelola siklus proses dan penggunaan kembali subkomposisi. (I812d1, b/252846775)
  • Sinkronkan garpu foundation tv dengan fondasi pembuatan. (I737c3, b/287011882)
  • Kelebihan LazyLayout yang ditambahkan akan menerima lambda LazyLayoutItemProvider, bukan objek biasa seperti sebelumnya. Overload sebelumnya tidak digunakan lagi. (I42a5a)
  • Tambahkan TvKeyboardAlignment untuk memungkinkan developer mengonfigurasi posisi keyboard virtual melalui AndroidImeOptions. Idb772
  • Menambahkan rememberCarouselState untuk mengingat CarouselState dengan Saver ke TV Compose Material. Id7275
  • Mengubah parameter scrimColor: Color menjadi parameter scrimBrush:Brush untuk memungkinkan pengguna menambahkan gradien ke scrim. (I254d4)

Versi 1.0.0-alpha08

26 Juli 2023

androidx.tv:tv-foundation:1.0.0-alpha08 dan androidx.tv:tv-material:1.0.0-alpha08 dirilis. Versi 1.0.0-alpha08 berisi commit berikut ini.

Fitur Baru

  • Memperkenalkan komponen Chip untuk Compose untuk materi TV. (I86da4)
  • Menambahkan komponen ListItem ke TV Compose Material. (I3f0b3)
  • Tambahkan DenseListItemkomponen ke Material Compose TV. (I536bf)

Perubahan API

  • Menandai API materi tv publik sebagai Eksperimental. (I632e7)
  • Memperkenalkan TabRowScope untuk berbagi status dari composable TabRow dengan composable Tab dan mengganti nama properti TabColors. (Ief587)

Versi 1.0.0-alpha07

7 Juni 2023

androidx.tv:tv-foundation:1.0.0-alpha07 dan androidx.tv:tv-material:1.0.0-alpha07 dirilis. Versi 1.0.0-alpha07 berisi commit berikut ini.

Perubahan API

  • Indikasi skala komponen kini menyertakan Tidak ada untuk menonaktifkan penskalaan. (I50df5)
  • Menambahkan dukungan klik lama untuk Platform Material TV, Kartu, dan Tombol. Id2b89
  • CarouselItem dan CarouselScope telah dihapus. Animasi konten latar depan dapat dibuat di slide dengan menggunakan Modifier.animateEnterExit dari AnimatedContentScope. (IC038e)
  • Menggabungkan parameter color dan contentColor sebagai colors untuk Platform Material TV. (Ie69eb)
  • Memperkenalkan composable RadioButton di Material TV. (I08690)
  • Memperkenalkan composable Switch di Material TV. (I45e29)
  • Memperkenalkan composable Checkbox di Material TV. (I6a45a)
  • Memperkenalkan Permukaan yang tidak dapat berinteraksi dalam Materi TV. (IC5f85)
  • Buat indikasi internal. (Ibff82)

Versi 1.0.0-alpha06

19 April 2023

androidx.tv:tv-foundation:1.0.0-alpha06 dan androidx.tv:tv-material:1.0.0-alpha06 dirilis. Versi 1.0.0-alpha06 berisi commit berikut ini.

Fitur Baru

  • Menambahkan implementasi Kartu Material 3 yang dioptimalkan untuk TV.
    • Kartu Dasar (I5b701)
    • ClassicCard, CompactCard, dan WideClassicCard (I70471)
    • StandardCardLayout dan WideCardLayout (I33fae)
  • Menambahkan implementasi Tombol Material 3 yang dioptimalkan untuk TV.

Perubahan API

  • Mengganti nama CarouselSlide dan slideCount di Carousel menjadi CarouselItem dan itemCount. (Ie554c)
  • Mengganti nama forward dan backward ContentTransforms menjadi StartToEnd dan EndToStart. (Ie554c)

Perbaikan Bug

  • Tangani tombol DPAD kembali saat berfokus pada NavigationDrawer. (d654f4)

Versi 1.0.0-alpha05

22 Maret 2023

androidx.tv:tv-foundation:1.0.0-alpha05 dan androidx.tv:tv-material:1.0.0-alpha05 dirilis. Versi 1.0.0-alpha05 berisi commit ini.

Perubahan API

  • Memperkenalkan composable Panel Samping Navigasi ke tv-material. Untuk mempelajari cara menggunakan composable ini, lihat contoh. (I12c08)
  • Memperkenalkan composable Icon di TV Material 3 (I72db9)
  • Memperkenalkan composable Surface ke tv-material dengan indikasi seperti Batas, Kilau, dan Skala, yang dapat digunakan untuk membuat komponen yang menyoroti elemen yang difokuskan dengan jelas di layar TV. (I4a6d8), (Iceea1), (Iee4d4), (I79edf), (Icb376)
  • Mengupdate CarouselItem menjadi CarouselSlide agar cocok dengan nama parameter slideCount di 'Carousel' API (Ic4299)

Versi 1.0.0-alpha04

8 Februari 2023

androidx.tv:tv-foundation:1.0.0-alpha04 dan androidx.tv:tv-material:1.0.0-alpha04 dirilis. Versi 1.0.0-alpha04 berisi commit berikut ini.

Fitur Baru

  • Di baris, kolom, dan petak lambat, pivot akan diganti, jika perlu, untuk memastikan seluruh item ditampilkan. (11d7e40)
  • Menambahkan penyesuaian warna tab dalam berbagai status. (21b2925)
  • Carousel kini menerima animasi kustom untuk scroll manual maju dan mundur. (431494a)

Perubahan API

  • Mengganti nama androidx.tv.material menjadi androidx.tv.material3 dan meratakan struktur paket pada androidx.tv.material3. (I6ca52)
  • Indikator dalam baris Indikator Carousel sekarang menjadi slot yang dapat disesuaikan oleh developer. (268af2a)
  • Mengganti nama focusableItem menjadi immersiveListItem. Pengguna harus menambahkan pengubah focusable() atau clickable() secara manual bersama dengan immersiveListItem (5dd5078)(b/263061052)
  • Mengganti nama timeToDisplayMillis menjadi autoScrollDurationMillis di komponen Carousel. (431494a)
  • CarouselItem kini dibatasi untuk digunakan dalam Carousel. (431494a)
  • Carousel kini menerima ContentTransforms sebagai definisi animasi, bukan EnterTransition dan ExitTransitions. (431494a)
  • Memperkenalkan PinnableContainer API yang disebarkan oleh daftar lambat melalui komposisi lokal yang memungkinkan penyematan item saat ini. (Ib8881, b/259274257, b/195049010)
  • Menambahkan properti mainAxisItemSpacing ke TvLazyListLayoutInfo dan TvLazyGridLayoutInfo (I37765)

Perbaikan Bug

  • Perbarui tab-baris untuk memastikannya menangani jumlah tab ke 0 atau 1 dengan benar. (I44009), (1c01525), (b/264018028)
  • Memperbaiki error penelusuran fokus saat TvLazyColumn berisi TvLazyRow kosong. (e11b4fe), (b/260299091)
  • Pengubah clickable kini berfungsi dengan ImmersiveList. (5dd5078), (b/263061052)
  • Tombol Kembali kini ditangani dan digunakan untuk keluar dari Carousel Unggulan. (84c138c)
  • Carousel tidak kehilangan fokus pada beberapa penekanan tombol cepat. (799489f)
  • Carousel tidak kehilangan fokus pada penekanan tombol yang lama. (b2cf37e)
  • Mengatasi error saat jumlah slide carousel berubah. (b261247)

Versi 1.0.0-alpha03

7 Desember 2022

androidx.tv:tv-foundation:1.0.0-alpha03 dan androidx.tv:tv-material:1.0.0-alpha03 dirilis. Versi 1.0.0-alpha03 berisi commit ini.

Fitur Baru

  • TabRow kini tersedia sebagai API eksperimental yang memungkinkan pengguna menambahkan menu navigasi atas ke aplikasi mereka. Secara umum, perangkat TV berharap tab dimuat saat judul tab difokuskan di baris tab.
  • Indikator khusus TV seperti indikator garis bawah dan indikator pil ditawarkan untuk dapat langsung dipakai. Contoh penggunaan dapat ditemukan di tv-samples

Versi 1.0.0-alpha02

9 November 2022

androidx.tv:tv-foundation:1.0.0-alpha02 dan androidx.tv:tv-material:1.0.0-alpha02 dirilis. Versi 1.0.0-alpha02 berisi commit ini.

Perbaikan Bug

  • Meningkatkan performa scroll saat men-scroll koleksi TvLazyRows/TvLazyColumns dengan mengurangi ruang penelusuran fokus.(I723a3)

Versi 1.0.0-alpha01

5 Oktober 2022

androidx.tv:tv-foundation:1.0.0-alpha01 dan androidx.tv:tv-material:1.0.0-alpha01 dirilis. Versi 1.0.0-alpha01 berisi commit ini.

Fitur Baru

Versi alfa pertama berisi implementasi pratinjau awal dari komponen untuk kasus penggunaan TV, termasuk:

  • Menambahkan pengubah scrollableWithPivot untuk mengizinkan penampung scroll non-lazy seperti Baris, Kolom, Petak agar penampung scroll men-scroll konten sehingga item dalam fokus tetap berada di posisi yang sama pada layar TV.
  • Menambahkan composable TvLazyRow, TvLazyColumn, TvLazyHorizontalGrid, TvLazyVerticalGrid agar penampung scroll men-scroll konten sehingga item dalam fokus tetap berada di posisi yang sama pada layar TV.
  • Menambahkan composable Carousel Unggulan untuk TV yang memungkinkan pengguna membuat carousel banner scroll otomatis.
  • Menambahkan composable Daftar Imersif untuk TV yang memungkinkan pengguna membuat Baris/Kolom/Petak Imersif yang mengubah latar belakang berdasarkan item daftar yang sedang difokuskan.

Masalah umum

  • Saat penampung scroll mendapatkan fokus, elemen pertama tidak mendapatkan fokus secara default.
  • Memfokuskan ke TextField tidak selalu membuka keyboard atau dapat menghambat fokus untuk berpindah ke kolom lain.
  • Scroll secara vertikal di LazyColumn yang berisi LazyRows memiliki performa buruk.