
本文以一个简单的小例子,简述AndroID开发中GrIDVIEw的常见应用,仅供学习分享使用。
概述GirIDVIEw是一个表格显示资源的控件,可以在两个可滚动的方向上显示。列表项的资源会通过listadapter自动添加到布局控件中GirdVIEw上。
如下图所示:
数据绑定步骤
如下图所示:
涉及知识点androID:numColumns="auto_fit" 设置GrIDVIEw中的列数,可以是数字,auto_fit表示系统自动根据屏幕的大小进行适应性显示。androID:verticalSpacing="10dp” 用于设置行与行之间的垂直间隔androID:horizontalSpacing="10dp" 用于设置列与列之间的水平间隔androID:stretchMode="columnWIDth" 设置列中元素的拉伸模式setonItemClickListener 设置列元素的监听事件示例效果图如下图所示:
核心代码GrIDVIEw如下:
1 <?xml version="1.0" enCoding="utf-8"?> 2 <relativeLayout 3 xmlns:androID="http://schemas.androID.com/apk/res/androID" 4 xmlns:tools="http://schemas.androID.com/tools" 5 androID:layout_wIDth="match_parent" 6 androID:layout_height 7 tools:context="com.hex.demogrIDvIEw.MainActivity"> 8 GrIDVIEw 9 androID:ID="@+ID/gv_info"10 androID:columnWIDth="90dp"11 androID:verticalSpacing="10dp"12 androID:horizontalSpacing13 androID:numColumns="auto_fit"14 androID:stretchMode="columnWIDth"15 androID:layout_wIDth16 androID:layout_height="match_parent"></GrIDVIEw17 </relativeLayout>
列表项代码(图片和文本)
linearLayout 3 androID:layout_wIDth androID:layout_height androID:orIEntation="vertical" 6 ImageVIEw 7 ="@+ID/img_info" 8 androID:src="@drawable/a011" 9 ="wrap_content"/>11 TextVIEw12 ="@+ID/tv_info" androID:text="abc" androID:textSize="20sp" androID:textAlignment="center" androID:textcolor="@color/colorAccent"17 18 19 linearLayout>
后台代码(Adapter类)
class MyAdapter extends BaseAdapter { 2 private Context mContext; 3 4 public MyAdapter(Context context) { 5 this.mContext = context; 6 } 7 8 @OverrIDe 9 public int getCount() {10 return mList != null ? mList.size() : 0;11 12 13 14 public Object getItem( position) {15 return mList.get(position);16 17 18 19 long getItemID(20 position;21 22 23 24 public VIEw getVIEw( position,VIEw convertVIEw,VIEwGroup parent) {25 VIEwHolder vIEwHolder;26 if (convertVIEw == null) {27 // if it's not recycled,initialize some attributes28 LayoutInflater inflater = (LayoutInflater) getSystemService(Context.LAYOUT_INFLATER_SERVICE); getLayoutInflater();29 convertVIEw = inflater.inflate(R.layout.grID_item,);30 vIEwHolder=new VIEwHolder();31 vIEwHolder.img = (ImageVIEw) convertVIEw.findVIEwByID(R.ID.img_info);32 vIEwHolder.tv = (TextVIEw) convertVIEw.findVIEwByID(R.ID.tv_info);33 34 convertVIEw.setTag(vIEwHolder);35 } else {36 vIEwHolder = (VIEwHolder) convertVIEw.getTag();37 }38 vIEwHolder.img.setimageResource((int)mList.get(position).get("img"));39 vIEwHolder.tv.setText((String) mList.get(position).get("txt"40 convertVIEw;41 42 }
后台代码(Activity)
class MainActivity AppCompatActivity { 2 private [] imgs; 3 private List<Map<String,Object>> mList; 4 GrIDVIEw gvInfo; 5 @OverrIDeprotected voID onCreate(Bundle savedInstanceState) { 7 super.onCreate(savedInstanceState); setContentVIEw(R.layout.activity_main); 9 gvInfo= (GrIDVIEw) this.findVIEwByID(R.ID.gv_info);10 11 imgs=new []{R.drawable.a011,R.drawable.a012,R.drawable.a013,R.drawable.a014,R.drawable.a015,R.drawable.a016,备注
R.drawable.a017,R.drawable.a018,R.drawable.a019,R.drawable.a0110,R.drawable.a0111};12 mList=new ArrayList<Map<String,1)">();13 for(int i=0;i<11;i++14 Map<String,Object> map = new HashMap<String,Object>15 map.put("img",imgs[i]);16 map.put("txt","第" + i + "个" mList.add(map);19 MyAdapter adapter =new MyAdapter(20 gvInfo.setAdapter(adapter);21 gvInfo.setonItemClickListener( AdapterVIEw.OnItemClickListener() {22 @OverrIDe23 voID onItemClick(AdapterVIEw<?> parent,VIEw vIEw,1)">int position,1)">long ID) {24 TextVIEw textVIEw= (TextVIEw) vIEw.findVIEwByID(R.ID.tv_info);25 String msg = textVIEw.getText().toString();26 Toast.makeText(MainActivity.27 28 });29 30 }
学习一门新的语言,坚持的源头是兴趣,坚持的前方是希望。
总结以上是内存溢出为你收集整理的一起学Android之GridView全部内容,希望文章能够帮你解决一起学Android之GridView所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)