响应刷新请求

本文档展示了当用户请求手动刷新时如何更新您的应用,无论他们是通过滑动手势触发刷新还是使用操作栏刷新操作。

响应刷新手势

当用户做出下拉刷新手势时,系统会显示进度指示器并调用您的应用的回调方法。您的回调方法负责更新应用的数据。

要响应您的应用中的刷新手势,请实现 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()。在您的覆盖方法中,通过使用值 true 调用 setRefreshing() 来触发 SwipeRefreshLayout 进度指示器,然后执行更新操作。在单独的方法中执行实际更新,以便无论用户使用滑动还是操作栏触发更新,都可以调用相同的方法。更新完成后,调用 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);
}