实现可以多选的ListView列表

public class TestActivity extends Activity {
/**代码中写布局的View*/
private LinearLayout mParentLinearLayout;
/**标题TextView*/
private TextView mTitleTv;
/**展示数据的ListView*/
private ListView mListView;
/**自定义的数据*/
private String[] mStrArray;
/**ListView的数据适配器*/
private ArrayAdapter<String> arrayAdapter;
/**定义一StringBuffer*/
private StringBuffer mBuffer;


@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
initViews();
initListeners();
}

private void initListeners() {
mListView.setOnItemSelectedListener(mLvOnItemSelectedListener);
mListView.setOnItemClickListener(mLvOnItemClickListener);
}

private void initViews() {
/**初始化mParentLinearLayout*/
mParentLinearLayout = new LinearLayout(TestActivity.this);
/**设置布局宽高*/
LinearLayout.LayoutParams mLayoutParams = new LinearLayout.LayoutParams(LinearLayout.LayoutParams.MATCH_PARENT, LinearLayout.LayoutParams.WRAP_CONTENT);
/**布局排列方式*/
mParentLinearLayout.setOrientation(LinearLayout.VERTICAL);
/**背景*/
mParentLinearLayout.setBackgroundColor(Color.parseColor("#F0F0F0"));


mTitleTv = new TextView(TestActivity.this);
mTitleTv.setLayoutParams(mLayoutParams);
mTitleTv.setText("请选择列表数据!");
mTitleTv.setTextColor(Color.BLACK);
/**往布局中添加TextView*/
mParentLinearLayout.addView(mTitleTv);


mListView = new ListView(TestActivity.this);
mListView.setLayoutParams(mLayoutParams);
mListView.setBackgroundColor(Color.LTGRAY);
mBuffer = new StringBuffer();
mStrArray = new String[] { "January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December" };
arrayAdapter = new ArrayAdapter<String>(TestActivity.this, android.R.layout.simple_list_item_multiple_choice, mStrArray);
/**设置ListView的选择模式*/
mListView.setChoiceMode(ListView.CHOICE_MODE_MULTIPLE);
mListView.setAdapter(arrayAdapter);
/**往布局中添加ListView*/
mParentLinearLayout.addView(mListView);
setContentView(mParentLinearLayout);
}


private OnItemSelectedListener mLvOnItemSelectedListener = new OnItemSelectedListener() {


public void onItemSelected(AdapterView<?> arg0, View arg1, int arg2, long arg3) {
/**选中后的操作*/
mBuffer.append(arg0.getItemAtPosition(arg2).toString() + "-");
mTitleTv.setText(mBuffer.toString());
}

public void onNothingSelected(AdapterView<?> arg0) {

}
};
OnItemClickListener mLvOnItemClickListener = new OnItemClickListener() {

public void onItemClick(AdapterView<?> arg0, View arg1, int arg2, long arg3) {
/**点击后的操作*/
mBuffer.append(arg0.getItemAtPosition(arg2).toString() + "");
mTitleTv.setText(mBuffer.toString());
/**还可以判断,如果已经选中,点击的话应该表示不选中*/
}
};
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Flutter中的`ListView`并不支持多选,但我们可以通过自定义`ListView`来实现多选功能。 首先,我们需要定义一个数据模型类,来表示每一个列表项。这个类至少需要包含两个属性:`title`和`selected`,分别表示列表项的标题和是否被选中。 ```dart class ListItem { String title; bool selected; ListItem({this.title, this.selected = false}); } ``` 然后,我们可以使用`ListView.builder`来构建列表。在构建列表项时,我们需要根据`selected`属性来决定是否显示选中状态的图标。 ```dart ListView.builder( itemCount: items.length, itemBuilder: (BuildContext context, int index) { return InkWell( onTap: () { setState(() { items[index].selected = !items[index].selected; }); }, child: Row( children: [ Checkbox( value: items[index].selected, onChanged: (_) { setState(() { items[index].selected = !items[index].selected; }); }, ), Text(items[index].title), if (items[index].selected) Icon(Icons.check), ], ), ); }, ) ``` 在以上代码中,使用了`InkWell`组件来监听列表项的点击事件,并在点击时修改`selected`属性。同时,使用了`Checkbox`组件来实现选中状态的切换,当然你也可以使用其他组件来替代它。 最后,我们需要在`State`类中维护一个`items`列表来存储所有的列表项。在多选操作完成后,我们可以通过遍历`items`列表来获取所有被选中的列表项。 ```dart List<ListItem> items = [ ListItem(title: 'Item 1'), ListItem(title: 'Item 2'), ListItem(title: 'Item 3'), ]; List<ListItem> getSelectedItems() { return items.where((item) => item.selected).toList(); } ``` 这样,我们就完成了一个基本的多选列表。当然,你还可以为列表项添加更多的属性和功能,让它更加丰富和实用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值