本文实例讲述了AndroID编程实现抽屉效果的方法。分享给大家供大家参考,具体如下:
今天在手机上实现了抽屉效果,其实很简单,但是效果却很酷。
首先在layout 下设置xml布局文件
<?xml version="1.0" enCoding="utf-8"?><relativeLayout xmlns:androID="http://schemas.androID.com/apk/res/androID" androID:layout_wIDth="fill_parent" androID:layout_height="fill_parent" > <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" > <GrIDVIEw androID:ID="@+ID/allApps" androID:layout_wIDth="wrap_content" androID:layout_height="wrap_content" androID:background="@drawable/bk" androID:columnWIDth="60dp" androID:gravity="center" androID:horizontalSpacing="10dp" androID:numColumns="auto_fit" androID:padding="10dp" androID:stretchMode="columnWIDth" androID:verticalSpacing="10dp" /> <ImageVIEw androID:ID="@+ID/imageVIEwIcon" androID:layout_wIDth="wrap_content" androID:layout_height="wrap_content" androID:src="@drawable/touch_handler" /> </SlIDingDrawer></relativeLayout>
SlIDingDrawer就是重要的抽屉控件 ,handle是抽屉的拖动按钮,content是抽屉中的内容。
然后建立 chouti的activity类:
import androID.app.Activity;import androID.content.Intent;import androID.content.pm.ResolveInfo;import androID.os.Bundle;import androID.vIEw.VIEw;import androID.vIEw.VIEwGroup;import androID.Widget.BaseAdapter;import androID.Widget.GrIDVIEw;import androID.Widget.ImageVIEw;import androID.Widget.SlIDingDrawer;public class Chouti extends Activity { private GrIDVIEw gv; private SlIDingDrawer sd; private ImageVIEw iv; private List<ResolveInfo> apps; /** Called when the activity is first created. */ @OverrIDe public voID onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentVIEw(R.layout.slIDingdrawer); loadApps(); gv = (GrIDVIEw) findVIEwByID(R.ID.allApps); sd = (SlIDingDrawer) findVIEwByID(R.ID.slIDing); iv = (ImageVIEw) findVIEwByID(R.ID.imageVIEwIcon); gv.setAdapter(new GrIDAdapter()); sd.setonDrawerOpenListener(new SlIDingDrawer.OnDrawerOpenListener()// 开抽屉 { @OverrIDe public voID onDrawerOpened() { iv.setimageResource(R.drawable.touch_handler);// 响应开抽屉事件 // ,把图片设为向下的 } }); sd.setonDrawerCloseListener(new SlIDingDrawer.OnDrawerCloseListener() { @OverrIDe public voID onDrawerClosed() { iv.setimageResource(R.drawable.touch_handler);// 响应关抽屉事件 } }); } private voID loadApps() { Intent intent = new Intent(Intent.ACTION_MAIN,null); intent.addcategory(Intent.category_LAUNCHER); apps = getPackageManager().queryIntentActivitIEs(intent,0); } public class GrIDAdapter extends BaseAdapter { public GrIDAdapter() { } public int getCount() { // Todo auto-generated method stub return apps.size(); } public Object getItem(int position) { // Todo auto-generated method stub return apps.get(position); } public long getItemID(int position) { // Todo auto-generated method stub return position; } public VIEw getVIEw(int position,VIEw convertVIEw,VIEwGroup parent) { // Todo auto-generated method stub ImageVIEw imageVIEw = null; if (convertVIEw == null) { imageVIEw = new ImageVIEw(Chouti.this); imageVIEw.setScaleType(ImageVIEw.ScaleType.FIT_CENTER); imageVIEw.setLayoutParams(new GrIDVIEw.LayoutParams(50,50)); } else { imageVIEw = (ImageVIEw) convertVIEw; } ResolveInfo ri = apps.get(position); imageVIEw.setimageDrawable(ri.activityInfo .loadIcon(getPackageManager())); return imageVIEw; } }}
loadApps方法是得到主界面上的图片和文字。
然后设置的自定义adapter中去。
看下运行后效果:
向上滑动imagevIEw按钮后:
为了体现更好的效果,可以用两张滑动图片,一张朝上的,一张朝下的。根据监听器做相应的切换。
更多关于AndroID相关内容感兴趣的读者可查看本站专题:《Android控件用法总结》、《Android开发入门与进阶教程》、《Android视图View技巧总结》、《Android编程之activity *** 作技巧总结》、《Android数据库 *** 作技巧总结》及《Android资源 *** 作技巧汇总》
希望本文所述对大家AndroID程序设计有所帮助。
总结以上是内存溢出为你收集整理的Android编程实现抽屉效果的方法示例全部内容,希望文章能够帮你解决Android编程实现抽屉效果的方法示例所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)