今天在Google+上看到了SwipeRefreshLayout這個名詞,遂搜索了下,發現竟然是剛剛google更新sdk新增加的一個widget,於是趕緊搶先體驗學習下。
SwipeRefreshLayout
SwipeRefreshLayout字面意思就是下拉刷新的佈局,繼承自ViewGroup,在support v4兼容包下,但必須把你的support library的版本升級到19.1。 提到下拉刷新大家一定對ActionBarPullToRefresh比較熟悉,而如今google推出了更官方的下拉刷新組件,這無疑是對開發者來說比較好的消息。利用這個組件可以很方便的實現Google Now的刷新效果,見下圖:
主要方法
-
setOnRefreshListener(OnRefreshListener): 爲佈局添加一個Listener
-
setRefreshing(boolean): 顯示或隱藏刷新進度條
-
isRefreshing(): 檢查是否處於刷新狀態
-
setColorScheme(): 設置進度條的顏色主題,最多能設置四種
xml佈局文件
佈局文件很簡單,只需要在最外層加上SwipeRefreshLayout,然後他的child是可滾動的view即可,如ScrollView或者ListView。如:
<android.support.v4.widget.SwipeRefreshLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/swipe_container"
android:layout_width="match_parent"
android:layout_height="match_parent">
<ScrollView
android:layout_width="match_parent"
android:layout_height="match_parent">
<TextView
android:text="@string/hello_world"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginTop="16dp"
android:gravity="center"/>
</ScrollView>
</android.support.v4.widget.SwipeRefreshLayout>
Activity代碼
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
swipeLayout = (SwipeRefreshLayout) findViewById(R.id.swipe_container);
swipeLayout.setOnRefreshListener(this);
swipeLayout.setColorScheme(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 onRefresh() {
new Handler().postDelayed(new Runnable() {
@Override public void run() {
swipeLayout.setRefreshing(false);
}
}, 5000);
}
上面的代碼很簡單,只需要給SwipeRefreshLayout添加一個listener,值得說明的是setColorScheme方法是設置刷新進度條的顏色,最多隻能設置4種循環顯示,默認第一個是隨用戶手勢加載的顏色進度條。
源碼
寫了的小demo在github上,地址在:SwipeRefreshLayoutDemo
總結
google在不斷完善自己的sdk,推出越來越多的組件,其目的是讓開發更簡單,設計上更統一,這可能是google未來的方向,不管怎樣,這對開發者來說無疑是非常好的消息。