ViewPager刷新解析

  原本以为PagerAdapter类似于BaseAdapter 但是使用起来发现刷新还是有区别的 解析如下

先上Demo

PagerAdapter的四大函数

  getCount 返回要滑动的View的个数

  isViewFromObject 从当前container中删除指定位置(position)的View

  instantiateItem 将当前视图添加到container中 返回当前View

  destroyItem

第一个问题 但数据源发生变化时 调用viewPagerAdapter.notifyDataSetChanged() 发现无法刷新数据

解决办法 PagerAdapter中重写getItemPosition方法

上代码

public class MainActivity extends Activity {

  private ViewPager view_pager; //预览照片的分页显示
private ViewPagerAdapter viewPagerAdapter; //分页图片的预览器 private ArrayList<String> fileNames = new ArrayList<String>(); //本地图片路径
private int currentPosition; //当前选择的图片 @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main); initData();
initView();
} // 获取本地所有照片路径
private void initData() { fileNames.clear();
Cursor cursor = getContentResolver().query(Media.EXTERNAL_CONTENT_URI, null, null, null, null);
while (cursor.moveToNext()) {
byte[] data = cursor.getBlob(cursor.getColumnIndex(Media.DATA)); //图片的保存位置的数据
fileNames.add(new String(data, 0, data.length - 1));
} } //初始化控件
private void initView() {
view_pager = (ViewPager) findViewById(R.id.view_pager);
viewPagerAdapter = new ViewPagerAdapter(this, fileNames);
view_pager.setAdapter(viewPagerAdapter); view_pager.setOnPageChangeListener(new ViewPager.OnPageChangeListener() { @Override
public void onPageSelected(int i) {
currentPosition = i; Log.i("mbk", "翻页后的当前页面" + currentPosition);
} @Override
public void onPageScrolled(int i, float f, int j) {
} @Override
public void onPageScrollStateChanged(int i) {
}
}); Button delete = (Button)findViewById(R.id.delete);
delete.setOnClickListener(new View.OnClickListener() { @Override
public void onClick(View v) {
if (fileNames.size() > 0) {
fileNames.remove(currentPosition);
}
Log.i("mbk", "删除的当前页面" + currentPosition);
viewPagerAdapter.notifyDataSetChanged();
}
}); } }
public class ViewPagerAdapter extends PagerAdapter{

  private Context context;
private ArrayList<String> fileNames = new ArrayList<String>(); //本地图片路径 public ViewPagerAdapter(Context context, ArrayList<String> fileNames) {
super();
this.context = context;
this.fileNames = fileNames;
} @Override
public int getCount() {
return fileNames.size();
} @Override
public boolean isViewFromObject(View view, Object object) {
return view == object;
} @Override
public View instantiateItem(ViewGroup container, int position) {
ImageView imageView = new ImageView(context);
Glide.with(context).load(fileNames.get(position)).centerCrop().into(imageView); container.addView(imageView, LayoutParams.MATCH_PARENT, LayoutParams.MATCH_PARENT);
return imageView;
} @Override
public void destroyItem(ViewGroup container, int position, Object object) {
container.removeView((View) object);
} //解决数据不刷新的问题
@Override
public int getItemPosition(Object object) {
return POSITION_NONE;
}
}

Demo见 https://github.com/huanyi0723/TestViewPager1

第二个问题 解决刷新单个页面的方法 对于控件采取setTag和findViewWithTag寻找到 再更新 同时注意position和currentPosition

上代码

public class MainActivity extends Activity {

  private ViewPager view_pager; //预览照片的分页显示
private ViewPagerAdapter viewPagerAdapter; //分页图片的预览器 private ArrayList<String> fileNames = new ArrayList<String>(); //本地图片路径
private int currentPosition = 0; //当前选择的图片 private Timer timer = new Timer(); // 定时器
private TimerTask timerTask;
private int progress = 0; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main); initData();
initView();
} // 获取本地所有照片路径
private void initData() { fileNames.clear();
Cursor cursor = getContentResolver().query(Media.EXTERNAL_CONTENT_URI, null, null, null, null);
while (cursor.moveToNext()) {
byte[] data = cursor.getBlob(cursor.getColumnIndex(Media.DATA)); //图片的保存位置的数据
fileNames.add(new String(data, 0, data.length - 1));
} } //初始化控件
private void initView() {
view_pager = (ViewPager) findViewById(R.id.view_pager);
viewPagerAdapter = new ViewPagerAdapter(this, fileNames, view_pager, currentPosition);
view_pager.setAdapter(viewPagerAdapter); view_pager.setOnPageChangeListener(new ViewPager.OnPageChangeListener() { @Override
public void onPageSelected(int i) {
currentPosition = i; Log.i("mbk", "翻页后的当前页面" + currentPosition);
} @Override
public void onPageScrolled(int i, float f, int j) {
} @Override
public void onPageScrollStateChanged(int i) {
}
}); Button delete = (Button)findViewById(R.id.delete);
delete.setOnClickListener(new View.OnClickListener() { @Override
public void onClick(View v) {
if (fileNames.size() > 0) {
fileNames.remove(currentPosition);
}
Log.i("mbk", "删除的当前页面" + currentPosition);
viewPagerAdapter.notifyDataSetChanged();
}
}); Button update = (Button)findViewById(R.id.update);
update.setOnClickListener(new View.OnClickListener() { @Override
public void onClick(View v) {
initTimeTask();
}
}); } // 定时器轮询
private void initTimeTask() { timerTask = new TimerTask() {
@Override
public void run() {
viewPagerAdapter.setProgress( progress , currentPosition); Log.i("mbk", "---------------MainActivity -----------progress--------------" + progress);
progress++;
}
}; timer.schedule(timerTask, 0, 1000); } }
public class ViewPagerAdapter extends PagerAdapter {

  private Context context;
private ArrayList<String> fileNames = new ArrayList<String>(); // 本地图片路径 private SeekBar seekBar;
private ViewPager view_pager; public ViewPagerAdapter(Context context, ArrayList<String> fileNames, ViewPager view_pager ) {
super();
this.context = context;
this.fileNames = fileNames;
this.view_pager = view_pager;
} @Override
public int getCount() {
return fileNames.size();
} @Override
public boolean isViewFromObject(View view, Object object) {
return view == object;
} @Override
public View instantiateItem(ViewGroup container, int position) { View view = LayoutInflater.from(context).inflate(R.layout.pager_adapter_item, null);
ImageView imageView = (ImageView) view.findViewById(R.id.imageView);
seekBar = (SeekBar) view.findViewById(R.id.seekBar);
seekBar.setMax(100); seekBar.setTag("seekBar" + position); Log.i("mbk", "---------------ViewPagerAdapter -----------setTag--------------" + position); Glide.with(context).load(fileNames.get(position)).centerCrop().into(imageView); container.addView(view, LayoutParams.MATCH_PARENT, LayoutParams.MATCH_PARENT);
return view; } @Override
public void destroyItem(ViewGroup container, int position, Object object) {
container.removeView((View) object);
} // 解决数据不刷新的问题
@Override
public int getItemPosition(Object object) {
return POSITION_NONE;
} public void setProgress(int progress, int currentPosition) {
seekBar = (SeekBar) view_pager.findViewWithTag("seekBar"+currentPosition);
seekBar.setProgress(progress); Log.i("mbk", "---------------ViewPagerAdapter -----------progress--------------" + progress);
}
}

Demo见 https://github.com/huanyi0723/TestViewPager2

Android ViewPager刷新解析的更多相关文章

  1. Android DiskLruCache 源代码解析 硬盘缓存的绝佳方案

    转载请标明出处: http://blog.csdn.net/lmj623565791/article/details/47251585: 本文出自:[张鸿洋的博客] 一.概述 依然是整理东西.所以最近 ...

  2. Android Service完全解析,关于服务你所需知道的一切(下)

    转载请注册出处:http://blog.csdn.net/guolin_blog/article/details/9797169 在上一篇文章中,我们学习了Android Service相关的许多重要 ...

  3. Android Service完全解析,关于服务你所需知道的一切(上)

    转载请注明出处:http://blog.csdn.net/guolin_blog/article/details/11952435 相信大多数朋友对Service这个名词都不会陌生,没错,一个老练的A ...

  4. Android ViewPager 用法

    Android ViewPager 用法 场景:一般第一次打开应用程序时,程序会有一个提示页来给展现应用程序都有哪些功能:或者程序更新时,又更新哪些新特性,都可以使用ViewPager Demo 描述 ...

  5. Android ViewPager再探:增加滑动指示条

    上一篇:<Android ViewPager初探:让页面滑动起来> ViewPager只是左右滑动有些丑,也不知道当前位于第几页面. 可以在上方加入滑动指示条,来确定当前位置. 只需要修改 ...

  6. Android ViewPager初探:让页面滑动起来

    下一篇:<Android ViewPager再探:增加滑动指示条> ViewPager需要用到适配器PagerAAdapter,以下四个函数需要重写: instantiateItem(Vi ...

  7. [转] Android Volley完全解析(一),初识Volley的基本用法

    版权声明:本文出自郭霖的博客,转载必须注明出处.   目录(?)[-] Volley简介 下载Volley StringRequest的用法 JsonRequest的用法   转载请注明出处:http ...

  8. Android OkHttp完全解析 --zz

    参考文章 https://github.com/square/okhttp http://square.github.io/okhttp/ 泡网OkHttp使用教程 Android OkHttp完全解 ...

  9. Android IntentService完全解析 当Service遇到Handler

    一 概述 大家都清楚,在Android的开发中,凡是遇到耗时的操作尽可能的会交给Service去做,比如我们上传多张图,上传的过程用户可能将应用置于后台,然后干别的去了,我们的Activity就很可能 ...

随机推荐

  1. Wall(凸包POJ 1113)

    Wall Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 32360 Accepted: 10969 Description On ...

  2. Rigidbody SweepTest测试

    和Physics的投射差不多,SweepTest可以直接投射当前碰撞 但是比较遗憾的是它对MeshCollider的支持不是很好,需要勾选Convex 投射和Physics一样,只要加了碰撞器,不管勾 ...

  3. Entity Framework 第三篇 实体特性声明

    Entity Framework中对实体的特性声明有着严格的要求 1.实体必须要有主键特性,但是如果实体没有主键特性那怎么办? public int ExecuteSqlCommand(string ...

  4. winform中拖动功能实现技巧

    实现的需求,我通过拖动选中的用户行放到左边的机构节点上,从而实现用户改变组织机构的关系 贴代码 private DataGridViewSelectedRowCollection sourceRowC ...

  5. Intel Code Challenge Final Round (Div. 1 + Div. 2, Combined) B

    Description You are given a table consisting of n rows and m columns. Numbers in each row form a per ...

  6. ACM-ICPC国际大学生程序设计竞赛北京赛区(2016)网络赛 The Book List

    描述 The history of Peking University Library is as long as the history of Peking University. It was b ...

  7. collections在java中的常见用法

    1. 工具类collections用于操作集合类,如List,Set,常用方法有: 1) 排序(Sort) 使用sort方法可以根据元素的自然顺序 对指定列表按升序进行排序.列表中的所有元素都必须实现 ...

  8. size()弃用

    size() 方法在 jQuery 版本 1.8 中被废弃. 请使用 length 属性代替.

  9. Zabbix监控交换机设置

    说明: Zabbix监控服务端已经配置完成,现在要使用Zabbix对交换机进行监控. 具体操作: 以下操作在被监控的交换机上进行,这里以Cisco交换机为例. 一.登录到Cisco交换机,开启snmp ...

  10. BZOJ 2666: [cqoi2012]组装

    题目链接:http://www.lydsy.com:808/JudgeOnline/problem.php?id=2666 题意:n种零件,m个位置,每个位置有一种零件.求一个位置x,使得cost(1 ...