Perilaku menjengkelkan peningkatan gambar pada layar HiDPI, yang mengarah pada foto buram (alias mimpi buruk fotografer), juga telah mengganggu saya selama beberapa waktu. Saya juga bertanya-tanya bahwa tidak ada atribut CSS sederhana untuk menonaktifkannya untuk gambar.
Solusi saya saat ini dengan CSS terlihat seperti ini:
@media only screen and (min--moz-device-pixel-ratio: 1.25),
(-o-min-device-pixel-ratio: 5/4),
(-webkit-min-device-pixel-ratio: 1.25),
(min-device-pixel-ratio: 1.25) {
img {
--pic-width: 460px;
width: calc(var(--pic-width) / 1.25 - var(--pic-width) + var(--pic-width));
}
}
@media only screen and (min--moz-device-pixel-ratio: 1.5),
(-o-min-device-pixel-ratio: 3/2),
(-webkit-min-device-pixel-ratio: 1.5),
(min-device-pixel-ratio: 1.5) {
img {
--pic-width: 460px;
width: calc(var(--pic-width) / 1.5 - var(--pic-width) + var(--pic-width));
}
}
@media only screen and (min--moz-device-pixel-ratio: 1.75),
(-o-min-device-pixel-ratio: 7/4),
(-webkit-min-device-pixel-ratio: 1.75),
(min-device-pixel-ratio: 1.75) {
img {
--pic-width: 460px;
width: calc(var(--pic-width) / 1.75 - var(--pic-width) + var(--pic-width));
}
}
@media only screen and (min--moz-device-pixel-ratio: 2.00),
(-o-min-device-pixel-ratio: 2),
(-webkit-min-device-pixel-ratio: 2.00),
(min-device-pixel-ratio: 2.00) {
img {
--pic-width: 460px;
width: calc(var(--pic-width) / 2.00 - var(--pic-width) + var(--pic-width));
}
}
Langkah selanjutnya adalah menggunakan kelas untuk menentukan dan mengatur ukuran gambar yang berbeda jika diperlukan. Saya tidak tahu cara untuk mendapatkan ukuran gambar secara dinamis. Fungsi CSS attr () tampaknya tidak berfungsi untuk ini.