使用SwipeRefreshLayout,實現下拉刷新
編輯你的 app / build.gradle 文件包括一個支持庫比版本19新:
SwipeRefreshLayout 是一個ViewGroup只能持有一個可滾動視圖。 這可以是一個 滾動視圖 或者一個 AdapterView 如 列表視圖 或者一個 RecyclerView 。
</div>
SwipeRefreshLayout 是一個ViewGroup只能持有一個可滾動視圖。 這可以是一個 滾動視圖 或者一個 AdapterView 如 列表視圖 或者一個 RecyclerView 。
ListView SwipeRefreshLayout 步驟1:包裝列表視圖
<android.support.v4.widget.SwipeRefreshLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/swipeContainer"
android:layout_width="match_parent"
android:layout_height="match_parent">
<ListView
android:id="@+id/lvItems"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_alignParentLeft="true"
android:layout_alignParentTop="true" >
</ListView>
</android.support.v4.widget.SwipeRefreshLayout>
第二步:設置SwipeRefreshLayout
public class TimelineActivity extends Activity {
private SwipeRefreshLayout swipeContainer;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
swipeContainer = (SwipeRefreshLayout) findViewById(R.id.swipeContainer);
// Setup refresh listener which triggers new data loading
swipeContainer.setOnRefreshListener(new OnRefreshListener() {
@Override
public void onRefresh() {
// Your code to refresh the list here.
// Make sure you call swipeContainer.setRefreshing(false)
// once the network request has completed successfully.
fetchTimelineAsync(0);
}
});
// Configure the refreshing colors
swipeContainer.setColorSchemeResources(android.R.color.holo_blue_bright,
android.R.color.holo_green_light,
android.R.color.holo_orange_light,
android.R.color.holo_red_light);
}
public void fetchTimelineAsync(int page) {
client.getHomeTimeline(0, new JsonHttpResponseHandler() {
public void onSuccess(JSONArray json) {
// Remember to CLEAR OUT old items before appending in the new ones
adapter.clear();
// ...the data has come back, add new items to your adapter...
adapter.addAll(...);
// Now we call setRefreshing(false) to signal refresh has finished
swipeContainer.setRefreshing(false);
}
public void onFailure(Throwable e) {
Log.d("DEBUG", "Fetch timeline error: " + e.toString());
}
});
}
}
/*請注意 ,重新加載成功后,我們還必須刷新完成后通過調用的信號 setRefreshing(假) 。 還要注意,你應該 清除舊的物品 在刷新之前添加新的。*/
[代碼]SwipeRefreshLayout RecyclerView 步驟1:包裝RecyclerView
<android.support.v4.widget.SwipeRefreshLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/swipeContainer"
android:layout_width="match_parent"
android:layout_height="match_parent">
<android.support.v7.widget.RecyclerView
android:id="@+id/rvItems"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_alignParentLeft="true"
android:layout_alignParentTop="true" />
</android.support.v4.widget.SwipeRefreshLayout>
[代碼]步驟2:更新RecyclerView.Adapter
/* Within the RecyclerView.Adapter class */
// Clean all elements of the recycler
public void clear() {
items.clear();
notifyDataSetChanged();
}
// Add a list of items
public void addAll(List<list> list) {
items.addAll(list);
notifyDataSetChanged();
}
[代碼]步驟3:設置SwipeRefreshLayout
/*接下來,我們需要配置 SwipeRefreshLayout 在視圖初始化的活動。 實例化的活動 SwipeRefreshLayout 應該添加一個 OnRefreshListener 通知只要刷新動作完成。 SwipeRefreshLayout 將通知偵聽器再次完成每一次的姿態,監聽器負責正確確定何時來發起一個刷新的內容。*/
本文由用戶 RegPoate 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!