Fundamentals
Core
Master
Shaders
Optimization
3D वेबसाइटें प्रदर्शन के मामले में मांग करने वाली हो सकती हैं। यह ध्यान रखना महत्वपूर्ण है कि सभी उपयोगकर्ता एक ही डिवाइस का उपयोग नहीं करते हैं।
कुछ के पास शक्तिशाली GPU और उच्च रिज़ॉल्यूशन स्क्रीन वाले उच्च अंत डिवाइस होते हैं जबकि अन्य के पास कमजोर GPU और निम्न रिज़ॉल्यूशन स्क्रीन वाले निम्न अंत डिवाइस होते हैं।
सुनिश्चित करने के लिए कि अधिकतम उपयोगकर्ता आपकी 3D वेब एप्स का उनके सर्वोत्तम पर आनंद ले सकें, आपको उन्हें अनुकूलित करना होगा और अनावश्यक गणनाओं से बचना होगा।
इस पाठ में, हम अपने React Three Fiber प्रोजेक्ट्स को अनुकूलित करने की विभिन्न तकनीकों और कुछ सामान्य गलतियों को बचने के बारे में देखेंगे।
Draw calls
3D ग्राफिक्स में, एक draw call GPU को भेजा गया एक कमांड है जो ग्राफिक API को क्या खींचना है और कैसे खींचना है बताता है।
जितने अधिक draw calls होंगे, GPU को उतना ही अधिक कार्य करना होगा।
अपने React Three Fiber प्रोजेक्ट्स में draw calls की संख्या की निगरानी करने के लिए आप Chrome के लिए SpectorJS एक्सटेंशन का उपयोग कर सकते हैं।
एक्सटेंशन इंस्टॉल करने के बाद, आप Chrome टूलबार में Spector.js आइकॉन पर क्लिक करके SpectorJS पैनल खोल सकते हैं।
Draw calls को रिकॉर्ड करना शुरू करने के लिए लाल वृत्त बटन पर क्लिक करें। कुछ सेकंड प्रतीक्षा करें और SpectorJS पैनल खुल जाएगा।
डिफ़ॉल्ट रूप से यह कमांड्स टैब में खुलता है। यह आपको GPU को भेजे गए सभी कमांड्स दिखाता है। बाईं कॉलम में, आप प्रत्येक draw call के लिए एक थंबनेल देख सकते हैं।
पहले draw calls छायाओं के लिए होते हैं। फिर आप करेक्टर के लिए draw calls देख सकते हैं और फिर प्रत्येक क्यूब के लिए एक (बाद वाले को अनुकूलित किया जाना चाहिए)।
सूचना टैब भी कुछ उपयोगी जानकारी देता है जैसे वर्टिसीज की संख्या और draw calls की संख्या।
अब हम अपने React Three Fiber प्रोजेक्ट्स को draw calls की संख्या कम करने के लिए कैसे अनुकूलित करें देखेंगे।
Instancing
Instancing का विचार 3D ग्राफ़िक्स में व्यापक रूप से उपयोग किया जाता है। यह एक ही geometry और material को कई वस्तुओं के लिए पुनः उपयोग करने की अनुमति देता है।
यह एक शानदार समाधान है जब आप एक ही वस्तु को कई बार प्रस्तुत करना चाहते हैं लेकिन विभिन्न position
, scale
, rotation
या color
के साथ...
यह सभी draw calls को एक में मिला देता है और प्रदर्शन में सुधार करता है।
Drei लाइब्रेरी हमें इसे आसानी से करने में मदद करने के लिए Instances कंपोनेंट प्रदान करती है।
हमें उस geometry और material को Instances
कंपोनेंट के साथ wrap करने की आवश्यकता है जिसे हम instantiate करना चाहते हैं।
End of lesson preview
To get access to the entire lesson, you need to purchase the course.