实际应用中,我们直接用DirectionalViewPager代替ViewPager,再设置其滑动方向即可,既可以水平,也可以垂直,一个setOritation直接搞定.
看到了吧,实现上下滑动的效果就这么简单.在此不得不致敬JakeWharton这位大牛在开源项目上的贡献,让我们这些开发者受益颇深..
例子中其他部分,我只替换了资源图片:
TestFragment:
- package com.way.verticalguider;
- import com.way.newversion.R;
- import android.os.Bundle;
- import android.support.v4.app.Fragment;
- import android.view.LayoutInflater;
- import android.view.View; // http://www.openeim.com/
- import android.view.ViewGroup;
- import android.widget.Button;
- import android.widget.ImageView;
- public class TestFragment extends Fragment {
- private static final String KEY_CONTENT = "TestFragment:Content";
- private static final String KEY_ISLASTPIC = "TestFragment:IsLastPic";
- private int mContent;
- private boolean mIsLastPic;
- public static TestFragment newInstance(int content, boolean isLastPic) {
- TestFragment fragment = new TestFragment();
- fragment.mContent = content;
- fragment.mIsLastPic = isLastPic;
- return fragment;
- }
- @Override
- public View onCreateView(LayoutInflater inflater, ViewGroup container,
- Bundle savedInstanceState) {
- if ((savedInstanceState != null)
- && savedInstanceState.containsKey(KEY_CONTENT)) {
- mContent = savedInstanceState.getInt(KEY_CONTENT);
- mIsLastPic = savedInstanceState.getBoolean(KEY_ISLASTPIC);
- }
- View root = inflater
- .inflate(R.layout.fragment_layout, container, false);
- ImageView iv = (ImageView) root.findViewById(R.id.iv);
- iv.setImageResource(mContent);
- Button btn = (Button) root.findViewById(R.id.btn);
- if (mIsLastPic)
- btn.setVisibility(View.VISIBLE);
- else
- btn.setVisibility(View.GONE);
- return root;
- }
- @Override
- public void onSaveInstanceState(Bundle outState) {
- super.onSaveInstanceState(outState);
- outState.putInt(KEY_CONTENT, mContent);
- outState.putBoolean(KEY_ISLASTPIC, mIsLastPic);
- }
- }
package com.way.verticalguider;
import com.way.newversion.R;
import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.Button;
import android.widget.ImageView;
public class TestFragment extends Fragment {
private static final String KEY_CONTENT = "TestFragment:Content";
private static final String KEY_ISLASTPIC = "TestFragment:IsLastPic";
private int mContent;
private boolean mIsLastPic;
public static TestFragment newInstance(int content, boolean isLastPic) {
TestFragment fragment = new TestFragment();
fragment.mContent = content;
fragment.mIsLastPic = isLastPic;
return fragment;
}
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
if ((savedInstanceState != null)
&& savedInstanceState.containsKey(KEY_CONTENT)) {
mContent = savedInstanceState.getInt(KEY_CONTENT);
mIsLastPic = savedInstanceState.getBoolean(KEY_ISLASTPIC);
}
View root = inflater
.inflate(R.layout.fragment_layout, container, false);
ImageView iv = (ImageView) root.findViewById(R.id.iv);
iv.setImageResource(mContent);
Button btn = (Button) root.findViewById(R.id.btn);
if (mIsLastPic)
btn.setVisibility(View.VISIBLE);
else
btn.setVisibility(View.GONE);
return root;
}
@Override
public void onSaveInstanceState(Bundle outState) {
super.onSaveInstanceState(outState);
outState.putInt(KEY_CONTENT, mContent);
outState.putBoolean(KEY_ISLASTPIC, mIsLastPic);
}
}
TestFragmentAdapter:
- package com.way.verticalguider;
- import com.way.newversion.R;
- import android.support.v4.app.Fragment;
- import android.support.v4.app.FragmentManager;
- import android.support.v4.app.FragmentPagerAdapter;
- class TestFragmentAdapter extends FragmentPagerAdapter {
- protected static final int[] CONTENT = new int[] {
- R.drawable.biz_ad_new_version1_img0,
- R.drawable.biz_ad_new_version1_img1,
- R.drawable.biz_ad_new_version1_img2,
- R.drawable.biz_ad_new_version1_img3 };
- public TestFragmentAdapter(FragmentManager fm) {
- super(fm);
- }
- @Override
- public Fragment getItem(int position) {
- boolean isLastPic = false;
- if (position == CONTENT.length - 1)
- isLastPic = true;
- return TestFragment.newInstance(CONTENT[position], isLastPic);
- }
- @Override
- public int getCount() {
- return CONTENT.length;
- }
- }
package com.way.verticalguider;
import com.way.newversion.R;
import android.support.v4.app.Fragment;
import android.support.v4.app.FragmentManager;
import android.support.v4.app.FragmentPagerAdapter;
class TestFragmentAdapter extends FragmentPagerAdapter {
protected static final int[] CONTENT = new int[] {
R.drawable.biz_ad_new_version1_img0,
R.drawable.biz_ad_new_version1_img1,
R.drawable.biz_ad_new_version1_img2,
R.drawable.biz_ad_new_version1_img3 };
public TestFragmentAdapter(FragmentManager fm) {
super(fm);
}
@Override
public Fragment getItem(int position) {
boolean isLastPic = false;
if (position == CONTENT.length - 1)
isLastPic = true;
return TestFragment.newInstance(CONTENT[position], isLastPic);
}
@Override
public int getCount() {
return CONTENT.length;
}
}
下面是我修改后例子的下载链接:
其实无论像这种上下滑动引导页的效果,可以有多种方式去实现,在此仅提供不敢说是最优化,但一定是 最便捷的一种方法.
有时间的话我会再研究下聚合阅读的那个动画效果,在此先记录下, 大家如有好的意见,欢迎讨论.