लोडिंग स्क्रीन

Starter pack

3D अनुभवों में, जटिल मॉडल्स और बड़ी टेक्सचर्स होना सामान्य है। इससे लंबा लोडिंग समय हो सकता है। ब्लैंक स्क्रीन और ख़राब पहले इम्प्रेशन से बचने के लिए, हम एक लोडिंग स्क्रीन जोड़ सकते हैं।

मैं व्यक्तिगत रूप से सोचता हूँ कि जब भी संभव हो, लोडिंग स्क्रीन से बचना चाहिए (जब तक कि यह डिज़ाइन का हिस्सा न हो)। सबसे पहले मॉडल्स और टेक्सचर्स को ऑप्टिमाइज़ करना चाहिए।

लेकिन कभी-कभी आपके पास कोई विकल्प नहीं होता, और यहां तक कि ऑप्टिमाइज़्ड मॉडल्स भी बड़े हो सकते हैं या आपके पास कई हो सकते हैं। इस स्थिति में, एक लोडिंग स्क्रीन एक अच्छा समाधान हो सकता है।

Suspense

Suspense एक React रैपर कंपोनेंट है जो आपको डेटा लोड होने तक फॉलबैक कंपोनेंट रेंडर करने की अनुमति देता है।

पारंपरिक ऐप्स में यह डेटा आमतौर पर डेटा फेचिंग या कोड स्प्लिटिंग को संदर्भित करता है। लेकिन React Three Fiber में, हम इसे मॉडल्स और टेक्सचर्स को लोड होने के लिए इंतजार करने के लिए उपयोग कर सकते हैं।

useLoader hook प्रॉमिसेज का उपयोग करता है मॉडल्स और टेक्सचर्स लोड करने के लिए। इसलिए हम उन्हें रिज़ॉल्व होने का इंतजार करने के लिए Suspense का उपयोग कर सकते हैं।

स्टार्टर पैक में, मैंने public/models/ में +3MB प्रत्येक के 4 मॉडल्स जोड़े हैं। (जो एक वेब ऐप के लिए बहुत है क्योंकि सभी में एक ही एनीमेशन हैं और उन्हें ऑप्टिमाइज़ किया जाना चाहिए) इससे हमें यह देखने की अनुमति मिलेगी कि Suspense कैसे काम करता है।

जब मैं रीलोड करता हूँ, तो मॉडल्स लोड होने से पहले हमारे पास एक लंबी ब्लैंक स्क्रीन होती है। यह एक अच्छा यूज़र अनुभव नहीं है, यूज़र्स सोच सकते हैं कि ऐप टूट गया है और छोड़ सकते हैं

यदि आप स्थानीय रूप से काम कर रहे हैं या मॉडल्स आपके ब्राउज़र में कैश्ड हैं, तो आपको ब्लैंक स्क्रीन दिखाई नहीं देगी।

संसाधनों को पुनः लोड करने के लिए आप अपने ब्राउज़र डेवलपर टूल्स के नेटवर्क टैब में कैश को अक्षम कर सकते हैं।

आप थ्रॉटलिंग विकल्प का उपयोग करके नेटवर्क को धीमा भी कर सकते हैं।

Disable cache and Throttle network

अब हम सभी को ब्लैंक स्क्रीन देखनी चाहिए, चलिए एक Suspense कंपोनेंट को fallback प्रॉप के साथ जोड़ते हैं:

import { Canvas } from "@react-three/fiber";
import { Experience } from "./components/Experience";
import { Suspense } from "react";

const CubeLoader = () => {
  return (
    <mesh>
      <boxGeometry />
      <meshNormalMaterial />
    </mesh>
  );
};

function App() {
  return (
    <>
      <Canvas camera={{ position: [-4, 4, 12], fov: 30 }}>
        <Suspense fallback={<CubeLoader />}>
          <group position-y={-1}>
            <Experience />
          </group>
        </Suspense>
      </Canvas>
    </>
  );
}

export default App;

हमारा fallback कंपोनेंट एक साधारण क्यूब है, यह सबसे अच्छा दिखने वाला लोडिंग स्क्रीन नहीं है, लेकिन यह समझने के लिए पर्याप्त है कि Suspense कैसे काम करता है।

जब हम रीलोड करते हैं, तो हम देख सकते हैं कि क्यूब मॉडल्स लोड होने तक डिस्प्ले होता है। जब वे लोड हो जाते हैं, तो क्यूब को Experience कंपोनेंट द्वारा बदल दिया जाता है।

प्रीलोड

एक सामान्य समस्या जो आप सामना कर सकते हैं वह है कि आपके संसाधन तुरंत आवश्यक नहीं होते हैं। उदाहरण के लिए, आपके पास एक मॉडल हो सकता है जो केवल तब लोड होता है जब उपयोगकर्ता एक बटन पर क्लिक करता है। इसलिए इसे Suspense द्वारा ध्यान में नहीं लिया जाएगा।

यह fallback घटक को फिर से प्रदर्शित कर सकता है जब संसाधन की आवश्यकता होती है। इससे बचने के लिए, हम विभिन्न Drei loaders से preload फ़ंक्शन का उपयोग कर सकते हैं।

Three.js logoReact logo

React Three Fiber: The Ultimate Guide to 3D Web Development

✨ You have reached the end of the preview ✨

Go to the next level with Three.js and React Three Fiber!

Get full access to this lesson and the complete course when you enroll:

  • 🔓 Full lesson videos with no limits
  • 💻 Access to the final source code
  • 🎓 Course progress tracking & completion
  • 💬 Invite to our private Discord community
Unlock the Full Course – Just $85

One-time payment. Lifetime updates included.