ViewPage流程:
/**
* ViewPage流程:
* 1.创建三个layout当做滑动的页面
* 2.使用 getLayoutInflater().from(this); 渲染布局 直接用返回值来渲染三个布局
* 3.创建一个类型为View的集合,然后把三个渲染过的布局add进去
* 4.创建适配器: 继承PagerAdapter, 创建一个View类型的集合,添加构造方法。
* 重写4个方法:
* 1.instantiateItem 添加要显示的视图,container.addView 返回当前集合长度
* 2.getCount 获取ViewPage中有多少个View
* 3.isViewFromObject 判断instantiateItem中返回来的key与一个页面视图是否是同一个视图
* 他俩是否对应,对应的表示用一个View,通常我们直接写return view == object
* 4.destroyItem 删除当前位置的页面,当前不用的页面 container.removeView 也没有返回值
* 5.设置适配器
*/
贴代码
public class MainActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
LayoutInflater from = getLayoutInflater().from(this);
View inflate1 = from.inflate(R.layout.layout1, null);
View inflate2 = from.inflate(R.layout.layout2, null);
View inflate3 = from.inflate(R.layout.layout3, null);
ArrayList<View> views = new ArrayList<>();
views.add(inflate1);
views.add(inflate2);
views.add(inflate3);
ViewPager viewPager = findViewById(R.id.vp_pager);
Adapter adapter = new Adapter(views);
viewPager.setAdapter(adapter);
}
}
package com.example.myviewpager;
import android.view.View;
import android.view.ViewGroup;
import androidx.annotation.NonNull;
import androidx.viewpager.widget.PagerAdapter;
import java.util.List;
public class Adapter extends PagerAdapter {
private List<View> list;
public Adapter(List<View> list) {
this.list = list;
}
@Override
public Object instantiateItem(ViewGroup container, int position) {
container.addView(list.get(position), null);
return list.get(position);
}
@Override
public int getCount() {
return list.size();
}
@Override
public boolean isViewFromObject(View view, Object object) {
return view == object;
}
@Override
public void destroyItem(ViewGroup container, int position, Object object) {
container.removeView(list.get(position));
}
}