使用PagerSlidingTabStrip ViewPager SwipeRefreshLayout打造豆瓣App的效果
来源:互联网 发布:程序员课程 编辑:程序博客网 时间:2024/06/09 09:32
打造效果
先简单介绍下三个所使用的开源库。
ViewPager
ViewPager是v4包里提供的,可以通过PagerAdapter根据左右的滑动产生不同的page。
PagerAdapter分为FragmentPagerAdapter, FragmentStatePagerAdapter。
唯一的区别是在对不再需要的fragment时所采用的处理方法不同。
前者选择detach,后者选择remove并保存状态。
ViewPager的使用方法类似ListView, 都是使用Adapter来提供内容。而ListView中getItem返回的是View, 而ViewPager返回的是Fragment。
使用方法
ViewPager pager = (ViewPager)findViewById(R.id.pager);pager.setAdapter(new PagerAdapter(getSupportFragmentManager()));// 继承PagerAdapter 必须实现的方法有getCount, 返回列表的总数。 getItem,即根据position返回对应的fragment。class PagerAdapter extends FragmentPagerAdapter { public Fragment getItem(int position) { return new Fragment(); } public int getCount(){ return NUM_OF_PAGES; }}
PagerSlidingTabStrip
github地址
作用是根据ViewPager生成对应的tab 在页面切换时有相应的动画效果
其中TestAdapter是FragmentPagerAdapter或FragmentStatePagerAdapter的子类。
使用方法
// Initialize the ViewPager and set an adapter ViewPager pager = (ViewPager) findViewById(R.id.pager); pager.setAdapter(new TestAdapter(getSupportFragmentManager())); // Bind the tabs to the ViewPager PagerSlidingTabStrip tabs = (PagerSlidingTabStrip) findViewById(R.id.tabs); tabs.setViewPager(pager);
SwipeRefreshLayout
SwipeRefreshLayout同样是v4包里的,它提供了下拉刷新的功能以及对应的动画效果,使用起来非常简便。但是其中只能包含一个View,且该View必须是可滑动的(不可滑动的话动画显示有bug),如ListView。
使用方法
在xml文件中添加android.support.v4.widget.SwipeRefreshLayout
<android.support.v4.widget.SwipeRefreshLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:id="@+id/refresh_layout" android:layout_width="match_parent" android:layout_height="match_parent"> <ListView android:id="@+id/lv" android:layout_width="match_parent" android:layout_height="match_parent" /></android.support.v4.widget.SwipeRefreshLayout>
下拉时若要触发事件, 需实现SwipeRefreshLayout.OnRefreshListener,重写onRefresh方法。
打造豆瓣App效果
整个项目UI有三个文件,为MainActivity, ListRefreshFragment, PagerFragment。
PagerFragment
PagerFragment为其中最简单的,仅含有一个TextView。
在最初创建的时候,会从getArguments()取出参数填充TextView。
arguments会在configuration changes后被自动保存,可参考该问题。
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { View pager = inflater.inflate(R.layout.pager_fragment, container, false); tv = (TextView) pager.findViewById(R.id.tv); Bundle bundle = getArguments(); pageNum = bundle.getInt("page_num"); tv.setText("" + pageNum); return pager; }
ListRefreshFragment
ListRefreshFragment布局文件
<android.support.v4.widget.SwipeRefreshLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:id="@+id/refresh_layout" android:layout_width="match_parent" android:layout_height="match_parent" tools:context="com.kay.douban.ListRefreshFragment"> <ListView android:id="@+id/lv" android:layout_width="match_parent" android:layout_height="match_parent" /></android.support.v4.widget.SwipeRefreshLayout>
对SwipeRefreshLayout进行配置
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { mRefreshLayout = (SwipeRefreshLayout) view.findViewById(R.id.refresh_layout); // fragment implements SwipeRefreshLayout.OnRefreshListener mRefreshLayout.setOnRefreshListener(this); // 设置动画颜色 mRefreshLayout.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);}// 下拉时显示动画3秒// 一般在onRefresh()里面执行更新操作public void onRefresh() { mRefreshLayout.setRefreshing(true); new Handler().postDelayed(new Runnable() { public void run() { // 通过setRefreshing(false)使动画停止 mRefreshLayout.setRefreshing(false); } }, 3000);}
MainActivity
布局文件
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical" tools:context=".MainActivity"> // 配置tab的颜色 字体大小等样式 <com.astuetz.PagerSlidingTabStrip android:id="@+id/pager_tabs" android:layout_width="match_parent" android:layout_height="48dp" android:textColor="#ff8f8f8f" android:textSize = "18sp" android:background="#ff2d2d2d" app:pstsShouldExpand="true" app:pstsIndicatorHeight="4dp" app:pstsIndicatorColor="#ff00cd79"/> <android.support.v4.view.ViewPager android:id="@+id/pager" android:layout_width="match_parent" android:layout_height="match_parent" /></LinearLayout>
在Activity中主要是配置PagerSlidingTabStrip以及FragmentPagerAdapter。
protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); requestWindowFeature(Window.FEATURE_NO_TITLE); setContentView(R.layout.activity_main); pagerTab = (PagerSlidingTabStrip) findViewById(R.id.pager_tabs); pager = (ViewPager) findViewById(R.id.pager); pager.setOffscreenPageLimit(3); pager.setAdapter(new PagerAdapter(getSupportFragmentManager())); pagerTab.setViewPager(pager);} private class PagerAdapter extends FragmentPagerAdapter { private final String[] TITLES = getResources().getStringArray(R.array.pager_name); private PagerAdapter(FragmentManager fm) { super(fm); } // 使tab可以显示对应fragment的title @Override public CharSequence getPageTitle(int position) { return TITLES[position]; } // 返回对应position的fragment 设置pagerFragment的arguments使得该fragment可以在TextView中显示 @Override public Fragment getItem(int position) { Bundle bundle = new Bundle(); Fragment pagerFragment; if (position == 0) { pagerFragment = new ListRefreshFragment(); } else { pagerFragment = new PagerFragment(); } bundle.putInt("page_num", position); pagerFragment.setArguments(bundle); return pagerFragment; } @Override public int getCount() { return NUM_PAGES; } }
github地址
关于各种开源库的导入,使用gradle。可参考build.gradle里的dependencies。
- 使用PagerSlidingTabStrip ViewPager SwipeRefreshLayout打造豆瓣App的效果
- PagerSlidingTabStrip+viewpager的使用
- 使用PagerSlidingTabStrip实现滑动标签同步的ViewPager效果
- 【Android界面实现】使用PagerSlidingTabStrip实现滑动标签同步的ViewPager效果
- PagerSlidingTabStrip加ViewPager的使用,PagerSlidingTabStrip增加单条目的点击事件
- 开源PagerSlidingTabStrip的使用Tab与ViewPager的完美结合
- Viewpager和PagerSlidingTabStrip的日常玩弄(使用)
- PagerSlidingTabStrip的各种属性的详解,打造炫酷的viewPager
- 标签—PagerSlidingTabStrip和ViewPager联动效果
- PagerSlidingTabStrip+ViewPager
- PagerSlidingTabStrip + ViewPager
- PagerSlidingTabStrip 的使用介绍
- PagerSlidingTabStrip的使用
- 使用RadioGroup和ViewPager打造主页界面效果
- PagerSlidingTabStrip,酷炫的ViewPager的滑动导航,使用及解析
- 使用MagicIndicator打造千变万化的ViewPager指示器
- Android 自定义 ViewPager 打造千变万化的图片切换效果
- Android 自定义 ViewPager 打造千变万化的图片切换效果
- 模拟火车票售票
- 【Android0001】Class Diagram of Android UI
- Lua调用自定义C++类 以及打包到Android
- Fibonacci序列
- typedef 和 #define
- 使用PagerSlidingTabStrip ViewPager SwipeRefreshLayout打造豆瓣App的效果
- 括号匹配
- Quality Control vs Verify Scope
- 两数之和等于x
- 舞者配对
- java关闭线程
- jQuery-ajax-.load方法
- 二叉树的前序中序后序遍历
- POJ 1274 The Perfect Stall