ViewModel को स्कोप करने वाले एपीआई (व्यू)   Android Jetpack का हिस्सा हैं.

कॉन्सेप्ट और Jetpack Compose को लागू करने का तरीका

ViewModel का सही तरीके से इस्तेमाल करने के लिए, स्कोप तय करना ज़रूरी है. हर ViewModel को किसी ऐसे ऑब्जेक्ट के लिए स्कोप किया जाता है जो ViewModelStoreOwner इंटरफ़ेस को लागू करता है. ऐसे कई एपीआई हैं जिनकी मदद से, अपने ViewModels के स्कोप को ज़्यादा आसानी से मैनेज किया जा सकता है.

ViewModelProvider.get() तरीके से, किसी भी ViewModelStoreOwner के लिए स्कोप किए गए ViewModel का इंस्टेंस पाया जा सकता है. Kotlin का इस्तेमाल करने वाले लोगों के लिए, सबसे आम इस्तेमाल के मामलों के लिए अलग-अलग एक्सटेंशन फ़ंक्शन उपलब्ध हैं. Kotlin के सभी एक्सटेंशन फ़ंक्शन के लागू करने के तरीके, बैकग्राउंड में ViewModelProvider API का इस्तेमाल करते हैं.

सबसे नज़दीकी ViewModelStoreOwner के लिए स्कोप किए गए ViewModels

किसी ViewModel को किसी ऐक्टिविटी, फ़्रैगमेंट या नेविगेशन ग्राफ़ के डेस्टिनेशन के लिए स्कोप किया जा सकता है. ऐक्टिविटी, फ़्रैगमेंट, और नेविगेशन लाइब्रेरी से मिले viewModels() एक्सटेंशन फ़ंक्शन की मदद से, सबसे नज़दीकी ViewModelStoreOwner के लिए स्कोप किए गए ViewModel का इंस्टेंस पाया जा सकता है.

व्यू

import androidx.activity.viewModels

class MyActivity : AppCompatActivity() {
    // ViewModel API available in activity.activity-ktx
    // The ViewModel is scoped to `this` Activity
    val viewModel: MyViewModel by viewModels()
}

import androidx.fragment.app.viewModels

class MyFragment : Fragment() {
    // ViewModel API available in fragment.fragment-ktx
    // The ViewModel is scoped to `this` Fragment
    val viewModel: MyViewModel by viewModels()
}

व्यू

import androidx.lifecycle.ViewModelProvider;

public class MyActivity extends AppCompatActivity {
    // The ViewModel is scoped to `this` Activity
    MyViewModel viewModel = new ViewModelProvider(this).get(MyViewModel.class);
}

public class MyFragment extends Fragment {
    // The ViewModel is scoped to `this` Fragment
    MyViewModel viewModel = new ViewModelProvider(this).get(MyViewModel.class);
}

किसी भी ViewModelStoreOwner के लिए स्कोप किए गए ViewModels

व्यू सिस्टम में मौजूद ComponentActivity.viewModels() और Fragment.viewModels() फ़ंक्शन, एक वैकल्पिक ownerProducer पैरामीटर लेते हैं. इसका इस्तेमाल यह तय करने के लिए किया जा सकता है कि ViewModel का इंस्टेंस किस ViewModelStoreOwner के लिए स्कोप किया गया है. यहां दिए गए उदाहरण में, पैरंट फ़्रैगमेंट के लिए स्कोप किए गए ViewModel का इंस्टेंस पाने का तरीका बताया गया है:

व्यू

import androidx.fragment.app.viewModels

class MyFragment : Fragment() {

    // ViewModel API available in fragment.fragment-ktx
    // The ViewModel is scoped to the parent of `this` Fragment
    val viewModel: SharedViewModel by viewModels(
        ownerProducer = { requireParentFragment() }
    )
}

व्यू

import androidx.lifecycle.ViewModelProvider;

public class MyFragment extends Fragment {

    SharedViewModel viewModel;

    @Override
    public void onViewCreated(View view, Bundle savedInstanceState) {
        // The ViewModel is scoped to the parent of `this` Fragment
        viewModel = new ViewModelProvider(requireParentFragment())
            .get(SharedViewModel.class);
    }
}

किसी फ़्रैगमेंट से, ऐक्टिविटी के लिए स्कोप किया गया ViewModel पाना, इस्तेमाल का एक आम मामला है. ऐसा करने के लिए, आप activityViewModels() व्यू एक्सटेंशन फ़ंक्शन का इस्तेमाल कर सकते हैं. अगर Views और Kotlin का इस्तेमाल नहीं किया जा रहा है, तो ऊपर बताए गए एपीआई का इस्तेमाल किया जा सकता है. इसके लिए, सही ओनर पास करें.

व्यू

import androidx.fragment.app.activityViewModels

class MyFragment : Fragment() {

    // ViewModel API available in fragment.fragment-ktx
    // The ViewModel is scoped to the host Activity
    val viewModel: SharedViewModel by activityViewModels()
}

व्यू

import androidx.lifecycle.ViewModelProvider;

public class MyFragment extends Fragment {

    SharedViewModel viewModel;

    @Override
    public void onViewCreated(View view, Bundle savedInstanceState) {
        // The ViewModel is scoped to the host Activity
        viewModel = new ViewModelProvider(requireActivity())
            .get(SharedViewModel.class);
    }
}

नेविगेशन ग्राफ़ के लिए स्कोप किए गए ViewModels

नेविगेशन ग्राफ़ भी ViewModel स्टोर के ओनर होते हैं. अगर नेविगेशन फ़्रैगमेंट का इस्तेमाल किया जा रहा है, तो व्यू एक्सटेंशन फ़ंक्शन की मदद से, किसी नेविगेशन ग्राफ़ के लिए स्कोप किए गए ViewModel का इंस्टेंस पाया जा सकता है.navGraphViewModels(graphId)

व्यू

import androidx.navigation.navGraphViewModels

class MyFragment : Fragment() {

    // ViewModel API available in navigation.navigation-fragment
    // The ViewModel is scoped to the `nav_graph` Navigation graph
    val viewModel: SharedViewModel by navGraphViewModels(R.id.nav_graph)

    // Equivalent navGraphViewModels code using the viewModels API
    val viewModel: SharedViewModel by viewModels(
        { findNavController().getBackStackEntry(R.id.nav_graph) }
    )
}

व्यू

import androidx.lifecycle.ViewModelProvider;

public class MyFragment extends Fragment {

    SharedViewModel viewModel;

    @Override
    public void onViewCreated(View view, Bundle savedInstanceState) {
        NavController navController = NavHostFragment.findNavController(this);
        NavBackStackEntry backStackEntry = navController.getBackStackEntry(R.id.my_graph);

        // The ViewModel is scoped to the `nav_graph` Navigation graph
        viewModel = new ViewModelProvider(backStackEntry).get(SharedViewModel.class);
    }
}

अगर Jetpack Navigation के अलावा Hilt का इस्तेमाल किया जा रहा है, तो hiltNavGraphViewModels(graphId) एपीआई का इस्तेमाल इस तरह किया जा सकता है.

व्यू

import androidx.hilt.navigation.fragment.hiltNavGraphViewModels

class MyFragment : Fragment() {

    // ViewModel API available in hilt.hilt-navigation-fragment
    // The ViewModel is scoped to the `nav_graph` Navigation graph
    // and is provided using the Hilt-generated ViewModel factory
    val viewModel: SharedViewModel by hiltNavGraphViewModels(R.id.nav_graph)
}

व्यू

import androidx.hilt.navigation.HiltViewModelFactory;
import androidx.lifecycle.ViewModelProvider;

public class MyFragment extends Fragment {

    SharedViewModel viewModel;

    @Override
    public void onViewCreated(View view, Bundle savedInstanceState) {
        NavController navController = NavHostFragment.findNavController(this);
        NavBackStackEntry backStackEntry = navController.getBackStackEntry(R.id.my_graph);

        // The ViewModel is scoped to the `nav_graph` Navigation graph
        // and is provided using the Hilt-generated ViewModel factory
        viewModel = new ViewModelProvider(
            backStackEntry,
            HiltViewModelFactory.create(getContext(), backStackEntry)
        ).get(SharedViewModel.class);
    }
}