इस डेमो को एक्सप्लोर करें
- साइट की झलक देखने के लिए, ऐप्लिकेशन देखें दबाएं. इसके बाद, फ़ुलस्क्रीन .
- ब्राउज़र के लोड होने की स्थिति देखने के लिए, अलग-अलग डिवाइसों का इस्तेमाल करके पेज को फिर से लोड करें इमेज.
इसके लिए, डिवाइस एम्युलेटर का इस्तेमाल किया जा सकता है. अगर आपको किसी खास डिसप्ले की तलाश है घनत्व, तो इन्हें आज़माएँ. इसके लिए यहाँ कुछ डिवाइस दिए गए हैं:
1x डेंसिटी | BlackBerry प्लेबुक, कई बाहरी मॉनिटर |
2x डेंसिटी | iPad या iPhone 5/6 |
3x डेंसिटी | Galaxy S5 या iPhone X |
- यह कोड काम करने वाले कोड के लिए,
index.html
को चेकआउट करें.
यह कैसे काम करता है?
सघनता डिस्क्रिप्टर का सिद्धांत शायद ज़्यादातर लोगों को न पता हो. बेहतर करने के लिए इन कामों को करने से, ब्राउज़र के काम करने के तरीके के बारे में थोड़ी-बहुत जानकारी मिलती है पिक्सल के साथ.
पिक्सल क्या होते हैं
चलिए, पिक्सल तय करके शुरुआत करते हैं. यह आवाज़ सुनाई देगी आसान, लेकिन "पिक्सल" असल में, इसके कई मतलब हो सकते हैं:
- डिवाइस पिक्सल (यानी "फ़िज़िकल पिक्सल")
- अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है किसी डिवाइस पर दिखाया जा सकने वाला सबसे छोटा रंग का बिंदु.
- लॉजिकल पिक्सल
- अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है वह जानकारी जो ग्रिड पर किसी खास जगह का रंग बताती है. इस तरह के पिक्सल का साइज़ पहले से तय नहीं होता.
- सीएसएस पिक्सल
- अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है सीएसएस की खास जानकारी में, पिक्सल को फ़िज़िकल मेज़रमेंट की इकाई के तौर पर बताया गया है. 1 पिक्सल = इंच का 1/96वां हिस्सा.
पिक्सल की डेंसिटी
पिक्सल डेंसिटी (इसे "स्क्रीन डेंसिटी" या "डिसप्ले डेंसिटी" भी कहा जाता है) किसी दिए गए फ़िज़िकल एरिया में डिवाइस के पिक्सल का घनत्व मापता है. यह है इसे आम तौर पर पिक्सल प्रति इंच (पीपीआई) का इस्तेमाल करके मापा जाता है.
कई सालों तक, 96 ppi एक आम डिसप्ले सघनता थी (इसलिए, CSS (इंच का 1/96वां हिस्सा). 1980 के दशक की शुरुआत से यह डिफ़ॉल्ट रिज़ॉल्यूशन था Windows के लिए. इसके अलावा, यह CRT का रिज़ॉल्यूशन था मॉनिटर करते हैं.
इसमें बदलाव होने लगा, क्योंकि 2000 के दशक में एलईडी मॉनिटर का इस्तेमाल आम हो गया. खास तौर पर, साल 2010 में, जब Apple ने रेटिना डिसप्ले की सुविधा लॉन्च की, तो इसने काफ़ी कमाल कर दिया. ये डिसप्ले का कम से कम रिज़ॉल्यूशन 192 पीपीआई था, जो कि रिज़ॉल्यूशन के दोगुना था "सामान्य" डिस्प्ले (192 ppi/96 ppi = 2).
window.devicePixelRatio
नई डिसप्ले टेक्नोलॉजी, "डिवाइस पिक्सल" के आने से इसमें बदलाव आने लगे
भौतिक आकार और आकार में
और अब इसका साइज़ "CSS पिक्सल" के बराबर नहीं था. यह तय करने की ज़रूरत है कि
"डिवाइस पिक्सल" के साइज़ के बीच संबंध और "सीएसएस पिक्सल" की वजह से
devicePixelRatio
(इसे कभी-कभी "CSS Pixel" भी कहा जाता है) का परिचय
अनुपात").
devicePixelRatio
से डिवाइस के पिक्सल और सीएसएस पिक्सल के बीच संबंध के बारे में पता चलता है
एक खास डिवाइस के लिए. 192 पीपीआई वाले डिवाइस में, 2 में से devicePixelRatio
(192) है
ppi/96 ppi = 2) के लिए उपलब्ध है, क्योंकि "इसके दो डिसप्ले पिक्सल एक सीएसएस पिक्सल के साइज़ के हैं".
आज-कल ज़्यादातर डिवाइसों में, डिवाइस पिक्सल का अनुपात 1.0 से 4.0 के बीच होता है.
window.devicePixelRatio
टाइप करके, किसी डिवाइस की पिक्सल डेंसिटी पता करें पर क्लिक करें.इसके पिक्सल रेशियो देखने के लिए, यह टेबल देखें सामान्य डिवाइस. अधिकांश 1.0 और 4.0 के बीच होते हैं.
असल में, इस जानकारी को कैसे लागू किया जा सकता है?
डिवाइस-पिक्सल-अनुपात के आधार पर इमेज का साइज़ तय करें
उच्च रिज़ॉल्यूशन वाली स्क्रीन पर छवियों को बहुत अच्छे से दिखाने के लिए,
अलग-अलग devicePixelRatios
के लिए अलग-अलग इमेज के वर्शन देना ज़रूरी है.
डिवाइस का पिक्सल अनुपात | इससे पता चलता है कि: | इस डिवाइस पर, एक <img> 250 पिक्सेल की CSS चौड़ाई वाले टैग के लिए, सबसे अच्छा दिखता है, जब सोर्स इमेज यह होती है... |
---|---|---|
1 | एक डिवाइस पिक्सल = एक सीएसएस पिक्सल | 250 पिक्सल चौड़ा |
2 | दो डिवाइस पिक्सल = एक सीएसएस पिक्सल | 500 पिक्सल चौड़ा |
3 | तीन डिवाइस पिक्सल = एक सीएसएस पिक्सल | 750 पिक्सल चौड़ा |
इन बातों का ध्यान रखें:
- इमेज एडिटर, फ़ाइल डायरेक्ट्री, और अन्य स्थान लॉजिकल पिक्सल की माप होते हैं.
- ज़्यादा रिज़ॉल्यूशन वाली स्क्रीन और बड़े डिसप्ले के लिए, आपको ऐसी इमेज की ज़रूरत होगी जिनमें बड़े डाइमेंशन. छोटी-छोटी इमेज को सिर्फ़ बड़ा करके देखने का मकसद खत्म हो जाता है इमेज के कई वर्शन दिखाता है. ब्राउज़र ऐसा ही कर सकता, अगर हाई रिज़ॉल्यूशन वाली इमेज नहीं दी गई है.
एक से ज़्यादा
इमेज दिखाने के लिए, डेंसिटी डिस्क्रिप्टर का इस्तेमाल करें
"srcset " एट्रिब्यूट की वैल्यू है. इसका इस्तेमाल अलग-अलग डिवाइसPixelRatios पर अलग-अलग इमेज दिखाएं.
index.html
फ़ाइल पर एक नज़र डालें और<img>
एलिमेंट को नोट करें.
<img src="flower.jpg"
srcset="flower-1x.jpg 1x,
flower-2x.jpg 2x,
flower-3x.jpg 3x">
यह उदाहरण शब्दों में बताया गया है:
1x
,2x
, और3x
ये सभी सघनता डिस्क्रिप्टर हैं, जो ब्राउज़र को बताते हैं पिक्सल की डेंसिटी, जिसके लिए इमेज को तैयार किया गया है. इससे ब्राउज़र सेव हो जाएगा इस जानकारी को तय करने के लिए कोई इमेज डाउनलोड नहीं करनी पड़ती.- ब्राउज़र तीन इमेज में से चुन सकता है:
flower-1x.jpg
(उम्मीद के मुताबिक)1.0
पिक्सल की सघनता वाले ब्राउज़र के लिए,flower-2x.jpg
(इसके लिए बनाया गया है)2.0
पिक्सल डेंसिटी वाले ब्राउज़र औरflower-3x.jpg
(इसके लिए बनाया गया है)3.0
पिक्सल सघनता वाले ब्राउज़र). flower.jpg
उन ब्राउज़र के लिए फ़ॉलबैक इमेज है जोsrcset
.
इसका इस्तेमाल कैसे करें:
- सघनता वाले डिस्क्रिप्टर लिखने के लिए, devicePixelRatio और
x
यूनिट का इस्तेमाल करें. इसके लिए उदाहरण के लिए, कई रेटिना स्क्रीन के लिए डेंसिटी डिस्क्रिप्टर (window.devicePixelRatio = 2
) को2x
के रूप में लिखा जाएगा. - अगर सघनता डिस्क्रिप्टर नहीं दिया गया है, तो इसे
1x
माना जाता है. - फ़ाइल नामों में डेंसिटी डिस्क्रिप्टर को शामिल करना आम बात है (और यह से आपको फ़ाइलों का ट्रैक रखने में सहायता मिलती है) लेकिन यह ज़रूरी नहीं है. इमेज में कोई भी इमेज हो सकती है फ़ाइल नाम.
sizes
एट्रिब्यूट को शामिल करने की ज़रूरत नहीं है. सिर्फ़sizes
एट्रिब्यूट इसका इस्तेमाल चौड़ाई डिस्क्रिप्टर के साथ किया जाता है.