Retina Monitor’s Web Image Solution

什麼是Retina螢幕


今天來談談網頁圖片在視網膜(Retina)螢幕的顯示議題,首先必須來談談什麼是視網膜螢幕,其實他就是一種能在單位尺寸內顯示更多像素點的螢幕,且已經達到視網膜能辨識的極限,視網膜螢幕是由蘋果公司提出,賈伯斯在2010年iPhone 4的發表會中提到:「當你所拿的東西距離你10-12英寸(約25-30厘米)時,它的解析度只要達到300ppi這個『神奇數字』(每英寸300個像素點)以上,你的視網膜就無法分辨出像素點了。」

所以簡言之,視網膜螢幕比較一般非視網膜螢幕的不同處在於,能在同樣的範圍顯示更多的像素點,也就是PPI(Pixels Per Inch)比較高的螢幕,可參考下圖所示:

可以看到圖左在單位尺寸內顯示的像素點較少,圖右則能以更多的像素去呈現,在肉眼上就會覺得圖右會比較細緻。

接下來談談網頁圖片與視網膜螢幕之間的關係,先來看看同樣一張圖片在不同螢幕上顯示的效果。

非Retina顯示

Retina顯示

當然在美觀的立場下,我們不會希望發生這樣的視覺差異,那網頁上要如何設置才可以做到讓圖形在視網膜螢幕下也能正常的顯示呢?以下提出一些解決方案:

方案1. 透過CSS針對不同的DPR (Device Pixel Ratio)設計顯示圖片


大家如果想知道自己螢幕的DPR,可以在Chrome的主控台輸入“window.devicePixelRatio”,就可以得知目前Chrome所在螢幕的DPR值。

非Retina螢幕
Retina螢幕

可以觀察出來在兩個螢幕的DRP值是不同的,而透過CSS的樣式,可以針對這兩個不同的DPR設定顯示方式,可以參考下面的做法:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        .logo{
            width: 190px;
            height: 190px;
            background-image: url("atd-icon.jpg");
            background-size: contain;
        }
        @media (-webkit-min-device-pixel-ratio: 2){
            .logo{
                background-image: url("atd-icon@2x.jpg");
            }
        }
    </style>
</head>
<body>
    <div class="logo"></div>
</body>
</html>
<script>
</script>

這邊必須針對圖檔尺寸做個說明,其中atd-icon.jpg為190 x 190,而atd-icon@2x.jpg為380 x 380。

@media (-webkit-min-device-pixel-ratio: 2)的部分是在DPR兩倍下的Media Query。

透過這樣的方式去設定,當DPR為2的時候,螢幕上的圖片改變為atd-icon_2.jpg,剛好能夠滿足在兩倍像素狀況下的顯示需求,當然以此類推,也能去設定三倍或更高倍數下的顯示圖片。

方案二. 透過img標籤的srcset屬性


<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <img src="atdIcon.jpg" srcset="atd-icon@2x.jpg x2">
</body>
</html>
<script>
</script>

其中srcset=”atd-icon@2x.jpg 2x”表示在DPR等於2的時候要去呈現的圖片。

非Retina螢幕
Retina螢幕

以上兩個方法都可以解決圖片在Retina螢幕上面顯示的問題,但也要稍微注意一下支援程度:

CSS -webkit-min-device-pixel-ratio 支援列表
HTML srcset 支援列表

可以看到在IE都是無法支援的狀態,但從Edge後就開始支援,當然也可以想想目前擁有Retina螢幕的使用者,用的瀏覽器都會是哪些?說不定你不會太在乎上面那兩張圖紅色的部分。

但若是一定要有IE瀏覽器的支援,大家應該也能從上述的文章了解,我們可以透過window.devicePixelRatio的數值自行寫script進行判斷,然後再給出適合DPR的圖片,不過這邊另外推薦一個JS Library可以協助你進行這方面的判斷。

方案三. 透過Retina.js輔助進行判斷


首先到Retina.js的網站下載他們所提供的js檔,接下來至網頁引入該JS,其實網站上也有詳細的使用方法,另外檔案大小僅有約4KB並不算很大,可以參考下面的Sample Code。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="retina.min.js"></script>
</head>
<body>
    <img src="atd-icon.jpg" />
</body>
</html>

可以看到在img標籤中僅使用了原始大小的atd-icon.jpg,但因為有引入retina.min.js,他會在螢幕DPR兩倍時,自動去搜尋符合倍率下的圖片,但要記得如果不加其他屬性去設定兩倍圖片的檔名,檔名就必須按照內建的規則,也就是atd-icon@2x.jpg,當然3x也依然支援,可以到官網看一下他的使用方式,但若是使用CSS設定的背景,依然沒辦法透過retina.js達到支援IE的效果。

以上三個方法提供目前在設計網頁時,對於Retina螢幕支援的做法,若在不考慮IE瀏覽器的情況下,其實方法1+方法2就已經可以解決所有情況,但若要支援IE則可以參考方法三的做法,也歡迎大家有問題可以留言進行討論。

方案四. 使用SVG圖檔


過往我們在網頁中使用的圖片僅有GIF、PNG、JPG這三種點陣圖格式,所以在高解析度(Retina)的螢幕中,我們需要輸入不同Size的圖片,來補足像素點不足的問題,現在有了另外一種解法“SVG”圖檔。

大家可以把SVG視為一種可以放在網頁上的向量圖檔,也就是說我們以前透過Illustrator或其他向量繪圖軟體(也包含Photoshop中向量工具)繪製出來的向量圖,本身放大就不會失真,但因為要放在網頁上,我們把它轉換成了前述的三種點陣格式,才導致圖檔放大後的失真,而SVG就是保留圖片原來的向量屬性,簡言之,就是把向量圖檔放在網頁上的意思。

非Retina螢幕
Retina螢幕

感覺這個解決方案應該會比前幾項方便,但也有他必須要注意的地方:

  1. 在SVG檔案中匯入的點陣圖,在儲存成SVG時並不會被向量化,例如上圖中間的ASUS Design Logo就是匯入的點陣圖(放大後還是會模糊)。
  2. SVG字型可能會遺失,所以需要使用網路字型或是將文字轉成外框或形狀之後再轉存成SVG。
字型遺失
轉換成外框或形狀

You may also like...

15,332 Responses

  1. OscarGed表示:

    Le https://infinisafe.de/pag/osobennosti_poslerodovogo_vosstanovleniya.html 2024 pour beneficier d’une offre VIP de 100% jusqu’a 130€ sur les paris sportifs ou de 1950€ + 150 tours. Tous les nouveaux joueurs ayant utilise le code lors de leur inscription recoivent un bonus de bienvenue. Ce code bonus special vous permettra de recevoir un bonus augmente lors de votre inscription sur le site du bookmaker 1xBet.com ! Ne manquez pas cette occasion et inscrivez-vous des maintenant avec le code promo 1xbet pour obtenir un bonus allant jusqu’a 130 €/$.

  2. HarryGed表示:

    https://infinisafe.de/pag/osobennosti_poslerodovogo_vosstanovleniya.htmlt utilisez le code bonus pour obtenir un bonus VIP de 100% jusqu’a 130€ pour les Paris sportifs, ainsi qu’un bonus de casino de 1950 € + 150 tours de machines a sous. En utilisant le code promotionnel, vous pouvez vous attendre a ce que vos gains soient aussi eleves que dans le cas du plus grand bookmaker 1xbet. Tous les joueurs des pays suivants peuvent utiliser le code lors de l’inscription et recevoir un bonus de bienvenue:

  3. Uazrahg表示:

    Добрый день!
    Где купить диплом специалиста?
    travelwithme.social/read-blog/45682

  4. Uazrxuj表示:

    Привет!
    Где приобрести диплом специалиста?
    enkling.com/read-blog/46090

  5. RichardWrifs表示:

    https://mexicandeliverypharma.com/# purple pharmacy mexico price list

  6. Hello! This is my 1st comment here so I just wanted to give a quick shout out and say I truly enjoy reading through your posts. Can you suggest any other blogs/websites/forums that deal with the same topics? Thanks!

  7. Dnrtfvi表示:

    Привет, друзья!
    Заказать документ о получении высшего образования вы сможете в нашем сервисе.
    ast-diploms.com/kupit-diplom-ekaterinbur
    Успехов в учебе!

  8. Dnrtjra表示:

    Добрый день!
    Заказать документ университета можно в нашей компании в Москве.
    diplomasx24.ru/kupit-diplom-rostov-na-donu
    Удачи!

  9. WayneCoirl表示:

    buying prescription drugs in mexico: purple pharmacy mexico price list – best online pharmacies in mexico

  10. DominicJaw表示:

    mexican border pharmacies shipping to usa: buying from online mexican pharmacy – buying from online mexican pharmacy

  11. Thanks for the marvelous posting! I truly enjoyed reading it, you’re a great author.

    I will always bookmark your blog and will often come back down the
    road. I want to encourage you to definitely continue your great work, have a nice afternoon!

  12. I am in fact pleased to glance at this weblog posts which consists of plenty of
    helpful data, thanks for providing these kinds of data.

  13. Treftbe表示:

    Привет!
    Быстрая схема покупки диплома старого образца: что важно знать?
    property25.org/где-купить-диплом-о-высшем-образовани
    Рады оказать помощь!.

  14. Trefvgm表示:

    Добрый день!
    Как избежать рисков при покупке диплома колледжа или ПТУ в России
    sex8.zone/home.php?mod=space&uid=9145316&do=profile
    Поможем вам всегда!.

  15. other表示:

    Hello there! I know this is kind of off topic but I was wondering which blog platform are you
    using for this site? I’m getting fed up of WordPress because I’ve had
    issues with hackers and I’m looking at alternatives for another platform.

    I would be awesome if you could point me in the direction of a good platform.

    Feel free to visit my web site … other

  16. Diplomi_szEa表示:

    Добрый день!
    Заказать документ ВУЗа вы сможете в нашей компании в Москве.
    diplomasx.com/kupit-diplom-kazan

  17. Diplomi_foEa表示:

    Здравствуйте!
    Заказать документ о получении высшего образования можно в нашей компании.
    ast-diplomy.com/kupit-diplom-chelyabinsk

  18. KevinInove表示:

    Mavericks rising superstar Luka Doncic https://mavericks-de-dallas.lukadoncic-fr.com continues to amaze the basketball world with his game.

  19. Arnoldten表示:

    mexico drug stores pharmacies mexico pharmacies prescription drugs mexico pharmacies prescription drugs

  20. Mazracd表示:

    Привет, друзья!
    Диплом пту купить официально с упрощенным обучением в Москве
    mans-diplomas.ru

  21. Thomasnag表示:

    The story of Michael Phelps https://amerique.michael-phelps.com how he became the greatest swimmer of all time, overcoming adversity, setting records and inspiring the world.

  22. CharlesCoall表示:

    The Boston Celtics https://celtics-de-boston.bill-russel.com are one of the most successful teams in the history of the National Basketball Association (NBA).

  23. Mazrftu表示:

    Добрый день!
    Официальная покупка диплома вуза с сокращенной программой обучения в Москве
    mans-diploms.ru

  24. Trefkzg表示:

    Добрый день!
    Покупка диплома о среднем полном образовании: как избежать мошенничества?
    matthiasjakobbecker.com/купить-диплом-проверенные-способы/
    Будем рады вам помочь!.

  25. Trefvoo表示:

    Здравствуйте!
    Официальная покупка диплома вуза с сокращенной программой обучения в Москве
    skillsofblocks.com/купить-диплом-о-высшем-образовании-ре/
    Окажем помощь!.

  26. Lazrude表示:

    Привет!
    Мы предлагаем дипломы любой профессии по разумным ценам.
    openmotonews.ru/vash-diplom-byistro-i-nadezhno

  27. Lazryln表示:

    Привет!
    Мы изготавливаем дипломы любой профессии по разумным ценам.
    pluto.media/купить-диплом-в-артеме

  28. RichardWrifs表示:

    https://mexicandeliverypharma.com/# mexican online pharmacies prescription drugs

發佈留言

發佈留言必須填寫的電子郵件地址不會公開。