zoukankan      html  css  js  c++  java
  • GridView, ListView 区别

    ListView, GridView部分的类层次结构
    AbsListView的xml属性 android:listSelector 当前item高亮时,显示的drawable


    android:drawSelectorOnTop 是否将selector显示在item的上方


    android:fastScrollEnabled 是否启动快速滚动。


    android:cacheColorHint 缓存颜色提示。它的值是一个颜色值,如#FFF,#FFFFFF等。

    【注意:最好要将这个属性设为@null或这与你背景颜色相同,不然你会看到意想不到的情况,后面有介绍】

    设置该值时,就提示列表,现在是绘制在一个纯色的、不透明的背景上的,以让列表优化绘制。
    android:scrollingCache 是否使用滚动缓存。

    设为true时,会在滚动过程中使用一个drawing cache,这样能使绘制变得更快,但会使用更多的内存。

    设为false时,就是不使用缓存。


    android:smoothScrollbar 是否平滑滚动条。

    设为true时,会更以更精确的方式计算滚动条大小,并且在滚动的过程中,实时的会对滚动条的大小进行计算。(所以如果各条数据的高度不一致时,会很耗性能,最好设为false)。

    设为false时,以粗略的方式来计算滚动条的大小(根据当前有多少条数据)。
    android:stackFromBottom 是否将内容从最后一个显示到第一个,并将滚动条放在最底部。
    android:transcriptMode

    改写模式,它的值可以为disabled,normal,alwaysScroll

    disabled时,在adapter的内容发生改变时,滚动条不发生变化

    normal时,当收到notifyDataSetChanged等提示时,只有内容发生改变时(例如增加了一个条目),滚动条会自动滚到底部

    alwaysScroll,当收到notifyDataSetChanged等提示时,不管内容改不改变,滚动条都将滚至底部


    android:textFilterEnabled 是否启用内容过滤。

    设为true时,会根据当前输入的文本,对列表内容进行过滤。


    android:cacheColorHint可能会引起的问题

    Xml代码 复制代码 收藏代码
     
    <LinearLayout
    	xmlns:android="http://schemas.android.com/apk/res/android"
    	android:layout_width="fill_parent"
    	android:layout_height="fill_parent"
    	android:orientation="vertical"
    	android:background="#0F0"
    	android:paddingTop="20dp"
    >		
    	<ListView
    		android:id="@+id/listview1"
    		android:layout_width="fill_parent"
    		android:layout_height="fill_parent" />
    </LinearLayout>
    

    【注意:布局的背景色是绿色,有20dp的padding,ListView没有设置android:cacheColorHint。意外就是拖动时,会出现黑色背景】

    引起这个的主要原因就是: 默认的ListItem背景是透明的,它在滚动的过程中会与android:cacheColorHint的颜色值进行混合,在黑色主题下默认的颜色值是#191919。

    解决解决办法就是将其设为透明或者与背景相同的颜色

    android:cacheColorHint="@null"

    GridView xml属性

    android:columnWidth

    列宽(一般与numColumns="auto_fit"配合使用,如果numColumns设置为具体的值时,其不起作用)
    android:gravity item

    在item container中如何放置(类似于TextView的gravity是决定text如何在TextView中如何放置)。


    android:horizontalSpacing

    水平空白


    android:numColumns

    列数。其值可以是具体值(如:100dp),也可以值auto_fit(根据GridView的宽度以及columnWidth来确定列数)


    android:stretchMode

    缩放模式。其值可以为:none, spacingWidth, columnWidht, spacingWidthUniform


    android:verticalSpacing

    垂直空白


    GridView其实也可以表现的像ListView,只要将其列设为1列 使用ArrayAdapter的GridView

     
    R.layout.activity_gridview_use
    <merge
    	xmlns:android="http://schemas.android.com/apk/res/android">
    	<GridView
    			android:id="@+id/gridview"
    			android:layout_width="fill_parent"
    			android:layout_height="fill_parent"
    			android:numColumns="auto_fit"
    			android:columnWidth="100dp" 
    			android:horizontalSpacing="20dp"
    			android:verticalSpacing="20dp" />
    </merge>		
    		
    		
    public class GridViewUse extends Activity {
    	@Override
    	protected void onCreate(Bundle savedInstanceState) {
    		super.onCreate(savedInstanceState);
    		setContentView(R.layout.activity_gridview_use);
    		GridView gridView = (GridView) findViewById(R.id.gridview);
    		ArrayAdapter<String> gridAdapter = new ArrayAdapter<String>(getApplicationContext(),
    				android.R.layout.simple_list_item_1, android.R.id.text1);
    		gridAdapter.add("one");
    		gridAdapter.add("two");
    		gridAdapter.add("three");
    		gridAdapter.add("four");
    		gridAdapter.add("five");
    		gridView.setAdapter(gridAdapter);
    	}
    }
    

    使用SimpleAdapter的GridView

    R.layout.item_image_text
    <LinearLayout
    	xmlns:android="http://schemas.android.com/apk/res/android"
    	android:layout_width="wrap_content"
    	android:layout_height="wrap_content"
    	android:orientation="vertical"
    >
    	<ImageView
    	    android:id="@+id/image"
    	    android:layout_width="wrap_content"
    	    android:layout_height="wrap_content"
    	    android:scaleType="fitCenter" />
    	
    	<TextView
    	    android:id="@+id/text"
    	    android:layout_width="wrap_content"
    	    android:layout_height="wrap_content"
    	    android:textColor="#FFF" />
    </LinearLayout>
    
    
    private static final String[] FROM = {"image", "text"};
    private static final int[] TO = {R.id.image, R.id.text};
    private static final List<HashMap<String, Object>> DATA = 
    		new ArrayList<HashMap<String, Object>>();
    	
    public class GridViewUse extends Activity {
    	@Override
    	protected void onCreate(Bundle savedInstanceState) {
    		super.onCreate(savedInstanceState);
    		setContentView(R.layout.activity_gridview_use);
    		GridView gridView = (GridView) findViewById(R.id.gridview);
    		HashMap<String, Object> item;
    		// item1
    		item = new HashMap<String, Object>();
    		item.put("image", R.drawable.ic_launcher);
    		item.put("text", "item1");
    		DATA.add(item);
    		// item2
    		item = new HashMap<String, Object>();
    		item.put("image", R.drawable.ic_launcher);
    		item.put("text", "item2");
    		DATA.add(item);
    		// item3
    		item = new HashMap<String, Object>();
    		item.put("image", R.drawable.ic_launcher);
    		item.put("text", "item3");
    		DATA.add(item);
    		
    		SimpleAdapter gridAdapter = new SimpleAdapter(getApplicationContext(), DATA, 
    				R.layout.item_image_text, FROM, TO);
    		gridView.setAdapter(gridAdapter);
    	}
    }
    



    ListView xml属性

    android:choiceMode

    选择行为的设置。可以设置的值none(默认),singleChoice(一个数据可以处于选中状态),multipleChoice(多个数据可以处于选中状态)


    android:divider

    数据间的分隔线。颜色或drawable


    android:dividerHeight

    分隔线的高度。


    android:entries

    列表的数据。值为一个数组资源值。


    android:footerDividersEnabled footer

    view间是否使用分隔线


    android:headerDividersEnabled

    header view间是否使用分隔线


    其他参考 ListView应该注意的地方:http://gundumw100.iteye.com/blog/1169065

  • 相关阅读:
    SELECT INTO 和 INSERT INTO SELECT 两种表复制语句
    Oracle中如何插入特殊字符: &amp;amp; 和 &amp;#39; (多种解决方案)
    oracle学习链接
    ORACLE中的游标Cursor总结
    SVN使用教程总结
    SVN使用教程之-分支/标记 合并 subeclipse
    weblogic启动 web应用ssh关闭 nohup命令
    Oracle 学习之:ASCII,CHR函数的作用和用法
    Oracle数据库单表循环提取输出
    设计模式-七大原则
  • 原文地址:https://www.cnblogs.com/navy-wang/p/3285049.html
Copyright © 2011-2022 走看看