Android-ViewPager的使用
Android-ViewPager的使用
ViewPager是安卓App很常用的工具类,通常是用来设置界面导航,比如微信,QQ都是使用这种,还有就是新闻类App,很常见
比如:
这就是一个典型的例子。
复习一下这个知识点。
大致步骤和之前的ListView差不多。
1.构造适配器
2.数据源
3.加载适配器
activity_main.xml
ViewPager使用v4的兼容包
view1-view4.xml
自定义适配器
MyPagerAdapter.java
package com.xieth.as.againviewpagerdemo;
import android.support.v4.view.PagerAdapter;
import android.view.View;
import android.view.ViewGroup;
import java.util.List;
/**
* Created by YR on 2016/04/05.
*/
public class MyPagerAdapter extends PagerAdapter{
private List viewList = null;
public MyPagerAdapter(List viewList) {
this.viewList = viewList;
}
// 实例化一个页卡
@Override
public Object instantiateItem(ViewGroup container, int position) {
container.addView(viewList.get(position));
return viewList.get(position);
}
// 销毁一个页卡
@Override
public void destroyItem(ViewGroup container, int position, Object object) {
container.removeView(viewList.get(position));
}
@Override
public int getCount() {
return viewList.size();
}
@Override
public boolean isViewFromObject(View view, Object object) {
return view == object;
}
}
MainActivity.java
package com.xieth.as.againviewpagerdemo;
import android.os.Bundle;
import android.support.v4.view.ViewPager;
import android.support.v7.app.AppCompatActivity;
import android.view.View;
import java.util.ArrayList;
import java.util.List;
public class MainActivity extends AppCompatActivity {
private ViewPager pager = null;
private MyPagerAdapter adapter = null;
private View[] views = new View[4];
private int[] viewId = {R.layout.view1, R.layout.view2, R.layout.view3, R.layout.view4};
//数据源
private List viewList = null;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
initViews();
adapter = new MyPagerAdapter(viewList);
pager.setAdapter(adapter);
}
private void initViews() {
pager = (ViewPager) findViewById(R.id.id_viewpager);
viewList = new ArrayList<>();
for (int i = 0; i < viewId.length; i++) {
views[i] = View.inflate(this, viewId[i], null);
viewList.add(views[i]);
}
}
}
运行: MainActivity.java 运行: 可以把下面长的短线去掉: 运行: 除了这样加载,还可以使用Fragment作为载体。 自定义适配器
这是一个简单的例子,然后可以在上面添加标题栏。
使用android.support.v4.view.PagerTabStrip<喎?http://www.Bkjia.com/kf/ware/vc/" target="_blank" class="keylink">vc3Ryb25nPjxiciAvPg0KPHN0cm9uZz5hY3Rpdml0eV9tYWluLnhtbDwvc3Ryb25nPjwvcD4NCjxwcmUgY2xhc3M9"brush:java;">
package com.xieth.as.againviewpagerdemo;
import android.os.Bundle;
import android.support.v4.view.PagerTabStrip;
import android.support.v4.view.ViewPager;
import android.support.v7.app.AppCompatActivity;
import android.view.View;
import java.util.ArrayList;
import java.util.List;
public class MainActivity extends AppCompatActivity {
private ViewPager pager = null;
private MyPagerAdapter adapter = null;
private View[] views = new View[4];
private int[] viewId = {R.layout.view1, R.layout.view2, R.layout.view3, R.layout.view4};
private String[] titleStr = {"第一页", "第二页", "第三页", "第四页"};
//数据源
private List
tab.setDrawFullUnderline(false);
fragment1-fragment4.java
id改一下即可
package com.xieth.as.againviewpagerdemo;
import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
/**
* Created by YR on 2016/04/05.
*/
public class Fragment1 extends Fragment{
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
return inflater.inflate(R.layout.view1, container, false);
}
}
MyFragmentPagerAdapter.java
package com.xieth.as.againviewpagerdemo;
import android.support.v4.app.Fragment;
import android.support.v4.app.FragmentManager;
import android.support.v4.app.FragmentPagerAdapter;
import java.util.List;
/**
* Created by YR on 2016/04/05.
*/
public class MyFragmentPagerAdapter extends FragmentPagerAdapter{
//数据源
private List