最近,网易新闻更新到V3.5了,给我印象最深的是第一次进应用时显示新特性的ViewPager变成垂直滑动了。于是,小小的模仿了一下,我们来看看效果:


Android之仿网易V3.5新特性_java

   

Android之仿网易V3.5新特性_ide_02

Android之仿网易V3.5新特性_android_03

   

Android之仿网易V3.5新特性_ViewPager_04


其实这是一个很简单的代码,一个自定义的ViewPager就可以搞定,引用自JakeWharton的一个开源项目:点击打开链接

这个项目实际上是在ViewPager的基础上,做了一个扩展,加入了对上下方向滑动的支持,正如项目的名字,使用该项目,可以灵活的改变viewpager的方向,而且仅用一个简单的属性设置就可以做到,我只对该项目提供的例子做了一些简单的改动,就做到了网易新闻这个引导页的效果。

项目中最主要的部分:

DirectionalViewPager:直接继承自ViewPager,主要在onInterceptTouchEvent()和onTouchEvent()里面加入了对于垂直方向滑动的支持.并提供了setOrientation()这个方法,

我们可以同过此方法,直接设置ViewPager的滑动效果,垂直或者是水平

VerticalViewPagerCompat:提供了设置DataSetObserver的方法:setDataSetObserver()

接下来看具体使用的部分:MainActivity

[java]  view plain  copy

1. package com.way.newversion;  
2.   
3. import android.os.Bundle;  
4. import android.support.v4.app.FragmentActivity;  
5.   
6. import com.way.directionalviewpager.DirectionalViewPager;  
7.   
8. public class MainActivity extends FragmentActivity {  
9. private DirectionalViewPager mDirectionalViewPager;  
10.   
11. @Override  
12. protected void onCreate(Bundle savedInstanceState) {  
13. super.onCreate(savedInstanceState);  
14.         setContentView(R.layout.activity_main);  
15. // Set up the pager  
16.         mDirectionalViewPager = (DirectionalViewPager) findViewById(R.id.pager);  
17. new TestFragmentAdapter(  
18.                 getSupportFragmentManager()));  
19. //设置方向垂直即可。  
20.   
21.     }  
22.   
23. }


实际应用中,我们直接用DirectionalViewPager代替ViewPager,再设置其滑动方向即可,既可以水平,也可以垂直,一个setOritation直接搞定.

看到了吧,实现上下滑动的效果就这么简单.在此不得不致敬JakeWharton这位大牛在开源项目上的贡献,让我们这些开发者受益颇深..


例子中其他部分,我只替换了资源图片:

我们每个界面都是使用的Fragment,由于通用以及简洁性,我这里就只使用一个TestFragment:

[java]  view plain  copy

1. package com.way.newversion;  
2.   
3. import android.os.Bundle;  
4. import android.support.v4.app.Fragment;  
5. import android.view.LayoutInflater;  
6. import android.view.View;  
7. import android.view.ViewGroup;  
8. import android.widget.Button;  
9. import android.widget.ImageView;  
10.   
11. public class TestFragment extends Fragment {  
12. private static final String KEY_CONTENT = "TestFragment:Content";  
13. private static final String KEY_ISLASTPIC = "TestFragment:IsLastPic";  
14. private int mContent;  
15. private boolean mIsLastPic;  
16.   
17. public static TestFragment newInstance(int content, boolean isLastPic) {  
18. new TestFragment();  
19.   
20.         fragment.mContent = content;  
21.         fragment.mIsLastPic = isLastPic;  
22. return fragment;  
23.     }  
24.   
25. @Override  
26. public View onCreateView(LayoutInflater inflater, ViewGroup container,  
27.             Bundle savedInstanceState) {  
28. if ((savedInstanceState != null)  
29.                 && savedInstanceState.containsKey(KEY_CONTENT)) {  
30.             mContent = savedInstanceState.getInt(KEY_CONTENT);  
31.             mIsLastPic = savedInstanceState.getBoolean(KEY_ISLASTPIC);  
32.         }  
33.         View root = inflater  
34. false);  
35.         ImageView iv = (ImageView) root.findViewById(R.id.iv);  
36.         iv.setImageResource(mContent);  
37.         Button btn = (Button) root.findViewById(R.id.btn);  
38. if (mIsLastPic)  
39.             btn.setVisibility(View.VISIBLE);  
40. else  
41.             btn.setVisibility(View.GONE);  
42. return root;  
43.     }  
44.   
45. @Override  
46. public void onSaveInstanceState(Bundle outState) {  
47. super.onSaveInstanceState(outState);  
48.         outState.putInt(KEY_CONTENT, mContent);  
49.         outState.putBoolean(KEY_ISLASTPIC, mIsLastPic);  
50.     }  
51. }

接下来是所有fragment的Adapter:

[java]  view plain  copy

    1. package com.way.newversion;  
    2.   
    3. import android.support.v4.app.Fragment;  
    4. import android.support.v4.app.FragmentManager;  
    5. import android.support.v4.app.FragmentPagerAdapter;  
    6.   
    7. class TestFragmentAdapter extends FragmentPagerAdapter {  
    8. protected static final int[] CONTENT = new int[] {  
    9.             R.drawable.biz_ad_new_version1_img0,  
    10.             R.drawable.biz_ad_new_version1_img1,  
    11.             R.drawable.biz_ad_new_version1_img2,  
    12.             R.drawable.biz_ad_new_version1_img3 };  
    13.   
    14. public TestFragmentAdapter(FragmentManager fm) {  
    15. super(fm);  
    16.     }  
    17.   
    18. @Override  
    19. public Fragment getItem(int position) {  
    20. boolean isLastPic = false;  
    21. if (position == CONTENT.length - 1)  
    22. true;  
    23. return TestFragment.newInstance(CONTENT[position], isLastPic);  
    24.     }  
    25.   
    26. @Override  
    27. public int getCount() {  
    28. return CONTENT.length;  
    29.     }  
    30. }

    好了,大概就是这样,有需要的朋友可以下载代码看看,很简单的,最后注意一下,我这里并未实现背景跟随滑动,加上之后会更加栩栩如生,这个就留给大家了。