zoukankan      html  css  js  c++  java
  • Android实现九宫格

    本文需要添加/修改3个文件:main.xml、meunitem.xml、Java源代码。 

    main.xml源代码如下,本身是个GirdView,用于装载Item: 

    <?xml version="1.0" encoding="utf-8"?> 
    <GridView xmlns:
    Android="http://schemas.android.com/apk/res/android" 
      android:id="@+id/GridView" 
      android:layout_width="fill_parent" 
      android:layout_height="fill_parent" 
      android:numColumns="auto_fit" 
      android:horizontalSpacing="10dp" 
      android:verticalSpacing="10dp" 
      android:columnWidth="90dp" 
      android:stretchMode="columnWidth" 
      android:gravity="center"></GridView> 

    介绍一下里面的某些属性: 

    android:numColumns="auto_fit" ,GridView的列数设置为自动 

    android:columnWidth="90dp",每列的宽度,也就是Item的宽度 
    android:stretchMode="columnWidth",缩放与列宽大小同步 
    android:verticalSpacing="10dp",两行之间的边距,如:行一(NO.0~NO.2)与行二(NO.3~NO.5)间距为10dp 
    android:horizontalSpacing="10dp",两列之间的边距。 


    接下来介绍 meunitem.xml,这个XML跟前面ListView的ImageItem.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="wrap_content" 

    <ImageView  android:layout_width="wrap_content" 
        android:id="@+id/ItemImage" 
        android:layout_height="wrap_content" 
        android:layout_centerHorizontal="true"/> 
    <TextView   android:layout_width="wrap_content" 
    android:layout_height="wrap_content" 
    android:layout_below="@+id/ItemImage" 
    android:id="@+id/ItemText" 
    android:layout_centerHorizontal="true" 
    /> 
    </RelativeLayout> 

    最后是JAVA的源代码 

    @Override 
    protected void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.mainmenu); 

    GridView gridview = (GridView) findViewById(R.id.GridView); 
    ArrayList<HashMap<String, Object>> meumList = new ArrayList<HashMap<String, Object>>(); 

    for(int i = 1;i < 10;i++) { 
    HashMap<String, Object> map = new HashMap<String, Object>(); 
    map.put("ItemImage", R.drawable.icon); 
    map.put("ItemText", "NO."+i); 
    meumList.add(map); 


    SimpleAdapter saMenuItem = new SimpleAdapter(this, 
      meumList, //数据源 
      R.layout.menuitem, //xml实现 
      new String[]{"ItemImage","ItemText"}, //对应map的Key 
      new int[]{R.id.ItemImage,R.id.ItemText});  //对应R的Id 

    //添加Item到网格中 
    gridview.setAdapter(saMenuItem); 
    gridview.setOnItemClickListener(new OnItemClickListener() { 
    public void onItemClick(AdapterView<?> arg0, View arg1, int arg2,long arg3) { 
                                            System.out.println("click index:"+arg2); 


    ); 

      
    附上 
     
    效果图:
     
    源代码下载:GirdViewDemo
    欢迎光临小站 好岸园 http://www.hopean.com
  • 相关阅读:
    sftp服务器搭建以及挂载新硬盘到home目录下
    做题小技巧
    18年2月份股市大跌感想
    使用docker配置laravel5.5环境
    git tag、gitignore和git撤销提交
    Tmux 学习
    rman异常案例二: 归档日志被人移动到其他目录,导致数据库恢复异常(续)
    tasklet与workqueue的区别和不同应用环境总结
    [置顶] Jquery网页打印
    svn服务器搭建和使用:Custom action GenerateSSLKey failed: Command terminated with non-zero exit code
  • 原文地址:https://www.cnblogs.com/hopeanCom/p/2845431.html
Copyright © 2011-2022 走看看