亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 系統 > Android > 正文

android書架效果實現原理與代碼

2020-04-11 12:37:17
字體:
來源:轉載
供稿:網友
以前也模仿者ireader實現了書架的效果,但是那種是使用listview實現的,并不好用。絕大多數都是用gridview實現的,網上這方面資料比較少,有些開源的電子書都是重點做了閱讀,并沒有像ireader和QQ閱讀這樣的書架效果。

書架這種效果我早就實現了,本來想做一個完美的電子書,但是因為自己的懶惰,僅僅持續了一兩天,今天又找到了以前的代碼分享出來,希望大家能一起實現一個比較完美的開源的電子書。廢話不多說先看下效果:
 
本地部分還沒有做,做好以后就可以吧本地的書加載到書架里了,這只是一個開始,后面還有很多復雜的沒有做。
下面先看一下書架的實現原理吧!
首先看一下layout下的布局文件main.xml
復制代碼 代碼如下:

<?xmlversion="1.0"encoding="utf-8"?>
<RelativeLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
>
<includelayout="@layout/head"android:id="@+id/head"/>
<cn.com.karl.view.MyGridView
android:id="@+id/bookShelf"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:layout_below="@id/head"
android:cacheColorHint="#00000000"
android:columnWidth="90.0dip"
android:fadingEdge="none"
android:horizontalSpacing="5dp"
android:listSelector="#00000000"
android:numColumns="3"
android:scrollbars="none"
android:verticalSpacing="20dp"/>

<SlidingDrawer
android:id="@+id/sliding"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:content="@+id/allApps"
android:handle="@+id/imageViewIcon"
android:orientation="vertical">

<Button
android:id="@+id/imageViewIcon"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="本地"
android:textSize="18dp"
android:background="@drawable/btn_local"/>
<GridView
android:id="@+id/allApps"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:background="@drawable/file_list_bg"
android:columnWidth="60dp"
android:gravity="center"
android:horizontalSpacing="10dp"
android:numColumns="auto_fit"
android:padding="10dp"
android:stretchMode="columnWidth"
android:verticalSpacing="10dp"/>
</SlidingDrawer>
</RelativeLayout>

上面是個自定義的gridview主要來實現書架,因為每一本書是一個item,在自定義的gridview中計算每一行的高度,然后把書架畫上去。下面是個抽屜。
復制代碼 代碼如下:

publicclassMyGridViewextendsGridView{
privateBitmapbackground;
publicMyGridView(Contextcontext,AttributeSetattrs){
super(context,attrs);
background=BitmapFactory.decodeResource(getResources(),
R.drawable.bookshelf_layer_center);
}
@Override
protectedvoiddispatchDraw(Canvascanvas){
intcount=getChildCount();
inttop=count>0?getChildAt(0).getTop():0;
intbackgroundWidth=background.getWidth();
intbackgroundHeight=background.getHeight()+2;
intwidth=getWidth();
intheight=getHeight();
for(inty=top;y<height;y+=backgroundHeight){
for(intx=0;x<width;x+=backgroundWidth){
canvas.drawBitmap(background,x,y,null);
}
}
super.dispatchDraw(canvas);
}
}

上面就是自定義書架的gridview,也是實現書架最核心的方法。
然后是每一個item的布局:
復制代碼 代碼如下:

<?xmlversion="1.0"encoding="utf-8"?>
<LinearLayoutxmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:gravity="center"
android:orientation="vertical">
<TextView
android:layout_height="110dp"
android:layout_width="90dp"
android:layout_marginTop="10dp"
android:background="@drawable/cover_txt"
android:id="@+id/imageView1"
android:text="天龍八部"
android:padding="15dp"
android:textColor="#000000"
/>
</LinearLayout>

最后就可以在主activity中顯示出來了。
復制代碼 代碼如下:

publicclassBookShelfActivityextendsBaseActivity{
privateGridViewbookShelf;
privateint[]data={
R.drawable.cover_txt,R.drawable.cover_txt,R.drawable.cover_txt,R.drawable.cover_txt,R.drawable.cover_txt,
R.drawable.cover_txt,R.drawable.cover_txt,R.drawable.cover_txt,R.drawable.cover_txt,R.drawable.cover_txt,
R.drawable.cover_txt,R.drawable.cover_txt,R.drawable.cover_txt,R.drawable.cover_txt,
R.drawable.cover_txt,R.drawable.cover_txt,R.drawable.cover_txt,R.drawable.cover_txt,
R.drawable.cover_txt,R.drawable.cover_txt,R.drawable.cover_txt,R.drawable.cover_txt,
R.drawable.cover_txt,R.drawable.cover_txt,R.drawable.cover_txt,R.drawable.cover_txt,
R.drawable.cover_txt,R.drawable.cover_txt,R.drawable.cover_txt,R.drawable.cover_txt,
R.drawable.cover_txt,R.drawable.cover_txt,R.drawable.cover_txt,R.drawable.cover_txt

};
privateString[]name={
"天龍八部","搜神記","水滸傳","黑道悲情"
};
privateGridViewgv;
privateSlidingDrawersd;
privateButtoniv;
privateList<ResolveInfo>apps;
/**Calledwhentheactivityisfirstcreated.*/
@Override
publicvoidonCreate(BundlesavedInstanceState){
super.onCreate(savedInstanceState);
this.requestWindowFeature(Window.FEATURE_NO_TITLE);
setContentView(R.layout.main);
bookShelf=(GridView)findViewById(R.id.bookShelf);
ShlefAdapteradapter=newShlefAdapter();
bookShelf.setAdapter(adapter);
bookShelf.setOnItemClickListener(newOnItemClickListener(){
@Override
publicvoidonItemClick(AdapterView<?>arg0,Viewarg1,intarg2,
longarg3){
//TODOAuto-generatedmethodstub
if(arg2>=data.length){

}else{
Toast.makeText(getApplicationContext(),""+arg2,Toast.LENGTH_SHORT).show();
}
}
});
loadApps();
gv=(GridView)findViewById(R.id.allApps);
sd=(SlidingDrawer)findViewById(R.id.sliding);
iv=(Button)findViewById(R.id.imageViewIcon);
gv.setAdapter(newGridAdapter());
sd.setOnDrawerOpenListener(newSlidingDrawer.OnDrawerOpenListener()//開抽屜
{
@Override
publicvoidonDrawerOpened(){
iv.setText("返回");
iv.setBackgroundResource(R.drawable.btn_local);//響應開抽屜事件
//,把圖片設為向下的
}
});
sd.setOnDrawerCloseListener(newSlidingDrawer.OnDrawerCloseListener(){
@Override
publicvoidonDrawerClosed(){
iv.setText("本地");
iv.setBackgroundResource(R.drawable.btn_local);//響應關抽屜事件
}
});
}
classShlefAdapterextendsBaseAdapter{
@Override
publicintgetCount(){
//TODOAuto-generatedmethodstub
returndata.length+5;
}
@Override
publicObjectgetItem(intarg0){
//TODOAuto-generatedmethodstub
returnarg0;
}
@Override
publiclonggetItemId(intarg0){
//TODOAuto-generatedmethodstub
returnarg0;
}
@Override
publicViewgetView(intposition,ViewcontentView,ViewGrouparg2){
//TODOAuto-generatedmethodstub

contentView=LayoutInflater.from(getApplicationContext()).inflate(R.layout.item1,null);

TextViewview=(TextView)contentView.findViewById(R.id.imageView1);
if(data.length>position){
if(position<name.length){
view.setText(name[position]);
}
view.setBackgroundResource(data[position]);
}else{
view.setBackgroundResource(data[0]);
view.setClickable(false);
view.setVisibility(View.INVISIBLE);
}
returncontentView;
}

}
@Override
publicbooleanonKeyDown(intkeyCode,KeyEventevent){
//TODOAuto-generatedmethodstub
if(keyCode==KeyEvent.KEYCODE_BACK){
AlertDialog.Builderbuilder=newAlertDialog.Builder(this);
builder.setMessage("你確定退出嗎?")
.setCancelable(false)
.setPositiveButton("確定",
newDialogInterface.OnClickListener(){
publicvoidonClick(DialogInterfacedialog,
intid){
finish();
}
})
.setNegativeButton("返回",
newDialogInterface.OnClickListener(){
publicvoidonClick(DialogInterfacedialog,
intid){
dialog.cancel();
}
});
AlertDialogalert=builder.create();
alert.show();
returntrue;
}
returnsuper.onKeyDown(keyCode,event);
}
privatevoidloadApps(){
Intentintent=newIntent(Intent.ACTION_MAIN,null);
intent.addCategory(Intent.CATEGORY_LAUNCHER);
apps=getPackageManager().queryIntentActivities(intent,0);
}
publicclassGridAdapterextendsBaseAdapter{
publicGridAdapter(){
}
publicintgetCount(){
//TODOAuto-generatedmethodstub
returnapps.size();
}
publicObjectgetItem(intposition){
//TODOAuto-generatedmethodstub
returnapps.get(position);
}
publiclonggetItemId(intposition){
//TODOAuto-generatedmethodstub
returnposition;
}
publicViewgetView(intposition,ViewconvertView,ViewGroupparent){
//TODOAuto-generatedmethodstub
ImageViewimageView=null;
if(convertView==null){
imageView=newImageView(BookShelfActivity.this);
imageView.setScaleType(ImageView.ScaleType.FIT_CENTER);
imageView.setLayoutParams(newGridView.LayoutParams(50,50));
}else{
imageView=(ImageView)convertView;
}
ResolveInfori=apps.get(position);
imageView.setImageDrawable(ri.activityInfo
.loadIcon(getPackageManager()));
returnimageView;
}
}
}

代碼寫的有點亂,有待整理下,哈哈。
上面只是一個畫龍點睛的作用,真要實現一個好的電子書,后面還有跟多的工作,也希望有興趣的朋友能在此基礎上實現一個完美的電子書,然后把源代碼開放,這樣我就不用在往下做了,嘎嘎。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
青青精品视频播放| 欧美日韩国产麻豆| 欧美视频在线观看免费网址| 欧美电影免费观看高清| 欧美情侣性视频| 国产综合在线看| 亚洲人成在线观| 久久午夜a级毛片| 色综合导航网站| 国产精品午夜国产小视频| 国产成人激情视频| 色偷偷av亚洲男人的天堂| 欧美黑人又粗大| 亚洲美女精品久久| 欧美黑人xxx| 亚洲a∨日韩av高清在线观看| 亚洲成人激情图| 欧美精品在线看| 亚洲福利在线观看| 国产一区视频在线| 久久久精品国产| 疯狂做受xxxx高潮欧美日本| 国产成人精品一区二区| 国产成人拍精品视频午夜网站| 在线精品91av| 久久在线免费视频| 91国产视频在线| 成人激情春色网| 日本久久亚洲电影| 日韩免费av在线| 欧美成人黑人xx视频免费观看| 中文字幕最新精品| 欧美高清在线视频观看不卡| 国产成人精品久久二区二区91| 国产一区二区黑人欧美xxxx| 欧美成人午夜激情在线| 色老头一区二区三区| 欧美成人国产va精品日本一级| 韩国精品美女www爽爽爽视频| 疯狂做受xxxx高潮欧美日本| 国产成+人+综合+亚洲欧美丁香花| 亚洲天堂日韩电影| 欧美精品日韩www.p站| 色偷偷888欧美精品久久久| 精品国产31久久久久久| 日韩一中文字幕| 国产精品最新在线观看| 国产精品国内视频| 国产精品扒开腿做| 国产精品高潮呻吟久久av黑人| 91美女片黄在线观看游戏| 亚洲视频在线观看| 国产日韩在线看片| 91精品国产高清自在线看超| 91免费的视频在线播放| 国产成人亚洲精品| 亚洲激情在线观看| 国产精品视频区1| 91精品国产91| 国产精品极品美女粉嫩高清在线| 91麻豆桃色免费看| 亚洲品质视频自拍网| 国内精品一区二区三区| 97人人模人人爽人人喊中文字| 国产性猛交xxxx免费看久久| 欧美日韩国产精品| 日韩在线中文视频| 久久久久久18| 国产一区二区三区欧美| 亚洲人成电影网站色www| 国模精品系列视频| 亚洲欧美日韩视频一区| 成人伊人精品色xxxx视频| 欧美有码在线观看视频| 久久亚洲国产精品| 国产视频欧美视频| 欧美剧在线观看| 久久琪琪电影院| 日韩av综合网站| 亚洲а∨天堂久久精品9966| 久久久噜噜噜久久中文字免| 青青青国产精品一区二区| 亚洲国产精久久久久久| 久久久免费精品视频| 欧美与黑人午夜性猛交久久久| www.99久久热国产日韩欧美.com| 国产一区二区日韩精品欧美精品| 久久亚洲春色中文字幕| 国产精品福利观看| 久久久久亚洲精品| 欧美大秀在线观看| 黄网动漫久久久| 中文字幕国产亚洲2019| 久久久久久久一区二区| 亚洲自拍偷拍区| 欧美性生交xxxxx久久久| 欧美激情a在线| 成人精品在线观看| 深夜成人在线观看| 正在播放国产一区| 日韩在线观看高清| 九九综合九九综合| 日韩大片免费观看视频播放| 国产成人一区二区在线| 97碰在线观看| 中文字幕亚洲无线码在线一区| 中文字幕亚洲综合久久| 亚洲精品aⅴ中文字幕乱码| 亚洲一区二区自拍| 91av在线播放视频| 国产美女久久久| 国产精品欧美激情| 精品福利视频导航| 国产香蕉精品视频一区二区三区| 97不卡在线视频| 97色在线观看| 日韩欧美在线看| 午夜免费在线观看精品视频| 欧美在线观看一区二区三区| 欧美日韩国产精品专区| 欧美激情视频播放| 亚洲成人在线视频播放| 91精品国产成人www| 欧美亚洲视频在线看网址| 国产综合在线视频| 亚洲大尺度美女在线| 日韩在线免费视频| 日本91av在线播放| 国产91网红主播在线观看| 亚洲欧美国产日韩天堂区| 国产一区二区三区在线观看网站| 国内精品久久久久| 欧美黑人性生活视频| 欧美成人精品一区二区| 日韩av网站导航| 亚洲欧美日韩国产精品| 亚洲精品v欧美精品v日韩精品| 成人观看高清在线观看免费| 亚洲国产高清福利视频| 夜夜嗨av色综合久久久综合网| 一区二区三区视频免费| 日韩精品福利在线| 91国产中文字幕| 欧美日韩一区免费| 中文亚洲视频在线| 国产精品尤物福利片在线观看| 日韩av电影免费观看高清| 日韩av色综合| 欧美成人精品一区二区| 亚洲一区制服诱惑| 91干在线观看| 欧美日韩国产中字| 国产精品自产拍高潮在线观看| 97涩涩爰在线观看亚洲| 国产成人小视频在线观看| 91国偷自产一区二区三区的观看方式| 91在线无精精品一区二区| 国产精品mp4| 欧美体内谢she精2性欧美| 久久69精品久久久久久国产越南| 精品国产福利视频| 久久久久久久久久久久久久久久久久av| 久久99热这里只有精品国产| 日本精品久久久久久久|