फ़ॉन्ट की नई खास जानकारी, जिससे फ़ॉन्ट फ़ाइल का साइज़ काफ़ी कम हो सकता है
इस लेख में, हम जानेंगे कि वैरिएबल फ़ॉन्ट क्या होते हैं, इनसे क्या फ़ायदे मिलते हैं, और इनका इस्तेमाल कैसे किया जा सकता है. सबसे पहले, यह जान लेते हैं कि वेब पर टाइपोग्राफ़ी कैसे काम करती है और वैरिएबल फ़ॉन्ट से क्या नए बदलाव आते हैं.
ब्राउज़र के साथ काम करना
मई 2020 से, ज़्यादातर ब्राउज़र में वैरिएबल फ़ॉन्ट काम करते हैं. क्या वैरिएबल फ़ॉन्ट का इस्तेमाल किया जा सकता है? और फ़ॉलबैक देखें.
परिचय
डेवलपर अक्सर फ़ॉन्ट और टाइपफ़ेस शब्दों का इस्तेमाल एक-दूसरे के लिए करते हैं. हालांकि, इन दोनों में अंतर है: टाइपफ़ेस, एक विज़ुअल डिज़ाइन है जो टेक्स्ट डालने की कई अलग-अलग टेक्नोलॉजी में मौजूद हो सकता है. फ़ॉन्ट, डिजिटल फ़ाइल फ़ॉर्मैट में इनमें से एक है. दूसरे शब्दों में, टाइपफ़ेस वह होता है जो आपको दिखता है और फ़ॉन्ट वह होता है जिसका इस्तेमाल किया जाता है.
एक और कॉन्सेप्ट जिसे अक्सर अनदेखा किया जाता है वह है स्टाइल और फ़ैमिली के बीच का अंतर. स्टाइल, एक खास टाइपफ़ेस होता है. जैसे, बोल्ड इटैलिक. फ़ैमिली, स्टाइल का पूरा सेट होता है.
वैरिएबल फ़ॉन्ट से पहले, हर स्टाइल को एक अलग फ़ॉन्ट फ़ाइल के तौर पर लागू किया जाता था. वैरिएबल फ़ॉन्ट की मदद से, सभी स्टाइल एक ही फ़ाइल में रखे जा सकते हैं.
डिज़ाइनर और डेवलपर के लिए चुनौतियां
जब कोई डिज़ाइनर प्रिंट प्रोजेक्ट बनाता है, तो उसे कुछ सीमाओं का सामना करना पड़ता है. जैसे, पेज लेआउट का साइज़, इस्तेमाल किए जा सकने वाले रंगों की संख्या (यह इस्तेमाल किए जाने वाले प्रिंटिंग प्रेस के हिसाब से तय होती है) वगैरह. हालांकि, वे अपनी पसंद के मुताबिक टाइपफ़ेस स्टाइल का इस्तेमाल कर सकते हैं. इसका मतलब है कि प्रिंट मीडिया का टाइपोग्राफ़ी अक्सर बेहतर और बेहतरीन होता है, ताकि पढ़ने का अनुभव सचमुच आनंददायक हो. याद करें कि पिछली बार आपको कौनसी बेहतरीन पत्रिका पढ़ने में मज़ा आया था.
वेब डिज़ाइनर और डेवलपर की समस्याएं, प्रिंट डिज़ाइनर से अलग होती हैं. इनमें से एक अहम समस्या, हमारे डिज़ाइन के लिए बैंडविड्थ की लागत है. बेहतर टाइपोग्राफ़ी के अनुभव के लिए, यह एक समस्या रही है, क्योंकि इसके लिए शुल्क देना पड़ता है. पारंपरिक वेब फ़ॉन्ट का इस्तेमाल करने पर, हमारे डिज़ाइन में इस्तेमाल किए गए हर स्टाइल के लिए, उपयोगकर्ताओं को एक अलग फ़ॉन्ट फ़ाइल डाउनलोड करनी पड़ती है. इससे, पेज लोड होने में लगने वाला समय और पेज को रेंडर होने में लगने वाला समय बढ़ जाता है. सिर्फ़ रेगुलर और बोल्ड स्टाइल के साथ-साथ उनके इटैलिक वर्शन को शामिल करने पर, फ़ॉन्ट डेटा का साइज़ 500 केबी या उससे ज़्यादा हो सकता है. यह समस्या तब भी आती है, जब हमने फ़ॉन्ट को रेंडर करने के तरीके, इस्तेमाल किए जाने वाले फ़ॉलबैक पैटर्न या FOIT और FOUT जैसे अनचाहे साइड इफ़ेक्ट के बारे में नहीं बताया हो.
कई फ़ॉन्ट फ़ैमिली में, स्टाइल की बहुत ज़्यादा रेंज उपलब्ध होती है. जैसे, थिन से लेकर ब्लैक वज़्ज़, नैरो और वाइड चौड़ाई, स्टाइल की कई तरह की जानकारी, और साइज़ के हिसाब से डिज़ाइन (बड़े या छोटे टेक्स्ट साइज़ के लिए ऑप्टिमाइज़ किए गए). हर स्टाइल (या स्टाइल के कॉम्बिनेशन) के लिए, आपको एक नई फ़ॉन्ट फ़ाइल लोड करनी होगी. इसलिए, कई वेब डेवलपर इन सुविधाओं का इस्तेमाल नहीं करते. इससे, उनके उपयोगकर्ताओं को पढ़ने का बेहतर अनुभव नहीं मिल पाता.
वैरिएबल फ़ॉन्ट की बनावट
वैरिएबल फ़ॉन्ट, स्टाइल को एक ही फ़ाइल में पैक करके इन समस्याओं को हल करते हैं.
यह सेंटर या 'डिफ़ॉल्ट' स्टाइल से शुरू होता है. आम तौर पर, यह 'रेगुलर' स्टाइल होता है. यह एक अपराइट रोमन डिज़ाइन होता है, जिसमें सबसे सामान्य वज़न और चौड़ाई होती है. यह प्लैन टेक्स्ट के लिए सबसे सही होता है. इसके बाद, इसे 'ऐक्सिस' नाम की एक लगातार रेंज में अन्य स्टाइल से कनेक्ट किया जाता है. सबसे सामान्य ऐक्सिस वेट है, जो डिफ़ॉल्ट स्टाइल को बोल्ड स्टाइल से कनेक्ट कर सकता है. किसी भी स्टाइल को अक्ष के साथ रखा जा सकता है. इसे वैरिएबल फ़ॉन्ट का 'इंस्टेंस' कहा जाता है. कुछ इंस्टेंस को फ़ॉन्ट डेवलपर ने नाम दिया है. उदाहरण के लिए, वेट ऐक्सिस के लेवल 600 को सेमीबोल्ड कहा जाता है.
वैरिएबल फ़ॉन्ट Roboto Flex के वज़न ऐक्सिस के लिए तीन स्टाइल हैं. रेगुलर स्टाइल बीच में होता है और अक्ष के दोनों सिरों पर दो स्टाइल होते हैं. एक हल्का और दूसरा ज़्यादा गहरा. इनमें से, 900 इंस्टेंस चुने जा सकते हैं:
फ़ॉन्ट डेवलपर, अलग-अलग ऐक्सिस का एक सेट ऑफ़र कर सकता है. इन्हें एक साथ इस्तेमाल किया जा सकता है, क्योंकि इन सभी में एक ही डिफ़ॉल्ट स्टाइल इस्तेमाल होती है. Roboto में चौड़ाई वाले अक्ष में तीन स्टाइल होते हैं: रेगुलर स्टाइल अक्ष के बीच में होता है और दो स्टाइल, एक छोटा और एक बड़ा, दोनों अक्ष के आखिर में होता है. ये रेगुलर स्टाइल की सभी चौड़ाइयां उपलब्ध कराते हैं. साथ ही, वेट ऐक्सिस के साथ मिलकर हर वेट के लिए सभी चौड़ाइयां उपलब्ध कराते हैं.
इसका मतलब है कि हज़ारों स्टाइल उपलब्ध हैं! ऐसा लग सकता है कि यह बहुत ज़्यादा है, लेकिन टाइप स्टाइल की इस विविधता से, पढ़ने के अनुभव की क्वालिटी को काफ़ी बेहतर बनाया जा सकता है. अगर परफ़ॉर्मेंस पर कोई असर नहीं पड़ता है, तो वेब डेवलपर अपनी ज़रूरत के हिसाब से कुछ या ज़्यादा स्टाइल का इस्तेमाल कर सकते हैं. यह उनके डिज़ाइन पर निर्भर करता है.
इटैलिक
वैरिएबल फ़ॉन्ट में इटैलिक को मैनेज करने का तरीका दिलचस्प है, क्योंकि इसके लिए दो अलग-अलग तरीके अपनाए जाते हैं. Helvetica या Roboto जैसे टाइपफ़ेस में इंटरपोलेशन के साथ काम करने वाले कॉन्टूर होते हैं. इसलिए, उनके रोमन और इटैलिक स्टाइल के बीच इंटरपोलेशन किया जा सकता है. साथ ही, रोमन से इटैलिक में बदलने के लिए, स्लैंट ऐक्सिस का इस्तेमाल किया जा सकता है.
Garamond, Baskerville या Bodoni जैसे अन्य टाइपफ़ेस में रोमन और इटैलिक ग्लिफ़ कॉन्टूर होते हैं, जो इंटरपोलेशन के साथ काम नहीं करते. उदाहरण के लिए, आम तौर पर रोमन भाषा के छोटे अक्षर "n" को दिखाने वाले कॉन्टूर, इटैलिक भाषा के छोटे अक्षर "n" को दिखाने वाले कॉन्टूर से मेल नहीं खाते. एक कॉन्टूर को दूसरे कॉन्टूर में बदलने के बजाय, इटैलिक ऐक्सिस, रोमन से इटैलिक कॉन्टूर पर टॉगल करता है.
इटैलिक में स्विच करने के बाद, उपयोगकर्ता के लिए उपलब्ध ऐक्सिस, रोमन के लिए उपलब्ध ऐक्सिस जैसे ही होने चाहिए. साथ ही, वर्ण सेट भी एक ही होना चाहिए.
अलग-अलग ग्लिफ़ के लिए भी ग्लिफ़ बदलने की सुविधा देखी जा सकती है. साथ ही, इसका इस्तेमाल वैरिएबल फ़ॉन्ट के डिज़ाइन स्पेस में कहीं भी किया जा सकता है. उदाहरण के लिए, दो वर्टिकल बार वाला डॉलर साइन डिज़ाइन, बड़े पॉइंट साइज़ पर सबसे अच्छा काम करता है. हालांकि, छोटे पॉइंट साइज़ पर सिर्फ़ एक बार वाला डिज़ाइन बेहतर होता है. जब हमारे पास ग्लिफ़ को रेंडर करने के लिए कम पिक्सल होते हैं, तो दो बार वाला डिज़ाइन पढ़ा नहीं जा सकता. इस समस्या को हल करने के लिए, इटैलिक ऐक्सिस की तरह ही, ऑप्टिकल साइज़ ऐक्सिस पर भी एक ग्लिफ़ को दूसरे से बदला जा सकता है. हालांकि, यह बदलाव टाइप डिज़ाइनर तय करता है.
खास तौर पर, टाइप डिज़ाइनर ऐसे फ़ॉन्ट बना सकते हैं जिनमें कई डाइमेंशन वाले डिज़ाइन स्पेस में, अलग-अलग स्टाइल के बीच इंटरपोलेशन किया जा सकता है. हालांकि, ऐसा सिर्फ़ तब किया जा सकता है, जब कॉन्टूर की अनुमति हो. इससे आपको टाइपोग्राफ़ी पर बेहतर कंट्रोल मिलता है.
ऐक्सिस की परिभाषाएं
पांच रजिस्टर किए गए ऐक्स होते हैं, जो फ़ॉन्ट की जानी-पहचानी और अनुमानित सुविधाओं को कंट्रोल करते हैं: वेट, चौड़ाई, ऑप्टिकल साइज़, स्लैंट, और इटैलिक. इसके अलावा, फ़ॉन्ट में कस्टम ऐक्सिस भी हो सकते हैं. इनसे, टाइप डिज़ाइनर के हिसाब से फ़ॉन्ट के डिज़ाइन के किसी भी हिस्से को कंट्रोल किया जा सकता है: जैसे, सिरफ़ का साइज़, स्वैश की लंबाई, ऐसेंडर की ऊंचाई या i पर मौजूद बिंदु का साइज़.
अक्ष एक ही सुविधा को कंट्रोल कर सकते हैं, लेकिन वे अलग-अलग वैल्यू का इस्तेमाल कर सकते हैं. उदाहरण के लिए, Oswald और Hepta Slab वैरिएबल फ़ॉन्ट में सिर्फ़ एक ऐक्सिस, वज़न उपलब्ध है. हालांकि, इनकी रेंज अलग-अलग है. Oswald की रेंज वैरिएबल फ़ॉन्ट में अपग्रेड होने से पहले की ही है, यानी 200 से 700. वहीं, Hepta Slab में 1 पर एक्स्ट्रीम हेयरलाइन वज़न है, जो 900 तक जाता है.
रजिस्टर किए गए पांच अक्षस, चार वर्णों के छोटे अक्षरों वाले टैग होते हैं. इनका इस्तेमाल, सीएसएस में उनकी वैल्यू सेट करने के लिए किया जाता है:
ऐक्सिस के नाम और सीएसएस वैल्यू | |
---|---|
वज़न |
wght
|
चौड़ाई |
wdth
|
स्लांट |
slnt
|
ऑप्टिकल साइज़ |
opsz
|
इटैलिक |
ital
|
फ़ॉन्ट डेवलपर यह तय करता है कि वैरिएबल फ़ॉन्ट में कौनसे ऐक्सिस उपलब्ध हैं और उनकी वैल्यू क्या हो सकती हैं. इसलिए, यह जानना ज़रूरी है कि हर फ़ॉन्ट क्या ऑफ़र करता है. फ़ॉन्ट के दस्तावेज़ में यह जानकारी मिलनी चाहिए. इसके अलावा, Wakamai Fondue जैसे टूल का इस्तेमाल करके भी फ़ॉन्ट की जांच की जा सकती है.
इस्तेमाल के उदाहरण और फ़ायदे
ऐक्सिस की वैल्यू सेट करने का तरीका, व्यक्ति की पसंद और टाइपोग्राफ़ी के सबसे सही तरीकों पर निर्भर करता है. किसी भी नई टेक्नोलॉजी का गलत इस्तेमाल किया जा सकता है. साथ ही, ज़्यादा कलात्मक या एक्सप्लोरेटिव सेटिंग की वजह से, असली टेक्स्ट को पढ़ने में भी मुश्किल हो सकती है. टाइटल के लिए, शानदार आर्टिस्टिक डिज़ाइन बनाने के लिए अलग-अलग ऐक्सिस को एक्सप्लोर करना दिलचस्प होता है. हालांकि, मुख्य कॉपी के लिए ऐसा करने पर, टेक्स्ट को पढ़ने में मुश्किल हो सकती है.
दिलचस्प एक्सप्रेशन
ऊपर एक कलाकृति का उदाहरण दिया गया है. इसमें मैंडी माइकल ने टाइपफ़ेस Decovar का इस्तेमाल किया है.
ऊपर दिए गए सैंपल के लिए, काम करने वाला उदाहरण और सोर्स कोड यहां देखा जा सकता है.
ऐनिमेशन
वैरिएबल फ़ॉन्ट की मदद से, ऐनिमेशन वाले वर्ण भी बनाए जा सकते हैं. ऊपर दिए गए उदाहरण में, टाइपफ़ेस Zycon के साथ अलग-अलग ऐक्सिस का इस्तेमाल किया गया है. Axis Praxis पर लाइव ऐनिमेशन का उदाहरण देखें.
Anicons, दुनिया का पहला ऐनिमेटेड और कलर आइकॉन फ़ॉन्ट है. यह Material Design आइकॉन पर आधारित है. ऐनआइकॉन एक एक्सपेरिमेंट है, जिसमें फ़ॉन्ट की दो नई टेक्नोलॉजी का इस्तेमाल किया गया है: वैरिएबल फ़ॉन्ट और कलर फ़ॉन्ट.
Finesse
Roboto Flex और Amstelvar में, "पैरामीटरिक ऐक्स" का एक सेट उपलब्ध है. इन ऐक्सिस में, अक्षरों को फ़ॉर्म के चार बुनियादी पहलुओं में बांटा गया है: काले या पॉज़िटिव शेप, सफ़ेद या नेगेटिव शेप, और x और y डाइमेंशन. जिस तरह प्राइमरी रंगों को अडजस्ट करने के लिए, किसी भी दूसरे रंग के साथ ब्लेंड किया जा सकता है उसी तरह इन चार पहलुओं का इस्तेमाल करके, किसी भी दूसरे ऐक्सिस को बेहतर बनाया जा सकता है.
Amstelvar में XTRA ऐक्सिस की मदद से, हर 1,000 में "सफ़ेद" वैल्यू में बदलाव किया जा सकता है, जैसा कि ऊपर दिखाया गया है. XTRA का इस्तेमाल करके, शब्दों की चौड़ाई को बराबर किया जा सकता है. इसके लिए, XTRA को अलग-अलग दिशाओं में इस्तेमाल करें.
सीएसएस में वैरिएबल फ़ॉन्ट
वैरिएबल फ़ॉन्ट फ़ाइलें लोड करना
वैरिएबल फ़ॉन्ट, स्टैटिक वेब फ़ॉन्ट की तरह ही @font-face
मकैनिज्म से लोड किए जाते हैं. हालांकि, इनमें दो नए बेहतर तरीके हैं:
@font-face {
font-family: 'Roboto Flex';
src: url('RobotoFlex-VF.woff2') format('woff2-variations');
src: url('RobotoFlex-VF.woff2') format('woff2') tech('variations');
font-weight: 100 1000;
font-stretch: 25% 151%;
}
1. सोर्स फ़ॉर्मैट: अगर ब्राउज़र वैरिएबल फ़ॉन्ट के साथ काम नहीं करता है, तो हम नहीं चाहते कि वह फ़ॉन्ट डाउनलोड करे. इसलिए, हम format
और tech
के ब्यौरे जोड़ते हैं: एक बार आने वाले समय के सिंटैक्स (format('woff2') tech('variations')
) में और एक बार, अब इस्तेमाल नहीं किए जाने वाले, लेकिन ब्राउज़र के बीच काम करने वाले सिंटैक्स (format('woff2-variations')
) में. अगर ब्राउज़र, वैरिएबल फ़ॉन्ट और आने वाले समय के सिंटैक्स के साथ काम करता है, तो वह पहले एलान का इस्तेमाल करेगा. अगर यह वैरिएबल फ़ॉन्ट और मौजूदा सिंटैक्स के साथ काम करता है, तो यह दूसरे एलान का इस्तेमाल करेगा. ये दोनों एक ही फ़ॉन्ट फ़ाइल पर ले जाते हैं.
2. स्टाइल रेंज: आपको पता चलेगा कि हम font-weight
और font-stretch
के लिए दो वैल्यू दे रहे हैं. ब्राउज़र को यह बताने के बजाय कि यह फ़ॉन्ट किस खास वेट (उदाहरण के लिए font-weight: 500;
) में उपलब्ध है, अब हम उसे फ़ॉन्ट के वेट की रेंज देते हैं. Roboto Flex के लिए, वज़न ऐक्सिस की रेंज 100 से 1,000 तक होती है. साथ ही, सीएसएस ऐक्सिस रेंज को सीधे font-weight
स्टाइल प्रॉपर्टी पर मैप करती है. @font-face
में रेंज तय करने पर, इस रेंज से बाहर की कोई भी वैल्यू, सबसे पास की मान्य वैल्यू पर "कैप" कर दी जाएगी. चौड़ाई के अक्ष की रेंज को font-stretch
प्रॉपर्टी के साथ उसी तरह से मैप किया जाता है.
अगर Google Fonts API का इस्तेमाल किया जा रहा है, तो इन सभी चीज़ों का ध्यान रखा जाएगा. सीएसएस में सही सोर्स फ़ॉर्मैट और रेंज के साथ-साथ, Google Fonts वैरिएबल फ़ॉन्ट के काम न करने पर स्टैटिक फ़ॉलबैक फ़ॉन्ट भी भेजेगा.
वेट और चौड़ाई का इस्तेमाल करना
फ़िलहाल, सीएसएस से wght
ऐक्सिस को font-weight
और wdth
ऐक्सिस को font-stretch
की मदद से सेट किया जा सकता है.
आम तौर पर, font-weight
को कीवर्ड (light
, bold
) के तौर पर सेट किया जाता है. इसके अलावा, इसे 100 से 900 के बीच की संख्या के तौर पर भी सेट किया जा सकता है. वैरिएबल फ़ॉन्ट की मदद से, फ़ॉन्ट की चौड़ाई की रेंज में कोई भी वैल्यू सेट की जा सकती है:
.kinda-light {
font-weight: 125;
}
.super-heavy {
font-weight: 1000;
}
इसी तरह, हम font-stretch
को कीवर्ड (condensed
,
ultra-expanded
) या प्रतिशत वैल्यू के साथ सेट कर सकते हैं:
.kinda-narrow {
font-stretch: 33.3%;
}
.super-wide {
font-stretch: 151%;
}
इटैलिक और ऑब्लिक का इस्तेमाल करना
ital
ऐक्सिस, उन फ़ॉन्ट के लिए है जिनमें रेगुलर स्टाइल और इटैलिक स्टाइल, दोनों होते हैं. ऐक्सिस को चालू/बंद करने वाला स्विच माना जाता है: वैल्यू 0
बंद है और यह सामान्य स्टाइल दिखाएगा, वैल्यू 1
इटैलिक दिखाएगा. अन्य ऐक्सिस के उलट, इसमें ट्रांज़िशन नहीं होता. 0.5
की वैल्यू से आपको "आधा इटैलिक" नहीं मिलेगा.
slnt
ऐक्सिस, इटैलिक से अलग होता है. यह कोई नया स्टाइल नहीं है, बल्कि सामान्य स्टाइल को तिरछा कर देता है. डिफ़ॉल्ट रूप से, इसकी वैल्यू 0
होती है. इसका मतलब है कि डिफ़ॉल्ट रूप से, अक्षरों के ऊपर की ओर वाले हिस्से का आकार. Roboto Flex में ज़्यादा से ज़्यादा -10 डिग्री का स्लैंट होता है. इसका मतलब है कि 0 से -10 तक के स्लैंट में अक्षर दाईं ओर झुकेंगे.
font-style
प्रॉपर्टी की मदद से, ये ऐक्सिस आसानी से सेट किए जा सकते हैं. हालांकि, अप्रैल 2020 तक, इस पर काम किया जा रहा है. इसलिए, फ़िलहाल इन्हें कस्टम ऐक्सिस के तौर पर इस्तेमाल करें और इन्हें font-variation-settings
के ज़रिए सेट करें:
i, em, .italic {
/* Should be font-style: italic; */
font-variation-settings: 'ital' 1;
}
.slanted {
/* Should be font-style: oblique 10deg; */
font-variation-settings: 'slnt' 10;
}
ऑप्टिकल साइज़ का इस्तेमाल करना
टाइपफ़ेस को बहुत छोटा (12 पिक्सल फ़ुटनोट) या बहुत बड़ा (80 पिक्सल वाली हेडलाइन) रेंडर किया जा सकता है. फ़ॉन्ट, साइज़ में हुए इन बदलावों के हिसाब से अक्षरों के आकार में बदलाव करके, अपने साइज़ को बेहतर बना सकते हैं. छोटे साइज़ में, ज़्यादा जानकारी के बिना बेहतर इमेज बनाई जा सकती है. वहीं, बड़े साइज़ में ज़्यादा जानकारी और पतले स्ट्रोक का इस्तेमाल किया जा सकता है.
इस ऐक्सिस के लिए, एक नई सीएसएस प्रॉपर्टी जोड़ी गई है: font-optical-sizing
. डिफ़ॉल्ट रूप से, यह auto
पर सेट होता है. इससे ब्राउज़र, font-size
के आधार पर ऐक्सिस की वैल्यू सेट करता है. इसका मतलब है कि ब्राउज़र अपने-आप सबसे अच्छा ऑप्टिकल साइज़ चुन लेगा. हालांकि, अगर आपको इसे बंद करना है, तो font-optical-sizing
को none
पर सेट करें.
अगर आपको जान-बूझकर ऐसा ऑप्टिकल साइज़ चाहिए जो फ़ॉन्ट साइज़ से मेल न खाता हो, तो opsz
ऐक्सिस के लिए कस्टम वैल्यू भी सेट की जा सकती है. इस सीएसएस की वजह से, टेक्स्ट बड़े साइज़ में दिखेगा. हालांकि, यह ऑप्टिकल साइज़ में दिखेगा, जैसे कि इसे 8pt
में प्रिंट किया गया हो:
.small-yet-large {
font-size: 100px;
font-variation-settings: 'opsz' 8;
}
कस्टम ऐक्सिस का इस्तेमाल करना
रजिस्टर किए गए ऐक्सिस के उलट, कस्टम ऐक्सिस किसी मौजूदा सीएसएस प्रॉपर्टी से मैप नहीं किए जाएंगे. इसलिए, आपको उन्हें हमेशा font-variation-settings
के ज़रिए सेट करना होगा.
रजिस्टर किए गए ऐक्सिस से अलग करने के लिए, कस्टम ऐक्सिस के टैग हमेशा बड़े अक्षरों में होते हैं.
Roboto Flex में कुछ कस्टम ऐक्सिस उपलब्ध हैं. इनमें सबसे अहम ग्रेड (GRAD
) है. ग्रेड ऐक्सिस दिलचस्प है, क्योंकि यह चौड़ाई में बदलाव किए बिना फ़ॉन्ट के वेट में बदलाव करता है. इसलिए, लाइन ब्रेक में बदलाव नहीं होता. ग्रेड ऐक्सिस में बदलाव करके, आपको वज़न ऐक्सिस में बदलाव करने की ज़रूरत नहीं पड़ती. इससे, पूरी चौड़ाई पर असर पड़ता है. इसके बाद, चौड़ाई ऐक्सिस में बदलाव करने से, पूरे वज़न पर असर पड़ता है.
GRAD
एक कस्टम ऐक्सिस है, जिसकी रेंज Roboto Flex में -200 से 150 के बीच है.
हमें font-variation-settings
के साथ इस समस्या को ठीक करना होगा:
.grade-light {
font-variation-settings: `GRAD` -200;
}
.grade-normal {
font-variation-settings: `GRAD` 0;
}
.grade-heavy {
font-variation-settings: `GRAD` 150;
}
Google Fonts पर वैरिएबल फ़ॉन्ट
Google Fonts ने वैरिएबल फ़ॉन्ट के साथ अपने कैटलॉग को बड़ा किया है. साथ ही, इसमें नियमित तौर पर नए फ़ॉन्ट जोड़े जा रहे हैं.
फ़िलहाल, इंटरफ़ेस का मकसद फ़ॉन्ट से एक इंस्टेंस चुनना है: अपनी पसंद का वैरिएशन चुनें और "यह स्टाइल चुनें" पर क्लिक करें. इसके बाद, यह <link>
एलिमेंट में जुड़ जाएगा, जो Google Fonts से सीएसएस और फ़ॉन्ट फ़ेच करता है.
सभी उपलब्ध ऐक्सिस या वैल्यू की रेंज का इस्तेमाल करने के लिए, आपको Google Fonts API के यूआरएल को मैन्युअल रूप से लिखना होगा. वैरिएबल फ़ॉन्ट की खास जानकारी में सभी ऐक्सिस और वैल्यू की सूची होती है.
Google वैरिएबल फ़ॉन्ट के लिंक टूल से, आपको वैरिएबल फ़ॉन्ट के सभी वर्शन के लिए नए यूआरएल भी मिल सकते हैं.
Font-variation-settings इनहेरिटेंस
रजिस्टर किए गए सभी ऐक्सिस, जल्द ही मौजूदा सीएसएस प्रॉपर्टी के ज़रिए काम करेंगे. हालांकि, फ़िलहाल आपको फ़ॉलबैक के तौर पर font-variation-settings
पर भरोसा करना पड़ सकता है. अगर आपके फ़ॉन्ट में कस्टम ऐक्सिस हैं, तो आपको font-variation-settings
की भी ज़रूरत होगी.
हालांकि, font-variation-settings
के साथ एक समस्या है. जिन प्रॉपर्टी को साफ़ तौर पर सेट नहीं किया जाता वे अपने-आप डिफ़ॉल्ट पर रीसेट हो जाएंगी.
पहले से सेट की गई वैल्यू इनहेरिट नहीं होती हैं! इसका मतलब है कि ये सुविधाएं उम्मीद के मुताबिक काम नहीं करेंगी:
<span class="slanted grade-light">
I should be slanted and have a light grade
</span>
सबसे पहले, ब्राउज़र .slanted
क्लास से font-variation-settings: 'slnt' 10
लागू करेगा. इसके बाद, यह .grade-light
क्लास से font-variation-settings: 'GRAD' -200
लागू करेगा. हालांकि, इससे slnt
को फिर से डिफ़ॉल्ट वैल्यू 0 पर रीसेट कर दिया जाएगा! नतीजा, हल्के ग्रेड में टेक्स्ट के तौर पर दिखेगा, लेकिन टेक्स्ट तिरछा नहीं होगा.
हालांकि, सीएसएस वैरिएबल का इस्तेमाल करके, इस समस्या को हल किया जा सकता है:
/* Set the default values */
:root {
--slnt: 0;
--GRAD: 0;
}
/* Change value for these elements and their children */
.slanted {
--slnt: 10;
}
.grade-light {
--grad: -200;
}
.grade-normal {
--grad: 0;
}
.grade-heavy {
--grad: 150;
}
/* Apply whatever value is kept in the CSS variables */
.slanted,
.grade-light,
.grade-normal,
.grade-heavy {
font-variation-settings: 'slnt' var(--slnt), 'GRAD' var(--GRAD);
}
सीएसएस वैरिएबल कैस्केड करेंगे. इसलिए, अगर किसी एलिमेंट (या उसके किसी पैरंट) ने slnt
को 10
पर सेट किया है, तो वह वैल्यू बरकरार रहेगी. भले ही, आपने GRAD
को किसी और पर सेट किया हो. इस तकनीक के बारे में ज़्यादा जानने के लिए, वैरिएबल फ़ॉन्ट इनहेरिटेंस ठीक करना लेख पढ़ें.
ध्यान दें कि सीएसएस वैरिएबल को ऐनिमेट नहीं किया जा सकता. इसलिए, ऐसा कुछ करने पर यह काम नहीं करता:
@keyframes width-animation {
from { --wdth: 25; }
to { --wdth: 151; }
}
ये ऐनिमेशन सीधे font-variation-settings
पर होने चाहिए.
परफ़ॉर्मेंस में बढ़ोतरी
OpenType वैरिएबल फ़ॉन्ट की मदद से, एक टाइप फ़ैमिली के कई वैरिएशन को एक फ़ॉन्ट फ़ाइल में सेव किया जा सकता है. Monotype ने 12 इनपुट फ़ॉन्ट को मिलाकर एक एक्सपेरिमेंट किया. इससे, इटैलिक और रोमन, दोनों स्टाइल में तीन चौड़ाई और आठ वेट जनरेट किए गए. एक वैरिएबल फ़ॉन्ट फ़ाइल में 48 अलग-अलग फ़ॉन्ट सेव करने का मतलब है कि फ़ाइल के साइज़ में 88% की कमी आई.
हालांकि, अगर Roboto Regular जैसे किसी एक फ़ॉन्ट का इस्तेमाल किया जा रहा है और किसी और फ़ॉन्ट का इस्तेमाल नहीं किया जा रहा है, तो हो सकता है कि कई ऐक्सिस वाले वैरिएबल फ़ॉन्ट पर स्विच करने पर, आपको फ़ॉन्ट साइज़ में कोई खास फ़ायदा न दिखे. हमेशा की तरह, यह इस बात पर निर्भर करता है कि आपको किस तरह का डेटा चाहिए.
दूसरी ओर, सेटिंग के बीच फ़ॉन्ट को ऐनिमेट करने से परफ़ॉर्मेंस से जुड़ी समस्याएं हो सकती हैं. हालांकि, ब्राउज़र में वैरिएबल फ़ॉन्ट की सुविधा बेहतर होने के बाद, यह समस्या कम हो जाएगी. फ़िलहाल, स्क्रीन पर मौजूद फ़ॉन्ट को ऐनिमेट करके भी इस समस्या को कम किया जा सकता है. Dinamo का यह स्निपेट, स्क्रीन पर न होने पर, क्लास vf-animation
वाले एलिमेंट में ऐनिमेशन को रोक देता है:
var observer = new IntersectionObserver(function(entries, observer) {
entries.forEach(function(entry) {
// Pause/Play the animation
if (entry.isIntersecting) entry.target.style.animationPlayState = "running"
else entry.target.style.animationPlayState = "paused"
});
});
var variableTexts = document.querySelectorAll(".vf-animation");
variableTexts.forEach(function(el) { observer.observe(el); });
अगर आपका फ़ॉन्ट, उपयोगकर्ता के इंटरैक्शन के हिसाब से काम करता है, तो इनपुट इवेंट को थ्रॉटल या डिबउन्स करना अच्छा रहेगा. इससे ब्राउज़र, वैरिएबल फ़ॉन्ट के ऐसे इंस्टेंस को रेंडर नहीं कर पाएगा जो पिछले इंस्टेंस से इतना कम बदला है कि मानवीय आंखों को फ़र्क़ नहीं दिखेगा.
अगर Google Fonts का इस्तेमाल किया जा रहा है, तो https://fonts.gstatic.com
से पहले से कनेक्ट करना एक अच्छा विचार है. https://fonts.gstatic.com
वह डोमेन है जहां Google के फ़ॉन्ट होस्ट किए जाते हैं. इससे यह पक्का होगा कि जब ब्राउज़र को सीएसएस में फ़ॉन्ट मिलेंगे, तो उसे पहले से पता होगा कि उन्हें कहां से डाउनलोड करना है:
<link rel="preconnect" href="https://fonts.gstatic.com" />
यह सलाह, दूसरे सीडीएन के लिए भी काम करती है: ब्राउज़र को नेटवर्क कनेक्शन सेट अप करने की अनुमति देने पर, वह आपके फ़ॉन्ट ज़्यादा तेज़ी से डाउनलोड कर सकता है.
Google Fonts को तेज़ी से लोड करने के बारे में ज़्यादा सलाह पाने के लिए, परफ़ॉर्मेंस से जुड़ी सलाह देखें.
फ़ॉलबैक और ब्राउज़र के लिए सहायता
सभी मॉडर्न ब्राउज़र, वैरिएबल फ़ॉन्ट के साथ काम करते हैं. अगर आपको पुराने ब्राउज़र के साथ काम करना है, तो अपनी साइट को स्टैटिक फ़ॉन्ट के साथ बनाएं और बेहतर बनाने के लिए वैरिएबल फ़ॉन्ट का इस्तेमाल करें:
/* Set up Roboto for old browsers, only regular + bold */
@supports not (font-variation-settings: normal) {
@font-face {
font-family: Roboto;
src: url('Roboto-Regular.woff2');
font-weight: normal;
}
@font-face {
font-family: Roboto;
src: url('Roboto-Bold.woff2');
font-weight: bold;
}
body {
font-family: Roboto;
}
.super-bold {
font-weight: bold;
}
}
/* Set up Roboto for modern browsers, all weights */
@supports (font-variation-settings: normal) {
@font-face {
font-family: 'Roboto';
src: url('RobotoFlex-VF.woff2') format('woff2 supports variations'),
url('RobotoFlex-VF.woff2') format('woff2-variations');
font-weight: 100 1000;
font-stretch: 25% 151%;
}
.super-bold {
font-weight: 1000;
}
}
पुराने ब्राउज़र के लिए, क्लास .super-bold
वाला टेक्स्ट सामान्य बोल्ड में रेंडर होगा, क्योंकि हमारे पास बोल्ड फ़ॉन्ट के तौर पर सिर्फ़ यही फ़ॉन्ट उपलब्ध है. वैरिएबल फ़ॉन्ट के साथ काम करने पर, हम 1,000 की सबसे ज़्यादा मोटाई का इस्तेमाल कर सकते हैं.
@supports
नियम, Internet Explorer पर काम नहीं करता. इसलिए, यह ब्राउज़र कोई स्टाइल नहीं दिखाएगा. अगर यह समस्या है, तो काम के पुराने ब्राउज़र को टारगेट करने के लिए, किसी भी पुराने हैक का इस्तेमाल किया जा सकता है.
अगर Google Fonts API का इस्तेमाल किया जा रहा है, तो यह आपके वेबसाइट पर आने वाले लोगों के ब्राउज़र के लिए सही फ़ॉन्ट लोड करेगा. मान लें कि आपको Oswald फ़ॉन्ट का वेट 200 से 700 के बीच चाहिए, तो इस तरह अनुरोध करें:
<link href="https://fonts.googleapis.com/css2?family=Oswald:wght@200..700&display=swap" rel="stylesheet">
वैरिएबल फ़ॉन्ट को इस्तेमाल करने वाले आधुनिक ब्राउज़र में, वैरिएबल फ़ॉन्ट दिखेगा. साथ ही, 200 से 700 के बीच का हर वेट उपलब्ध होगा. पुराने ब्राउज़र को हर वेट के लिए, अलग-अलग स्टैटिक फ़ॉन्ट दिखाए जाएंगे. इस मामले में, इसका मतलब है कि वे छह फ़ॉन्ट फ़ाइलें डाउनलोड करेंगे: एक 200 की वज़न के लिए, एक 300 की वज़न के लिए वगैरह.
धन्यवाद
यह लेख सिर्फ़ इन लोगों की मदद से लिखा जा सका:
- मुस्तफ़ा कुर्तुदु, Google में यूएक्स डिज़ाइनर और डिज़ाइन एडवोकेट
- रोएल नीस्केंस, Kabisa में यूएक्स डिज़ाइनर/डेवलपर और टाइपोग्राफ़ी विशेषज्ञ
- डेव क्रॉसलैंड, Google Fonts के प्रोग्राम मैनेजर
- डेविड बर्लो, Font Bureau में टाइप डिज़ाइनर और टाइपोग्राफ़र
- लॉरेंस पेनी, axis-praxis.org के डेवलपर
- मंडी माइकल, variablefonts.dev के डेवलपर
Unsplash पर ब्रूनो मार्टिन्स की हीरो इमेज.