listView隔行换色多选

2024-08-26 10:08
文章标签 listview 多选 隔行 换色

本文主要是介绍listView隔行换色多选,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

参照网上相关文章写了下listview隔行换色与多选

1.item_fg_seclib.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="match_parent"
        android:layout_height="wrap_content" 
        >
<LinearLayout 
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
         android:minHeight="40dp"
          android:gravity="center_vertical"
        >
        <LinearLayout
            android:layout_width="0dp"
            android:layout_weight="1"
            android:layout_height="match_parent"
            android:gravity="center_vertical"
             >


            <CheckBox
                android:id="@+id/itemCbox"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:textColor="@color/blue"
                android:text=""
                />


            <TextView
                 android:id="@+id/itemName"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:gravity="left"
                android:text="@string/pro_name" 
                android:textColor="@color/blue"/>


        </LinearLayout>
        <TextView
            android:id="@+id/itemSn"
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:text="@string/pro_Bid" 
            android:layout_weight="1"
            android:gravity="center"
            android:textColor="@color/blue"/>


        <TextView
            android:id="@+id/itemStatus"
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:text="@string/status"
            android:layout_weight="1" 
            android:gravity="right"
            android:paddingRight="@dimen/h8"
            android:textColor="@color/blue"/>


    </LinearLayout>
    </LinearLayout>

2.SecUpLoadAdapter:

public class SecUpLoadAdapter extends BaseAdapter {
private Context context;
private ArrayList<ProductItemInfo> list;
private static HashMap<Integer, Boolean> isSelected;
class Viewholder{
CheckBox itemCbox;
TextView itemName;
TextView itemSn;
TextView itemStatus;
}
public SecUpLoadAdapter(Context context,ArrayList<ProductItemInfo> list){
this.context=context;
this.list=list;
isSelected=new HashMap<Integer, Boolean>();
initData();
}
private void initData() {
for (int i = 0; i < list.size(); i++) {
getIsSelected().put(i, false);
}

}
@Override
public int getCount() {
return list.size();
}
@Override
public ProductItemInfo getItem(int arg0) {
return list.get(arg0);
}
@Override
public long getItemId(int arg0) {
// TODO Auto-generated method stub
return 0;
}
@Override
public View getView(final int position, View convertView, ViewGroup viewGroup) {
Viewholder holder=null;
ProductItemInfo productItemInfo=list.get(position);
if(convertView==null){
convertView=View.inflate(context, R.layout.item_fg_seclib,null);
holder=new Viewholder();
holder.itemCbox=(CheckBox)convertView.findViewById(R.id.itemCbox);
holder.itemSn=(TextView)convertView.findViewById(R.id.itemSn);
holder.itemStatus=(TextView)convertView.findViewById(R.id.itemStatus);
convertView.setTag(holder);
}else{
holder=(Viewholder) convertView.getTag();
}
holder.itemCbox.setOnCheckedChangeListener(new OnCheckedChangeListener() {

@Override
public void onCheckedChanged(CompoundButton arg0, boolean arg1) {
getIsSelected().put(position,arg0.isChecked());
notifyDataSetChanged();
}
});

if(position%2==1){
convertView.setBackgroundColor(context.getResources().getColor(R.color.gray_verylight));
}else{
convertView.setBackgroundColor(context.getResources().getColor(R.color.white));
}
holder.itemCbox.setChecked(getIsSelected().get(position));
String status=null;
if(productItemInfo.getStatus()==false){
status = context.getResources().getString(R.string.un_upload);
}else{
status=context.getResources().getString(R.string.upload);
}
holder.itemStatus.setText(status);
return convertView;
}
public static HashMap<Integer, Boolean> getIsSelected() {
return isSelected;
}


public static void setIsSelected(HashMap<Integer, Boolean> isSelected) {
SecUpLoadAdapter.isSelected = isSelected;
}


/**
* 设置取消或全选
* @param flag
*/
public void setOptionAll(boolean flag){
for (int i = 0; i < isSelected.size(); i++) {
isSelected.put(i, flag);
}
notifyDataSetChanged();
}
}


3.Activity里调用

cbCheckAll=(CheckBox)rootView.findViewById(R.id.secLibCbox);

 ArrayList<ProductItemInfo> data=new ArrayList<ProductItemInfo>();
for (int i = 0; i < 1000; i++) {
ProductItemInfo info=new ProductItemInfo();
info.setId(i);
info.setName("商品"+i);
info.setSelected(false);
info.setSn("1000"+i);
if(i%2==1){
info.setStatus(false);
}else{
info.setStatus(true);
}
data.add(info);
}
adapter = new SecUpLoadAdapter(ac, data);
ArrayAdapter<String> adapter2=new ArrayAdapter<String>(ac, android.R.layout.simple_list_item_1,data2);
unUploadLv.setAdapter(adapter);


cbCheckAll.setOnCheckedChangeListener(new OnCheckedChangeListener() {

@Override
public void onCheckedChanged(CompoundButton arg0, boolean arg1) {
adapter.setOptionAll(arg0.isChecked());
}
});


这篇关于listView隔行换色多选的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1108257

相关文章

listview与复选框的合并使用

在使用listview的过程中,我们常常需要使用复选框,实现一些批处理功能。这时候我们需使用自定义的adapter,实现相关复选框的事件响应。      首先在adapter定义一个哈希表,用于存放复选框的选中情况:      如private static HashMap<String,Boolean> isSelected,private static HashMap<Inter

简单的android Listview使用例子

为了熟悉Listview的使用,做了一个小例子联系一下, 主要步骤: 1. 在MainActivity中,创建一个adapter对象(可以是android自带的ArrayAdapter,也可以是自定义的如SongAdapter) 2. 如果自定义,就要创建ListView的子项,如song_listview_item.xml 3. 创建ListView对象,并用setAdapter方法把a

兔子--计算listview的高度,解决listview与scrollview控件冲突

/** * 计算ListView的高度 * * @param listView */ public void setListViewHeightBasedOnChildren(ListView listView) { // 获取ListView对应的Adapter OrderGoodsAdapter listAdapter = (OrderGoodsAdapter) listView.getAda

Flutter-单选和多选

import 'package:flutter/material.dart';//单选和多选void main() => runApp(MaterialApp(home: _home(),));class _home extends StatefulWidget {@overrideState<StatefulWidget> createState() {// TODO: implement

Flutter-listview的item左右滑动,删除item

import 'package:flutter/material.dart';//列表左右滑动删除void main() =>runApp(MaterialApp(home: HomePage(),));class HomePage extends StatelessWidget {final List<String> items = List.generate(20, (index) =>

自定义布局实现listview上拉加载下拉刷新

listview布局有时加载数据偏多,需要上拉加载第二页等更多数据,下拉刷新数据等功能,也有开源的框架XRefreshView ,可以参考http://www.w2bc.com/Article/44291,当初开发项目时,便于自己控制,就自定义布局实现这功能。 1、自定义布局用来管理三个子控件:下拉头,包含内容的自定义listview,上拉头(代码有详细介绍) public class Pul

NM_LISTVIEW结构

NM_LISTVIEW结构.该结构用于存储列表视图的通知消息的有关信息,大部分列表视图的通知消息都会附带指向该结构的指针.NM_LISTVIEW的定义为  typedef   struct   tagNM_LISTVIEW   {    NMHDR   hdr;   //标准的NMHDR结构  int   iItem;   //表项的索引,若为-1则无效

【ListView】有关填充bug

假设要实现如下效果 ListView里若使用RelativeLayot则会出现错误 得不到垂直线的填充 线性布局的高度设置为match_parent会使高度为0,必须给它一个固定值,比如20dp ListView建议使用LinearLayout在最外层,而最外层的宽高无论如何设置都无法确定的,建议第二层也使用linearLayout来布局 【实现

ListView数据只有显示不全bug

Android编程中,ScrollView嵌套ListView时,会无法正确的计算ListView的大小。解决的办法有如下两种: 解决方案1: 直接把包含ListView控件的ScrollView控件从布局文件中去除,留下ListView控件,这是最简单快捷的解决办法,如果一定要在ScrollView中包含ListView,则参考解决方案2:

ScrollView嵌套listview滑动位置底部bug

三种方案,个人推荐第三种: 1 sv.fullScroll(ScrollView.FOCUS_UP); 2 sv.setScrollY(0); 3 sv.smoothScrollTo(0,20); 滑动冲突解决listView: public class ListViewForScrollView extends ListView {public ListVie