रीफ़्रेश करने के अनुरोध का जवाब देना

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

रीफ़्रेश करने के जेस्चर का जवाब दें

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

अपने ऐप्लिकेशन में रीफ़्रेश जेस्चर की प्रतिक्रिया देने के लिए, SwipeRefreshLayout.OnRefreshListener अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है और इसके onRefresh() तरीका. जब उपयोगकर्ता कुछ करता है, तो onRefresh() तरीका शुरू होता है स्वाइप करें.

असल में अपडेट करने की कार्रवाई के लिए, कोड को किसी अलग तरीके में रखें ViewModel में जाकर, अपडेट करने के उस तरीके को अपने onRefresh() लागू करना. इस तरह, उसी अपडेट का इस्तेमाल उपयोगकर्ता की ओर से कार्रवाई से रीफ़्रेश ट्रिगर किए जाने पर अपडेट करने का तरीका बार.

अपने अपडेट के तरीके में, setRefreshing(false) अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है जब यह डेटा अपडेट कर लेता है. इस तरीके को कॉल करने से SwipeRefreshLayout अभी तक किसी भी व्यक्ति ने चेक इन नहीं किया है प्रोग्रेस इंडिकेटर को हटाएं और व्यू का कॉन्टेंट अपडेट करें.

उदाहरण के लिए, नीचे दिया गया कोड, onRefresh() को लागू करता है और दिखाए गए डेटा को अपडेट करने के लिए, myUpdateOperation() तरीके को शुरू करता है से ListView:

Kotlin

// Sets up a SwipeRefreshLayout.OnRefreshListener that invokes when
// the user performs a swipe-to-refresh gesture.

mySwipeRefreshLayout.setOnRefreshListener {
    Log.i(LOG_TAG, "onRefresh called from SwipeRefreshLayout")

    // This method performs the actual data-refresh operation and calls
    // setRefreshing(false) when it finishes.
    myUpdateOperation()
}

Java

// Sets up a SwipeRefreshLayout.OnRefreshListener that is invoked when
// the user performs a swipe-to-refresh gesture.

mySwipeRefreshLayout.setOnRefreshListener(() -> {
    Log.i(LOG_TAG, "onRefresh called from SwipeRefreshLayout");

    // This method performs the actual data-refresh operation and calls
    // setRefreshing(false) when it finishes.
    myUpdateOperation();
  }
);

रीफ़्रेश करें पर कार्रवाई करें

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

रीफ़्रेश करने के लिए की गई सेटिंग बदलें onOptionsItemSelected(). अपनी ओवरराइड विधि में, कॉल करने पर, प्रोग्रेस दिखाने वाला SwipeRefreshLayout इंडिकेटर true वैल्यू के साथ setRefreshing() लगाएं. इसके बाद, यह परफ़ॉर्म करें अपडेट ऑपरेशन. असल अपडेट को किसी अलग तरीके से करें, ताकि विधि को कॉल किया जा सकता है कि क्या उपयोगकर्ता अपडेट को स्वाइप करके ट्रिगर करता है या कार्रवाई बार पर क्लिक करें. अपडेट पूरा होने पर, setRefreshing(false) पर कॉल करें रीफ़्रेश की स्थिति दिखाने वाले इंडिकेटर को हटाने के लिए.

नीचे दिए गए कोड में, अनुरोध पर कार्रवाई करने का तरीका बताया गया है:

Kotlin

// Listen for option item selections to receive a notification when the user
// requests a refresh by selecting the refresh action bar item.

override fun onOptionsItemSelected(item: MenuItem): Boolean {
    when (item.itemId) {

        // Check whether the user triggers a refresh:
        R.id.menu_refresh -> {
            Log.i(LOG_TAG, "Refresh menu item selected")

            // Signal SwipeRefreshLayout to start the progress indicator.
            mySwipeRefreshLayout.isRefreshing = true

            // Start the refresh background task. This method calls
            // setRefreshing(false) when it finishes.
            myUpdateOperation()

            return true
        }
    }

    // User doesn't trigger a refresh. Let the superclass handle this action.
    return super.onOptionsItemSelected(item)
}

Java

// Listen for option item selections to receive a notification when the user
// requests a refresh by selecting the refresh action bar item.

@Override
public boolean onOptionsItemSelected(MenuItem item) {
    switch (item.getItemId()) {

        // Check whether the user triggers a refresh:
        case R.id.menu_refresh:
            Log.i(LOG_TAG, "Refresh menu item selected");

            // Signal SwipeRefreshLayout to start the progress indicator.
            mySwipeRefreshLayout.setRefreshing(true);

            // Start the refresh background task. This method calls
            // setRefreshing(false) when it finishes.
            myUpdateOperation();

            return true;
    }

    // User doesn't trigger a refresh. Let the superclass handle this action.
    return super.onOptionsItemSelected(item);
}