Tema Gelap Otomatis

Chrome 96 memperkenalkan uji coba origin untuk Tema Gelap Otomatis di Android. Dengan fitur ini, browser akan menerapkan tema gelap yang dibuat secara otomatis ke situs bertema terang, saat pengguna memilih tema gelap di sistem operasi. Pengguna dapat memilih tidak menggunakan tema gelap dengan menonaktifkan opsi di tingkat OS atau di setelan tertentu di Chrome.

Mendaftar untuk uji coba origin

Anda juga dapat mengaktifkan algoritma penggelapan untuk pengguna, melalui uji coba origin. Dengan begitu, Anda dapat menguji performa Tema Gelap Otomatis sehubungan dengan KPI Anda.

Buka dokumentasi untuk mempelajari cara menyiapkan uji coba origin, lalu daftar ke uji coba origin AutoDarkMode untuk mendapatkan token.

Menguji Tema Gelap Otomatis di perangkat Anda

Dengan DevTools

Untuk mengaktifkan Tema Gelap Otomatis di DevTools:

  1. Klik menu tiga titik.
  2. Pilih Alat Lainnya, lalu Rendering.
  3. Pilih Aktifkan pada opsi Emulasi mode gelap otomatis.

Di ponsel Android

Untuk menguji Tema Gelap Otomatis di ponsel Android Anda:

  1. Buka chrome://flags dan aktifkan eksperimen #darken-websites-checkbox-in-theme-setting.
  2. Kemudian, ketuk menu tiga titik, pilih Setelan, lalu Tema, dan centang kotak Terapkan Tema gelap ke situs, jika memungkinkan.

Sekarang, halaman terang akan digelapkan di ponsel.

Penyesuaian per elemen

Meskipun kami ingin Tema Gelap Otomatis menghasilkan hasil yang baik dalam semua kasus, percakapan awal dengan developer menunjukkan bahwa mereka ingin menyesuaikan elemen tertentu, agar lebih sesuai dengan tampilan dan nuansa yang diinginkan.

Dalam uji coba origin ini, penyesuaian tersebut dapat dilakukan menggunakan JavaScript untuk mendeteksi apakah pengguna menggunakan Tema Gelap Otomatis, lalu menyesuaikan elemen yang diinginkan.

Mendeteksi Tema Gelap Otomatis

Untuk mendeteksi apakah pengguna menggunakan Tema Gelap Otomatis, buat elemen dengan background-color yang disetel ke canvas dan skema warna disetel ke terang. Jika warna yang dikomputasi untuk latar belakang selain putih (rgb(255, 255, 255)), Tema Gelap Otomatis akan diterapkan ke halaman.

<div id="detection"
     style="display: none; background-color: canvas; color-scheme: light">
</div>
const detectionDiv = document.querySelector('#detection');
// If the computed style is not white then the page is in Auto Dark Theme.
const isAutoDark = getComputedStyle(detectionDiv).backgroundColor != 'rgb(255, 255, 255)';
// Update element styles when Auto Dark Theme is applied.
if (isAutoDark) {
  const myElement = document.querySelector('#my-element');
  myElement.classList.add('autoDarkOnlyStyle');
}

Menyesuaikan sejumlah besar elemen

Solusi di atas mungkin sulit diskalakan jika Anda perlu menyesuaikan lebih banyak elemen. Alternatifnya adalah menggunakan deteksi Tema Gelap Otomatis untuk menambahkan class penanda ke isi halaman:

function setAutoDarkClass() {
  // We can also use JavaScript to generate the detection element.
  const detectionDiv = document.createElement('div');
  detectionDiv.style.display = 'none';
  detectionDiv.style.backgroundColor = 'canvas';
  detectionDiv.style.colorScheme = 'light';
  document.body.appendChild(detectionDiv);
  // If the computed style is not white then the page is in Auto Dark Theme.
  const isAutoDark = getComputedStyle(detectionDiv).backgroundColor != 'rgb(255, 255, 255)';

  // remove the detection element from the DOM.
  document.body.removeChild(detectionDiv);

  // Set the marker class on the body if in Auto Dark Theme.
  if (isAutoDark) {
    document.body.classList.add('auto-dark-theme');
  }
}
document.addEventListener("DOMContentLoaded", setAutoDarkClass);

Kemudian, gunakan CSS untuk menyesuaikan elemen sesuai kebutuhan:

.auto-dark-theme > #my-element {
  border-color: red;
}

API penyesuaian per elemen masih dalam tahap pengembangan awal. Kami bekerja sama dengan tim standar untuk memberi developer API yang lebih ekspresif untuk tidak menggunakan layanan ini. Anda dapat mengikuti percakapan tentang masalah GitHub ini.

Cara memilih untuk menonaktifkan Tema Gelap Otomatis

Selain menghormati pilihan pengguna di perangkat mereka, tema gelap memberikan manfaat bagi pengguna seperti peningkatan masa pakai baterai dan aksesibilitas. Daripada menonaktifkan Tema Gelap Otomatis, sebaiknya terapkan tema gelap pilihan Anda sendiri, untuk menghormati preferensi pengguna dan mempertahankan manfaat tersebut.

Namun, jika tidak memungkinkan untuk menerapkan tema gelap Anda sendiri, dan hasil yang dihasilkan oleh Tema Gelap Otomatis tidak memuaskan, Anda dapat memilih untuk tidak menggunakan fitur ini,

Menggunakan tag meta

Alternatif pertama untuk memilih tidak ikut Tema Gelap Otomatis adalah dengan menambahkan tag meta berikut ke header halaman Anda. Keuntungan menggunakan tag meta adalah mencegah Tema Gelap Otomatis diterapkan sama sekali, yang dapat menyebabkan "kilatan konten gelap".

<head>
  <meta name="color-scheme" content="only light">
  ...
</head>

Memilih tidak ikut per elemen

Alternatif kedua untuk memilih tidak ikut adalah menetapkan nilai properti CSS color-scheme ke only light. Meskipun pilihan tidak ikut per elemen dapat digunakan untuk memilih tidak ikut seluruh halaman dari Mode Gelap Otomatis, keuntungan dari pendekatan ini adalah hanya memungkinkan pilihan tidak ikut bagian tertentu dari halaman:

#my-element {
  color-scheme: only light;
}

Anda masih dapat menggunakan pendekatan ini untuk memilih tidak ikut seluruh halaman dari Tema Gelap Otomatis dengan menetapkan skema warna pada elemen :root:

:root {
  color-scheme: only light;
}

Kirimi kami masukan!

Tema Gelap Otomatis masih ditentukan, dan kami mencari masukan di semua area penerapan: dari hasil algoritma penggelapan hingga API developer untuk penyesuaian elemen dan pilihan tidak ikut.

Ada banyak saluran yang dapat Anda gunakan untuk mengirimkan masukan kepada kami:

Foto oleh Félix Besombes.