




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、ViewPager+GridView实现GridView左右滑动翻页,实时动态读取数据实现思路:给ViewPager动态加载View,加载ViewPager当前最后一个View时预先判断是否还有数据,如果有就新建一个线程添加一个View,完成根据滑动及时读取数据。包含两个文件:main.javaDatabaseHelper.javamain.javapackageyy.viewpagergridview;importjava.util.ArrayList;importjava.util.List;importandroid.app.Activity;importandroid.content.
2、Context;importandroid.database.Cursor;importandroid.database.sqlite.SQLiteDatabase;importandroid.os.Bundle;importandroid.os.Handler;importandroid.os.HandlerThread;importandroid.os.Looper;importandroid.os.Message;importandroid.os.Parcelable;importandroid.support.v4.view.PagerAdapter;importandroid.sup
3、port.v4.view.ViewPager;importandroid.support.v4.view.ViewPager.OnPageChangeListener;importandroid.view.View;importandroid.view.View.OnClickListener;importandroid.widget.GridView;importandroid.widget.SimpleCursorAdapter;importandroid.widget.TextView;importdbhelper.DatabaseHelper;publicclassmainextend
4、sActivityprivateViewPagermyViewPager;privateMyPagerAdaptermyAdapter;privateListmListViews;privateinttolalnum;privateintpagesize=3;/每页显示数量privateDatabaseHelperdbhelper;privateSQLiteDatabasedb;privateCursorcur;privateTextViewgirdviewpage;OverrideprotectedvoidonCreate(BundlesavedInstanceState)/*实现思路:给V
5、iewPager动态加载View,加载ViewPager当前最后一个View时预先判断是否还有数据,如果有就新建一个线程添加一个View,完成根据滑动及时读取数据。*/super.onCreate(savedInstanceState);setContentView(R.layout.main);show();/加载前两页GirdViewpublicvoidshow()myAdapter=newMyPagerAdapter();myViewPager=(ViewPager)findViewById(R.id.viewpagerLayout);myViewPager.setAdapter(myA
6、dapter);mListViews=newArrayList();/预先加载两个View,及两页数据,如果考虑实际情况,可以从倒数第二个View就开始预装数据。dbhelper=newDatabaseHelper(main.this,testdata,1);db=dbhelper.getReadableDatabase();cur=db.rawQuery(selectcount(id)asnumfromtesttable,null);cur.moveToFirst();tolalnum=Integer.parseInt(cur.getString(0);if(tolalnum0)girdvi
7、ewpage=(TextView)findViewById(R.id.girdviewpage);/要得到正确的页数就自己写了,这个不是目的,所以需要自己重写girdviewpage.setText(共有+cur.getString(O)+条数据。当前第1页,共+tolalnum/pagesize+页);/新手,目前没有找到更合适的方法来拆分Cursorif(tolalnum1)/新建一个线程读取下一个View的数据HandlerThreadhandlerthread=newHandlerThread(GetNewViewThread+arg0);handlerthread.start();m
8、yhandlermh=newmyhandler(handlerthread.getLooper();Messagems=mh.obtainMessage();ms.arg1=arg0+1;ms.sendToTarget();girdviewpage.setText(共有+tolalnum+条数据。当前第+(argO+l)+页,共+tolalnum/pagesize+页);classmyhandlerextendsHandlerpublicmyhandler(Looperlooper)super(looper);OverridepublicvoidhandleMessage(Messagemsg
9、)/TODOAuto-generatedmethodstubsuper.handleMessage(msg);/读取下一列数据intnextnum=msg.arg1;db=dbhelper.getReadableDatabase();cur=db.rawQuery(selectidas_id,namefromtesttableorderbyidLimit+pagesize+Offset+(nextnum)*pagesize,null);/执行SQL语句,注意LimitOffset用法if(cur.getCount()0)GridViewgd=newGridView(main.this);mys
10、impcursoradptermyadapter=newmysimpcursoradpter(main.this,R.layout.gridview,cur,newStringname,newintR.id.txtlable1);gd.setAdapter(myadapter);gd.setNumColumns(3);gd.setHorizontalSpacing(1);gd.setVerticalSpacing(1);gd.setColumnWidth(90);gd.setStretchMode(2);/添加viewmListViews.add(gd);db.close();privatec
11、lassMyPagerAdapterextendsPagerAdapterOverridepublicvoiddestroyItem(Viewarg0,intarg1,Objectarg2)(ViewPager)arg0).removeView(mListViews.get(arg1);OverridepublicintgetCount()returnmListViews.size();OverridepublicObjectinstantiateItem(Viewarg0,intarg1)(ViewPager)arg0).addView(mListViews.get(arg1),0);ret
12、urnmListViews.get(arg1);OverridepublicbooleanisViewFromObject(Viewarg0,Objectarg1)returnarg0=(arg1);OverridepublicvoidfinishUpdate(Viewarg0)/TODOAuto-generatedmethodstubOverridepublicvoidrestoreState(Parcelablearg0,ClassLoaderarg1)/TODOAuto-generatedmethodstubOverridepublicParcelablesaveState()/TODO
13、Auto-generatedmethodstubreturnnull;OverridepublicvoidstartUpdate(Viewarg0)/TODOAuto-generatedmethodstubDatabaseHelper.java/数据库操作,初始化数据packagedbhelper;importandroid.content.Context;importandroid.database.sqlite.SQLiteDatabase;importandroid.database.sqlite.SQLiteOpenHelper;importandroid.database.sqlit
14、e.SQLiteDatabase.CursorFactory;/DatabaseHelper作为一个访问SQLite的助手类,提供两个方面的功能,/第一,getReadableDatabase(),getWritableDatabase()以获得SQLiteDatabse对象,通过该对象可以对数据库进行操作/第二,提供了onCreate()和onUpgrade()两个回调函数,允许我们在创建和升级数据库时,进行自己的操作publicclassDatabaseHelperextendsSQLiteOpenHelperprivatestaticfinalintVERSION=1;/在SQLiteO
15、epnHelper的子类当中,必须有该构造函数publicDatabaseHelper(Contextcontext,Stringname,CursorFactoryfactory,intversion)/必须通过super调用父类当中的构造函数super(context,name,factory,version);/TODOAuto-generatedconstructorstubpublicDatabaseHelper(Contextcontext,Stringname)this(context,name,VERSION);publicDatabaseHelper(Contextconte
16、xt,Stringname,intversion)this(context,name,null,version);才会/该函数是在第一次创建数据库的时候执行,实际上是在第一次得到SQLiteDatabse对象的时候,调用这个方法OverridepublicvoidonCreate(SQLiteDatabasedb)/TODOAuto-generatedmethodstub/execSQL函数用于执行SQL语句db.execSQL(createtabletesttable(idint,namevarchar(50);for(inti=1;i500;i+)db.execSQL(insertintotesttable(id,name)values(+i+,+i+);Override
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 危险品管理对噪声振动和辐射的管理和控制要求考核试卷
- 服装设计人体工学原理考核试卷
- 批发业采购谈判技巧与策略考核试卷
- 机床功能部件在虚拟现实设备中的交互式设计考核试卷
- 有机肥料在土壤侵蚀控制与生态恢复中的应用考核试卷
- 儿童情商培训课件
- 代加工合同范本简单
- 灯具采购标准合同范本
- 简易的物业合同范本
- 助学赠与合同范本
- 水浒传读书分享(完美版)模板两篇
- 《配电自动化运维人员培训考核规范(征求意见意见稿)》
- (中职组)植物病虫害防治知识竞赛考试题库(含答案)
- 肌肉注射新版本
- 大班语言活动-海豹到哪里去了
- 2021年4月自考00808商法试题及答案含解析
- 高考概率大题必练20题(理科)-含答案
- 新人通识训试卷附有答案
- 凉水井煤矿矿山地质环境与土地复垦方案
- 果实酚类和挥发性物质含量特征及其与果实品质关系的研究
- 2023年东华高级中学中考自招数学复习题及答案解析
评论
0/150
提交评论