रेंडरिंगNG आर्किटेक्चर

Chris Harrelson
Chris Harrelson

यहां आपको पता चलेगा कि रेंडरिंगजीएस कॉम्पोनेंट किस तरह से काम करता है अलग-अलग हिस्सों को सेट अप किया जाता है और रेंडरिंग पाइपलाइन उनके बीच से कैसे फ़्लो करती है.

सबसे ऊंचे लेवल से शुरू करते हुए, रेंडरिंग के काम हैं:

  1. स्क्रीन पर पिक्सल में कॉन्टेंट रेंडर करें.
  2. कॉन्टेंट में एक से दूसरी स्थिति में विज़ुअल इफ़ेक्ट ऐनिमेट करें.
  3. इनपुट के जवाब में स्क्रोल करें.
  4. सही जगहों पर बेहतर तरीके से रास्ते डालें, ताकि डेवलपर स्क्रिप्ट और दूसरे सबसिस्टम जवाब दे सकें.

रेंडर की जाने वाली सामग्री हर ब्राउज़र टैब के लिए फ़्रेम का एक ट्री है, साथ ही ब्राउज़र इंटरफ़ेस. टचस्क्रीन से आने वाले रॉ इनपुट इवेंट की स्ट्रीम, माउस, कीबोर्ड, और अन्य हार्डवेयर डिवाइस शामिल हैं.

हर फ़्रेम में ये चीज़ें शामिल होती हैं:

  • DOM स्थिति
  • सीएसएस
  • कैनवस
  • बाहरी संसाधन, जैसे कि इमेज, वीडियो, फ़ॉन्ट, और SVG

फ़्रेम एक एचटीएमएल दस्तावेज़ होता है. साथ ही, उसका यूआरएल भी होता है. ब्राउज़र टैब में लोड किए गए वेब पेज में एक टॉप-लेवल फ़्रेम होता है, टॉप लेवल दस्तावेज़ में शामिल हर iframe के लिए चाइल्ड फ़्रेम, और उनके रिकर्सिव iframe डिसेंडेंट.

विज़ुअल इफ़ेक्ट एक ग्राफ़िकल ऑपरेशन होता है, जिसे बिट मैप पर लागू किया जाता है, जैसे कि स्क्रोल, ट्रांसफ़ॉर्म, क्लिप, फ़िल्टर, ओपैसिटी या ब्लेंड.

आर्किटेक्चर कॉम्पोनेंट

रेंडरिंग में, इन टास्क को कई स्टेज और कोड में तर्क के साथ बांटा जाता है कॉम्पोनेंट. कॉम्पोनेंट, अलग-अलग सीपीयू प्रोसेस, थ्रेड, और सब-कॉम्पोनेंट का इस्तेमाल करते हैं. हर लक्ष्य को हासिल करने में हर महिला की मदद भरोसेमंद, बेहतरीन परफ़ॉर्मेंस और सभी वेब कॉन्टेंट के लिए एक्सटेंशन की ज़रूरत होती है.

पाइपलाइन का स्ट्रक्चर रेंडर करना

रेंडरिंग पाइपलाइन का डायग्राम.
ऐरो हर स्टेज के इनपुट और आउटपुट के बारे में बताते हैं. स्टेज बनाने की सेवा कलर के हिसाब से नहीं दिखाए जाते. इससे पता चलता है कि वे किस थ्रेड या प्रोसेस को एक्ज़ीक्यूट करते हैं. तय सीमा में कुछ मामलों में, स्टेज कई जगहों पर चलाए जा सकते हैं. ये चरण, कुछ चीज़ों के दो रंग होते हैं. हरे रंग के स्टेज, मुख्य थ्रेड को रेंडर करते हैं; पीले रंग, रेंडर प्रोसेस कंपोज़िटर हैं; नारंगी स्टेज विज़ प्रोसेस हैं.

रेंडर करने की प्रोसेस, एक पाइपलाइन में जारी रहती है. इसमें कई स्टेज और आर्टफ़ैक्ट बनाए जाते हैं ट्रैक करें. हर चरण में कोड होता है. यह एक ऐसा टास्क होता है जिसके बारे में पूरी जानकारी दी गई होती है रेंडरिंग. आर्टफ़ैक्ट, डेटा स्ट्रक्चर हैं जो स्टेज के इनपुट या आउटपुट हों.

चरण इस प्रकार हैं:

  1. ऐनिमेट करें: समय-समय पर जानकारी देने वाली समयावधि के आधार पर, तय की गई स्टाइल बदलें और समय के साथ प्रॉपर्टी ट्री में बदलाव करें.
  2. स्टाइल: सीएसएस को डीओएम पर लागू करें और कंप्यूट की गई स्टाइल बनाएं.
  3. लेआउट: स्क्रीन पर डीओएम एलिमेंट का साइज़ और पोज़िशन तय करते हैं, और नहीं बदला जा सकने वाला फ़्रैगमेंट ट्री बनाएं.
  4. प्री-पेंट: प्रॉपर्टी ट्री और अमान्य सभी मौजूदा डिसप्ले सूचियों और जीपीयू टेक्सचर टाइल को ज़रूरत के मुताबिक बनाएं.
  5. स्क्रोल करना: प्रॉपर्टी ट्री में बदलाव करके, दस्तावेज़ों के स्क्रोल ऑफ़सेट और स्क्रोल किए जा सकने वाले डीओएम एलिमेंट को अपडेट करें.
  6. पेंट: ऐसी डिसप्ले सूची कंप्यूट करें जिसमें डीओएम से जीपीयू टेक्सचर टाइल को रास्टर करने का तरीका बताया गया हो.
  7. पूरा करें: प्रॉपर्टी ट्री और डिसप्ले सूची को कंपोज़िटर थ्रेड में कॉपी करें.
  8. लेयराइज़ करें: इंडिपेंडेंट रास्टराइज़ेशन और ऐनिमेशन के लिए, डिसप्ले सूची को कंपोज़िट की गई लेयर वाली सूची में बांटें.
  9. रास्टर, डिकोड, और पेंट वर्कलेट: ये वर्कलेट, कोड में बदली गई इमेज, और वर्कलेट कोड को पेंट करते हैं जीपीयू टेक्सचर टाइल.
  10. चालू करें: एक कंपोज़िटर फ़्रेम बनाएं, जो विज़ुअल इफ़ेक्ट के साथ, जीपीयू टाइल को स्क्रीन पर ड्रॉ और जगह देने का तरीका बताता है.
  11. एग्रीगेट: सभी दिखने वाले कंपोज़िटर फ़्रेम के कंपोज़िटर फ़्रेम को, एक ग्लोबल कंपोज़िटर फ़्रेम में मिलाएं.
  12. ड्रॉ करें: स्क्रीन पर पिक्सल बनाने के लिए, जीपीयू पर एग्रीगेट किया गया कंपोज़िटर फ़्रेम एक्ज़ीक्यूट करें.

अगर रेंडरिंग पाइपलाइन के स्टेज ज़रूरी नहीं हैं, तो उन्हें स्किप किया जा सकता है. उदाहरण के लिए, विज़ुअल इफ़ेक्ट के ऐनिमेशन और स्क्रोल करने पर, लेआउट स्किप किया जा सकता है, प्री-पेंट किया जा सकता है, और पेंट किया जा सकता है. इसलिए, ऐनिमेशन और स्क्रोल को डायग्राम में पीले और हरे बिंदुओं से मार्क किया जाता है. अगर विज़ुअल इफ़ेक्ट के लिए लेआउट, प्री-पेंट, और पेंट को स्किप किया जा सकता है, उन्हें पूरी तरह कंपोज़िटर थ्रेड पर चलाया जा सकता है और मुख्य थ्रेड को छोड़ा जा सकता है.

ब्राउज़र के यूज़र इंटरफ़ेस (यूआई) की रेंडरिंग सीधे तौर पर यहां नहीं दिखाई गई है, हालांकि, इसे इसी पाइपलाइन के आसान वर्शन के तौर पर माना जा सकता है (और असल में, इसे लागू करने के ज़्यादातर कोड का इस्तेमाल किया जाता है). वीडियो (सीधे तौर पर दिखाया नहीं गया है) आम तौर पर, अलग-अलग कोड के साथ रेंडर होता है, जो फ़्रेम को जीपीयू टेक्सचर टाइल में डीकोड करता है और फिर कंपोज़िटर फ़्रेम्स और ड्रॉ स्टेप में प्लग इन हो जाता है.

प्रोसेस और थ्रेड का स्ट्रक्चर

सीपीयू प्रोसेस

एक से ज़्यादा सीपीयू प्रोसेस का इस्तेमाल करने से, परफ़ॉर्मेंस बेहतर होती है और सुरक्षा को ध्यान में नहीं रखा जाता है साइटों के बीच और ब्राउज़र की स्थिति से, और जीपीयू हार्डवेयर से स्थिरता और सुरक्षा अलग रखना.

सीपीयू प्रोसेस के अलग-अलग हिस्सों का डायग्राम

  • रेंडरिंग की प्रोसेस, किसी एक ही साइट और टैब संयोजन का उपयोग करना चाहिए. रेंडर करने की कई प्रोसेस होती हैं.
  • ब्राउज़र प्रोसेस, ब्राउज़र यूज़र इंटरफ़ेस (यूआई) के लिए इनपुट को रेंडर, ऐनिमेट, और रूट करती है (पता बार, टैब के टाइटल, और आइकॉन शामिल हैं) और बाकी बचे सभी रूट सही रेंडर प्रोसेस में इनपुट डालना. ब्राउज़र की एक प्रोसेस होती है.
  • Viz प्रोसेस, रेंडर करने की एक से ज़्यादा प्रोसेस से कंपोज़िटिंग को इकट्ठा करती है और ब्राउज़र प्रोसेस पर निर्भर करता है. यह जीपीयू का इस्तेमाल करके ड्रॉ करता है और ड्रॉ करता है. यहां है एक Viz प्रोसेस पूरी करनी होगी.

अलग-अलग साइटें वेबसाइट पर कभी भी दिखती हैं अलग-अलग रेंडर प्रोसेस में होते हैं.

एक ही साइट के कई ब्राउज़र टैब या विंडो, आम तौर पर अलग-अलग रेंडर में जाते हैं ऐसा कर सकता है, जब तक कि टैब एक-दूसरे से जुड़े न हों, जैसे कि खोलें. डेस्कटॉप पर ज़्यादा मेमोरी के दबाव में, Chromium में एक से ज़्यादा टैब लग सकते हैं एक ही साइट से एक ही रेंडर प्रोसेस में भेज दें, भले ही वह संबंधित न हो.

किसी एक ब्राउज़र टैब में, अलग-अलग साइटों के फ़्रेम हमेशा एक-दूसरे से अलग रेंडर प्रोसेस में होते हैं, लेकिन एक ही साइट के फ़्रेम हमेशा एक ही रेंडर प्रोसेस में होते हैं. रेंडरिंग के हिसाब से, कई रेंडर प्रोसेस का अहम फ़ायदा यह है कि क्रॉस-साइट iframe और टैब परफ़ॉर्मेंस अलग-अलग रखते हैं. एक-दूसरे से जुड़ी हुई क्वेरी हैं. इसके अलावा, ऑरिजिन पहले से ज़्यादा आइसोलेशन के लिए ऑप्ट इन कर सकते हैं.

सभी Chromium के लिए, एक ही Viz प्रोसेस है. आम तौर पर, यह प्रोसेस सिर्फ़ एक बनाने के लिए एक जीपीयू और स्क्रीन.

Viz को उसकी प्रोसेस में अलग करना, गड़बड़ियों का सामना करने में स्थिरता के लिए अच्छा है जीपीयू ड्राइवर या हार्डवेयर. यह सिक्योरिटी आइसोलेशन के लिए भी अच्छा है, जो जीपीयू एपीआई के लिए ज़रूरी है, जैसे कि Vulkan और आम तौर पर सुरक्षा.

ब्राउज़र में कई टैब और विंडो हो सकते हैं, इसलिए और उन सभी में ड्रॉ करने के लिए ब्राउज़र यूज़र इंटरफ़ेस (यूआई) पिक्सल होता है, आप सोच सकते हैं: ब्राउज़र की एक ही प्रोसेस क्यों होती है? इसकी वजह यह है कि एक समय पर, उनमें से किसी एक पर ही फ़ोकस किया गया है; असल में, न दिखने वाले ब्राउज़र टैब आम तौर पर बंद हो जाते हैं और अपनी सारी जीपीयू मेमोरी ड्रॉप कर देते हैं. हालांकि, ब्राउज़र के यूज़र इंटरफ़ेस (यूआई) को रेंडर करने वाली जटिल सुविधाओं को तेज़ी से लागू किया जा रहा है रेंडर प्रक्रियाओं में भी ( WebUI) है. ऐसा सिर्फ़ परफ़ॉर्मेंस पर निर्भर न करने की वजह से नहीं किया गया है. यह भी ज़रूरी है कि इसे Chromium के वेब रेंडरिंग इंजन का आसानी से इस्तेमाल करने का फ़ायदा मिले.

पुराने Android डिवाइसों पर, वेबव्यू में इस्तेमाल किए जाने पर रेंडर और ब्राउज़र प्रोसेस शेयर की जाती है (यह आम तौर पर, Android पर Chromium पर लागू नहीं होता, सिर्फ़ वेबव्यू पर लागू होता है). वेबव्यू पर, एम्बेड करने वाले ऐप्लिकेशन के साथ ब्राउज़र प्रोसेस को भी शेयर किया जाता है, और वेबव्यू में सिर्फ़ एक रेंडर प्रोसेस होती है.

कभी-कभी सुरक्षित वीडियो कॉन्टेंट को डिकोड करने के लिए, एक काम की तरीका भी इस्तेमाल की जाती है. यह प्रोसेस पिछले डायग्राम में नहीं दिखाई गई है.

बातचीत के थ्रेड

Thread की मदद से, धीमे टास्क काम करने के बावजूद, परफ़ॉर्मेंस को अलग-अलग और बेहतर तरीके से लागू किया जा सकता है. पाइपलाइन समानांतराइज़ेशन और मल्टीपल बफ़रिंग पर ध्यान दिया जा सकता है.

रेंडर करने की प्रोसेस का डायग्राम.

  • मुख्य थ्रेड, स्क्रिप्ट, रेंडरिंग इवेंट लूप, दस्तावेज़ का लाइफ़साइकल, हिट टेस्टिंग, स्क्रिप्ट इवेंट डिस्पैच, और एचटीएमएल, सीएसएस, और अन्य डेटा फ़ॉर्मैट को पार्स करना.
    • मुख्य थ्रेड के हेल्पर, इमेज बिटमैप और ब्लॉब बनाने जैसे काम करते हैं, जिन्हें कोड में बदलने या डिकोड करने की ज़रूरत होती है.
    • वेब वर्कर रन स्क्रिप्ट और ऑफ़स्क्रीन कैनवास के लिए रेंडरिंग इवेंट लूप है.
  • कंपोज़िटर थ्रेड, इनपुट इवेंट को प्रोसेस करता है, वेब कॉन्टेंट को स्क्रोल करके और ऐनिमेशन करता है, वेब कॉन्टेंट की सबसे बेहतरीन लेयराइज़ेशन का पता लगाता है. और इमेज डीकोड, वर्कलेट और रास्टर टास्क को पेंट करें.
    • कंपोज़िटर थ्रेड हेल्पर, विज़ रास्टर टास्क को कोऑर्डिनेट करते हैं, साथ ही, इमेज डिकोड करने के टास्क, पेंट वर्कलेट, और फ़ॉलबैक रास्टर एक्ज़ीक्यूट कर सकते हैं.
  • मीडिया, डीमक्सर या ऑडियो आउटपुट थ्रेड डिकोड करना, वीडियो और ऑडियो स्ट्रीम प्रोसेस करने और उन्हें सिंक करने में मदद मिलती है. (याद रखें कि वीडियो, रेंडरिंग की मुख्य पाइपलाइन के साथ-साथ चलता है.)

मुख्य और कंपोज़िटर थ्रेड को अलग-अलग करना परफ़ॉर्मेंस आइसोलेशन ऐनिमेशन और मुख्य थ्रेड के काम से स्क्रोल किया जा सकता है.

हर रेंडर की प्रोसेस में सिर्फ़ एक मुख्य थ्रेड होता है. भले ही एक ही साइट के कई टैब या फ़्रेम एक ही प्रक्रिया में खत्म हो जाएं. हालांकि, अलग-अलग ब्राउज़र एपीआई में किए गए काम से परफ़ॉर्मेंस आइसोलेशन होती है. उदाहरण के लिए, कैनवस एपीआई में इमेज बिटमैप और ब्लॉब की जनरेशन मुख्य थ्रेड के हेल्पर थ्रेड में चलती है.

इसी तरह, हर रेंडर प्रोसेस में सिर्फ़ एक कंपोज़िटर थ्रेड होता है. आम तौर पर यह समस्या नहीं होती कि सिर्फ़ एक ही समस्या है. कंपोज़िटर थ्रेड पर बहुत महंगे ऑपरेशन होते थे को या तो कंपोज़िटर वर्कर थ्रेड या Viz प्रोसेस के लिए असाइन किया जाता है, यह काम इनपुट रूटिंग, स्क्रोलिंग या ऐनिमेशन के साथ किया जा सकता है. कंपोज़िटर वर्कर थ्रेड, Viz प्रोसेस में चलाए जाने वाले टास्क को कोऑर्डिनेट करते हैं, हालांकि, हर जगह जीपीयू से तेज़ी आती है Gmail के कंट्रोल से बाहर की वजहों से फ़ेल हो सकता है. जैसे कि ड्राइवर की गड़बड़ियां. इन स्थितियों में वर्कर थ्रेड, सीपीयू पर फ़ॉलबैक मोड में काम करता है.

कंपोज़िटर वर्कर थ्रेड की संख्या, डिवाइस की क्षमता पर निर्भर करती है. उदाहरण के लिए, डेस्कटॉप पर आम तौर पर ज़्यादा थ्रेड इस्तेमाल किए जाएंगे, क्योंकि उनमें ज़्यादा सीपीयू कोर होते हैं और मोबाइल डिवाइसों की तुलना में उनकी बैटरी कम होती है. यह इसका एक उदाहरण है स्केल अप करना और स्केल करना शामिल है.

रेंडर प्रोसेस की थ्रेडिंग आर्किटेक्चर, तीन अलग-अलग तरह के ऐप्लिकेशन का एक ऐप्लिकेशन है ऑप्टिमाइज़ेशन पैटर्न:

  • हेल्पर थ्रेड: लंबे समय तक चलने वाले सबटास्क को दूसरे थ्रेड में बंद करें, ताकि उन्हें बनाए रखा जा सके एक साथ कई अनुरोधों पर प्रतिक्रिया देने वाला पैरंट थ्रेड. मुख्य थ्रेड हेल्पर और कंपोज़िटर हेल्पर थ्रेड इस तकनीक के अच्छे उदाहरण हैं.
  • एक से ज़्यादा बफ़र करना: नया कॉन्टेंट रेंडर करते समय, पहले रेंडर किया गया कॉन्टेंट दिखाने के लिए, ताकि रेंडरिंग में लगने वाला समय. कंपोज़िटर थ्रेड इस तकनीक का इस्तेमाल करता है.
  • पाइपलाइन पैरललाइज़ेशन: रेंडरिंग पाइपलाइन को एक से ज़्यादा जगहों पर चलाएं साथ-साथ स्क्रोलिंग और ऐनिमेशन तेज़ी से किए जा सकते हैं; भले ही, किसी मुख्य थ्रेड को रेंडर करने के लिए अपडेट हो रहा है. स्क्रोल और ऐनिमेशन, साथ-साथ चलेगा.

ब्राउज़र प्रक्रिया

ब्राउज़र प्रोसेस का एक डायग्राम, जिसमें रेंडर और कंपोज़िटिंग थ्रेड के साथ-साथ रेंडर और कंपोज़िटिंग थ्रेड हेल्पर के बीच संबंध को दिखाया गया है.

  • रेंडर और कंपोज़िटिंग थ्रेड, ब्राउज़र यूज़र इंटरफ़ेस (यूआई) में इनपुट का जवाब देता है, दूसरे इनपुट को सही रेंडर प्रोसेस पर ले जाता है; ब्राउज़र यूज़र इंटरफ़ेस (यूआई) को लेआउट और पेंट करता है.
  • रेंडर और कंपोज़िटिंग थ्रेड हेल्पर इमेज डिकोड करने के टास्क और फ़ॉलबैक रास्टर या डिकोड करना.

ब्राउज़र प्रोसेस रेंडर और कंपोज़िटिंग थ्रेड एक जैसे हैं के काम करने के तरीके और उनके काम करने के तरीके पर ज़्यादा ध्यान देते हैं. इसे छोड़कर, मुख्य थ्रेड और कंपोज़िटर थ्रेड को एक साथ जोड़ दिया जाता है. इस मामले में सिर्फ़ एक थ्रेड की ज़रूरत है, क्योंकि मुख्य थ्रेड के लंबे टास्क से परफ़ॉर्मेंस आइसोलेशन, क्योंकि इन्हें डिज़ाइन नहीं किया गया है.

विज़ प्रोसेस

Viz प्रोसेस में जीपीयू का मुख्य थ्रेड और डिसप्ले कंपोज़िटर थ्रेड शामिल होता है.

  • GPU मुख्य थ्रेड के रैस्टर, जीपीयू टेक्सचर टाइल में सूचियां और वीडियो फ़्रेम दिखाते हैं, और कंपोज़िटर फ़्रेम को स्क्रीन पर खींचता है.
  • डिसप्ले कंपोज़िटर थ्रेड, हर रेंडर प्रोसेस से कंपोज़िटिंग को एग्रीगेट और ऑप्टिमाइज़ करता है, साथ ही, स्क्रीन पर प्रज़ेंटेशन के लिए एक कंपोज़िटर फ़्रेम में, ब्राउज़र प्रोसेस को पूरा करना.

रास्टर और ड्रॉ आम तौर पर एक ही थ्रेड पर होते हैं, क्योंकि वे दोनों जीपीयू संसाधनों पर निर्भर करते हैं, और जीपीयू के मल्टी-थ्रेड का इस्तेमाल करना मुश्किल है (जीपीयू तक ज़्यादा आसान मल्टी-थ्रेडेड ऐक्सेस की सुविधा नए तरीके से डेवलप करने में मदद करती है. Vulkan मानक). Android वेबव्यू पर, ड्रॉइंग के लिए ओएस-लेवल का एक अलग रेंडर थ्रेड मौजूद होता है ऐसा इसलिए होता है, क्योंकि वेबव्यू किसी खास ऐप्लिकेशन में एम्बेड होते हैं. आने वाले समय में, अन्य प्लैटफ़ॉर्म पर भी इस तरह का थ्रेड हो सकता है.

डिसप्ले कंपोज़िटर किसी दूसरे थ्रेड पर है, क्योंकि उसे हर समय रिस्पॉन्सिव होना चाहिए, साथ ही, जीपीयू के मुख्य थ्रेड पर, धीमे ट्रैफ़िक के किसी भी संभावित सोर्स को ब्लॉक न करें. जीपीयू के मुख्य थ्रेड पर धीमे ट्रैफ़िक की एक वजह, बिना Chromium कोड के कॉल करना है, जैसे, वेंडर के लिए खास तौर पर बनाए गए जीपीयू ड्राइवर, जो कि ऐसे तरीके से धीमा हो सकते हैं जिनका अनुमान लगाना मुश्किल हो.

कॉम्पोनेंट स्ट्रक्चर

हर रेंडर प्रोसेस के मुख्य या कंपोज़िटर थ्रेड में, कुछ ऐसे लॉजिकल सॉफ़्टवेयर कॉम्पोनेंट होते हैं जो एक-दूसरे के साथ स्ट्रक्चर्ड तरीके से इंटरैक्ट करते हैं.

मुख्य थ्रेड के कॉम्पोनेंट को रेंडर करने की प्रोसेस

ब्लिंक रेंडरर का डायग्राम.

ब्लिंक रेंडरर में:

  • लोकल फ़्रेम ट्री फ़्रैगमेंट, लोकल फ़्रेम के ट्री और फ़्रेम में डीओएम को दिखाता है.
  • DOM और कैनवस API कॉम्पोनेंट में, इन सभी एपीआई को लागू किया जाता है.
  • दस्तावेज़ लाइफ़साइकल रनर, रेंडरिंग पाइपलाइन के चरणों को तय किए गए चरण तक लागू करता है.
  • इनपुट इवेंट हिट टेस्टिंग और डिस्पैचिंग कॉम्पोनेंट, हिट टेस्ट को इन कामों के लिए लागू करता है यह पता लगाना कि किसी इवेंट से कौनसा डीओएम एलिमेंट टारगेट किया गया है और फिर यह इनपुट इवेंट को चलाता है एल्गोरिदम और डिफ़ॉल्ट व्यवहार की जानकारी भेजी जाती है.

रेंडरिंग इवेंट लूप शेड्यूलर और रनर यह तय करता है कि इवेंट पर क्या चलाना है लूप और कब दिखेगा. यह रेंडरिंग, डिवाइस से मेल खाने वाली फ़्रीक्वेंसी पर होने के लिए शेड्यूल करता है डिसप्ले.

फ़्रेम ट्री का डायग्राम.

लोकल फ़्रेम ट्री के फ़्रैगमेंट समझना थोड़ा मुश्किल है. याद रखें कि फ़्रेम ट्री मुख्य पेज होता है और इसके चाइल्ड iframe बार-बार होते हैं. अगर फ़्रेम किसी रेंडर प्रोसेस में रेंडर होता है, तो वह लोकल होता है, नहीं तो यह रिमोट होता है.

फ़्रेम को रेंडर करने की प्रोसेस के हिसाब से, उनमें रंग भरने की कल्पना की जा सकती है. पिछली इमेज में, हरे रंग के सर्कल से हर फ़्रेम को रेंडर करने की एक ही प्रोसेस में शामिल किया जाता है; नारंगी विज्ञापन एक सेकंड में हैं और नीले रंग वाला तीसरी जगह में है.

लोकल फ़्रेम ट्री फ़्रैगमेंट, फ़्रेम ट्री में एक ही रंग का जुड़ा हुआ कॉम्पोनेंट होता है. इमेज में चार लोकल फ़्रेम ट्री हैं: साइट A के लिए दो, साइट B के लिए, और साइट C के लिए. हर लोकल फ़्रेम ट्री को अपना खुद का ब्लिंक रेंडरर कॉम्पोनेंट मिलता है. स्थानीय फ़्रेम ट्री का ब्लिंक रेंडरर एक ही रेंडर प्रक्रिया में हो भी सकता है और नहीं भी स्थानीय फ़्रेम ट्री की तरह. जैसा कि ऊपर बताया गया है, यह रेंडर करने की प्रोसेस चुनने के तरीके से तय होता है.

रेंडर प्रोसेस कंपोज़िटर थ्रेड स्ट्रक्चर

रेंडर प्रोसेस कंपोज़िटर कॉम्पोनेंट दिखाने वाला डायग्राम.

रेंडर प्रोसेस कंपोज़िटर के कॉम्पोनेंट में ये शामिल होते हैं:

  • यह एक डेटा हैंडलर होता है, जो कंपोज़िट की गई लेयर की सूची, डिसप्ले लिस्ट, और प्रॉपर्टी ट्री को बनाए रखता है.
  • लाइफ़साइकल रनर, जो ऐनिमेशन, स्क्रोल, कंपोज़िट, रास्टर, और रेंडरिंग पाइपलाइन के चरणों को डिकोड करके, उन्हें चालू किया जा सकता है. (ध्यान रखें कि ऐनिमेशन और स्क्रोल, मुख्य थ्रेड और कंपोज़िटर, दोनों में हो सकते हैं.)
  • इनपुट और हिट टेस्ट हैंडलर इनपुट प्रोसेसिंग और हिट टेस्ट करने के लिए कंपोज़िट लेयर के रिज़ॉल्यूशन पर होता है. यह तय करने के लिए कि कंपोज़िटर थ्रेड पर स्क्रोल करने वाले जेस्चर चलाए जा सकते हैं या नहीं, और यह कि किस रेंडर प्रोसेस के हिट टेस्ट को टारगेट किया जाना चाहिए.

इस्तेमाल किए जा रहे आर्किटेक्चर का उदाहरण

इस उदाहरण में तीन टैब हैं:

टैब 1: foo.com

<html>
  <iframe id=one src="foo.com/other-url"></iframe>
  <iframe  id=two src="bar.com"></iframe>
</html>

टैब 2: bar.com

<html>
 …
</html>

टैब 3: baz.com html <html> … </html>

इन टैब की प्रोसेस, थ्रेड, और कॉम्पोनेंट का स्ट्रक्चर इस तरह दिखता है:

टैब को प्रोसेस करने का डायग्राम.

आइए, रेंडरिंग के चार मुख्य कामों में से हर एक का उदाहरण देखते हैं. रिमाइंडर:

  1. कॉन्टेंट को स्क्रीन पर पिक्सल में रेंडर करना.
  2. कॉन्टेंट में एक से दूसरी स्थिति में विज़ुअल इफ़ेक्ट एनिमेटेड करें.
  3. इनपुट के जवाब में स्क्रोल करें.
  4. सही जगहों पर बेहतर तरीके से रूट भेजें, ताकि डेवलपर स्क्रिप्ट और दूसरे सबसिस्टम जवाब दे सकें.

टैब पहले के लिए बदले गए DOM को रेंडर करने के लिए:

  1. डेवलपर स्क्रिप्ट, foo.com के लिए रेंडर करने की प्रोसेस में DOM को बदल देती है.
  2. ब्लिंक रेंडरर, कंपोज़िटर को बताता है कि उसे रेंडर होने की ज़रूरत है.
  3. कंपोज़िटर विज़ को बताता है कि उसे रेंडर होने की ज़रूरत है.
  4. Viz, रेंडर की शुरुआत कंपोज़िटर को वापस शुरू करने का सिग्नल देता है.
  5. कंपोज़िटर, स्टार्ट सिग्नल को ब्लिंक रेंडरर पर फ़ॉरवर्ड करता है.
  6. मुख्य थ्रेड इवेंट लूप रनर, दस्तावेज़ का लाइफ़साइकल चलाता है.
  7. मुख्य थ्रेड, नतीजे को कंपोज़िटर थ्रेड को भेजती है.
  8. कंपोज़िटर इवेंट लूप रनर, कंपोज़िटिंग लाइफ़साइकल चलाता है.
  9. किसी भी रास्टर टास्क को रास्टर के लिए विज़ को भेजा जाता है (अक्सर इनमें से एक से ज़्यादा टास्क होते हैं).
  10. जीपीयू पर विज़ रैस्टर कॉन्टेंट.
  11. विज़, रास्टर टास्क पूरा होने के बारे में स्वीकार करते हैं. ध्यान दें: Chromium अक्सर रास्टर के पूरा होने का इंतज़ार नहीं करता, और इसके बजाय सिंक टोकन जिसे हल करना ज़रूरी है रास्टर टास्क के हिसाब से, 15वें चरण को पूरा करने से पहले.
  12. एक कंपोज़िटर फ़्रेम, Viz को भेजा गया.
  13. Viz, foo.com रेंडर प्रोसेस के लिए कंपोज़िटर फ़्रेम को एग्रीगेट करता है, Bar.com iframe रेंडर होने की प्रोसेस और ब्राउज़र यूज़र इंटरफ़ेस (यूआई) पर स्विच करता है.
  14. विज़ ड्रॉ शेड्यूल करता है.
  15. विज़, एग्रीगेट किए गए कंपोज़िटर फ़्रेम को स्क्रीन पर ड्रॉ करता है.

सीएसएस ट्रांसफ़ॉर्म ट्रांज़िशन को टैब दो पर ऐनिमेट करने के लिए:

  1. Bar.com रेंडर प्रोसेस के लिए कंपोज़िटर थ्रेड में एक ऐनिमेशन दिखता है मौजूदा प्रॉपर्टी ट्री में बदलाव करके, अपने कंपोज़िटर इवेंट लूप में. इसके बाद, कंपोज़िटर का लाइफ़साइकल फिर से चलता है. (रास्टर और डिकोड करने वाले टास्क, हो सकते हैं, लेकिन उन्हें यहां नहीं दिखाया जाता.)
  2. एक कंपोज़िटर फ़्रेम, Viz को भेजा गया.
  3. Viz, foo.com रेंडर प्रोसेस, बार.com रेंडर प्रोसेस, और ब्राउज़र यूज़र इंटरफ़ेस (यूआई) के लिए कंपोज़िटर फ़्रेम को एग्रीगेट करता है.
  4. विज़ ड्रॉ शेड्यूल करता है.
  5. विज़, एग्रीगेट किए गए कंपोज़िटर फ़्रेम को स्क्रीन पर ड्रॉ करता है.

टैब तीन पर वेब पेज को स्क्रोल करने के लिए:

  1. ब्राउज़र प्रोसेस में input इवेंट का क्रम (माउस, टच या कीबोर्ड) आता है.
  2. हर इवेंट को baz.com के रेंडर प्रोसेस कंपोज़िटर थ्रेड में रूट किया जाता है.
  3. कंपोज़िटर यह तय करता है कि मुख्य थ्रेड को इवेंट के बारे में जानने की ज़रूरत है या नहीं.
  4. ज़रूरी होने पर, इवेंट को मुख्य थ्रेड पर भेजा जाता है.
  5. मुख्य थ्रेड, input इवेंट लिसनर को ट्रिगर करता है (pointerdown, touchstar, pointermove, touchmove या wheel) यह देखने के लिए कि क्या श्रोता इवेंट पर preventDefault को कॉल करेंगे.
  6. मुख्य थ्रेड यह बताती है कि preventDefault को कंपोज़िटर को कॉल किया गया था या नहीं.
  7. अगर ऐसा नहीं है, तो इनपुट इवेंट को वापस ब्राउज़र प्रोसेस में भेजा जाएगा.
  8. ब्राउज़र प्रोसेस उसे हाल ही के अन्य इवेंट के साथ मिला कर, उसे स्क्रोल जेस्चर में बदल देती है.
  9. स्क्रोल जेस्चर को एक बार फिर baz.com के रेंडर प्रोसेस कंपोज़िटर थ्रेड पर भेजा जाता है,
  10. स्क्रोल वहां लागू होता है और bar.com के लिए कंपोज़िटर थ्रेड लागू होती है रेंडर प्रोसेस के कंपोज़िटर इवेंट लूप में ऐनिमेशन टिक होता है. इसके बाद यह प्रॉपर्टी ट्री में स्क्रोल ऑफ़सेट को बदल देता है और कंपोज़िटर के लाइफ़साइकल को फिर से चलाता है. यह मुख्य थ्रेड को scroll इवेंट ट्रिगर करने के लिए भी कहता है (यहां नहीं दिखाया गया है).
  11. एक कंपोज़िटर फ़्रेम, Viz को भेजा गया.
  12. Viz, foo.com रेंडर प्रोसेस के लिए कंपोज़िटर फ़्रेम को एग्रीगेट करता है, बार.com रेंडर प्रोसेस, और ब्राउज़र यूज़र इंटरफ़ेस (यूआई) की इमेज शामिल करें.
  13. विज़ ड्रॉ शेड्यूल करता है.
  14. विज़, एग्रीगेट किए गए कंपोज़िटर फ़्रेम को स्क्रीन पर ड्रॉ करता है.

टैब पहले पर iframe #two में हाइपरलिंक पर click इवेंट को रूट करने के लिए:

  1. ब्राउज़र प्रोसेस में input इवेंट (माउस, टच या कीबोर्ड) आता है. यह अनुमानित हिट टेस्ट करता है ताकि यह तय किया जा सके कि bar.com iframe रेंडर होने की प्रोसेस को क्लिक मिलना चाहिए और उसे वहां भेज दिया जाता है.
  2. Bar.com का कंपोज़िटर थ्रेड, click इवेंट को मुख्य थ्रेड पर रूट करता है Bar.com के लिए काम करता है और इसे प्रोसेस करने के लिए रेंडरिंग इवेंट लूप टास्क को शेड्यूल करता है.
  3. Bar.com के मुख्य थ्रेड का इनपुट इवेंट प्रोसेसर हिट यह तय करने के लिए टेस्ट करता है कि iframe में मौजूद DOM एलिमेंट पर क्लिक किया गया है और स्क्रिप्ट की निगरानी के लिए click इवेंट ट्रिगर करता है. preventDefault सुनाई नहीं दे रहा, इसलिए यह हाइपरलिंक पर ले जाती है.
  4. हाइपरलिंक के डेस्टिनेशन पेज के लोड होने पर, एक नई स्थिति दिखाई जाती है, "रेंडरिंग का बदला गया DOM" जैसे चरणों के साथ पिछला उदाहरण. (इन बदलावों को यहां नहीं दिखाया गया है.)

खाना पैक कराकर ले जाने की सुविधा

रेंडरिंग के काम करने के तरीके को याद रखने और उसे अपने हिसाब से बनाने में बहुत समय लग सकता है.

सबसे ज़रूरी बात यह है कि रेंडरिंग पाइपलाइन को मॉड्यूलराइज़ेशन और बारीकियों पर ध्यान देने की सुविधा को कई अपने-आप में पूरे कॉम्पोनेंट. इसके बाद, इन कॉम्पोनेंट को पैरलल में बांट दिया गया है प्रोसेस और थ्रेड को ऑप्टिमाइज़ किया जा सकता है. बेहतर परफ़ॉर्मेंस साथ ही, इस्तेमाल करने के बेहतरीन अवसर उपलब्ध होने चाहिए.

हर कॉम्पोनेंट, परफ़ॉर्मेंस और सुविधाओं को चालू करने में अहम भूमिका निभाता है मॉडर्न वेब ऐप्लिकेशन उपलब्ध हैं.

मुख्य डेटा स्ट्रक्चर के बारे में पढ़ना जारी रखें, जो रेस्पॉन्ड करने के लिए, कोड कॉम्पोनेंट के बराबर ही ज़रूरी हैं.


यूना क्रवेट्स के इलस्ट्रेशन.