Android ViewPager刷新解析
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刷新解析的更多相关文章
- Android DiskLruCache 源代码解析 硬盘缓存的绝佳方案
转载请标明出处: http://blog.csdn.net/lmj623565791/article/details/47251585: 本文出自:[张鸿洋的博客] 一.概述 依然是整理东西.所以最近 ...
- Android Service完全解析,关于服务你所需知道的一切(下)
转载请注册出处:http://blog.csdn.net/guolin_blog/article/details/9797169 在上一篇文章中,我们学习了Android Service相关的许多重要 ...
- Android Service完全解析,关于服务你所需知道的一切(上)
转载请注明出处:http://blog.csdn.net/guolin_blog/article/details/11952435 相信大多数朋友对Service这个名词都不会陌生,没错,一个老练的A ...
- Android ViewPager 用法
Android ViewPager 用法 场景:一般第一次打开应用程序时,程序会有一个提示页来给展现应用程序都有哪些功能:或者程序更新时,又更新哪些新特性,都可以使用ViewPager Demo 描述 ...
- Android ViewPager再探:增加滑动指示条
上一篇:<Android ViewPager初探:让页面滑动起来> ViewPager只是左右滑动有些丑,也不知道当前位于第几页面. 可以在上方加入滑动指示条,来确定当前位置. 只需要修改 ...
- Android ViewPager初探:让页面滑动起来
下一篇:<Android ViewPager再探:增加滑动指示条> ViewPager需要用到适配器PagerAAdapter,以下四个函数需要重写: instantiateItem(Vi ...
- [转] Android Volley完全解析(一),初识Volley的基本用法
版权声明:本文出自郭霖的博客,转载必须注明出处. 目录(?)[-] Volley简介 下载Volley StringRequest的用法 JsonRequest的用法 转载请注明出处:http ...
- Android OkHttp完全解析 --zz
参考文章 https://github.com/square/okhttp http://square.github.io/okhttp/ 泡网OkHttp使用教程 Android OkHttp完全解 ...
- Android IntentService完全解析 当Service遇到Handler
一 概述 大家都清楚,在Android的开发中,凡是遇到耗时的操作尽可能的会交给Service去做,比如我们上传多张图,上传的过程用户可能将应用置于后台,然后干别的去了,我们的Activity就很可能 ...
随机推荐
- Wall(凸包POJ 1113)
Wall Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 32360 Accepted: 10969 Description On ...
- Rigidbody SweepTest测试
和Physics的投射差不多,SweepTest可以直接投射当前碰撞 但是比较遗憾的是它对MeshCollider的支持不是很好,需要勾选Convex 投射和Physics一样,只要加了碰撞器,不管勾 ...
- Entity Framework 第三篇 实体特性声明
Entity Framework中对实体的特性声明有着严格的要求 1.实体必须要有主键特性,但是如果实体没有主键特性那怎么办? public int ExecuteSqlCommand(string ...
- winform中拖动功能实现技巧
实现的需求,我通过拖动选中的用户行放到左边的机构节点上,从而实现用户改变组织机构的关系 贴代码 private DataGridViewSelectedRowCollection sourceRowC ...
- 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 ...
- ACM-ICPC国际大学生程序设计竞赛北京赛区(2016)网络赛 The Book List
描述 The history of Peking University Library is as long as the history of Peking University. It was b ...
- collections在java中的常见用法
1. 工具类collections用于操作集合类,如List,Set,常用方法有: 1) 排序(Sort) 使用sort方法可以根据元素的自然顺序 对指定列表按升序进行排序.列表中的所有元素都必须实现 ...
- size()弃用
size() 方法在 jQuery 版本 1.8 中被废弃. 请使用 length 属性代替.
- Zabbix监控交换机设置
说明: Zabbix监控服务端已经配置完成,现在要使用Zabbix对交换机进行监控. 具体操作: 以下操作在被监控的交换机上进行,这里以Cisco交换机为例. 一.登录到Cisco交换机,开启snmp ...
- BZOJ 2666: [cqoi2012]组装
题目链接:http://www.lydsy.com:808/JudgeOnline/problem.php?id=2666 题意:n种零件,m个位置,每个位置有一种零件.求一个位置x,使得cost(1 ...