Winform中两个listbox的操作是平时比较常用的操作。

本次将以一个Winform实例来分享一下两个listbox的操作,包括:listbox添加项,项的上移下移等操作。

假设有两个listbox:一个叫listBoxCategory,这个listbox是一个包含所有建筑元素项目的项;另一个叫listBoxSelected,这个是将左边的listbox中的项选中并添加到的listbox。

<1>  Resource文件的定义:

<2>  listBox中的每一项定义:

public class CategoryItem
{
public CategoryItem(string categoryName, int categoryId)
{
CategoryName = categoryName;
CategoryId = categoryId;
}
public string CategoryName {get; set;}
public int CategoryId {get; set;}
}

<3>  listBoxCategoery在初始化时,它的每一项都是由doc.Settings.Categories提供,但是不能和listBoxSelected中的初始项冲突;listBoxSelected中的初始项由Existinglist提供

 private void listboxInitialize(Document doc)
{
List<CategoryItem> categoryitems = new List<CategoryItem>();
listBoxCategory.DisplayMember = "CategoryName";
listBoxCategory.ValueMember = "id";
listBoxSelected.DisplayMember = "CategoryName";
listBoxSelected.ValueMember = "id";
foreach (Category cat in doc.Settings.Categories)
{
bool checkreapter = false;
foreach(int defaultlistId in Existinglist)
{
if(cat.Id.IntegerValue==defaultlistId)
{
checkreapter = true; break;
}
}
if(checkreapter == false)
{
listBoxCategory.Items.Add(new CategoryItem(cat.Name, cat.Id.IntegerValue)); //防止和listBoxSelected中的项冲突
}
}
foreach (int defaultlistId in Existinglist)
{
listBoxSelected.Items.Add(new CategoryItem(doc.Settings.Categories.get_Item((BuiltInCategory)defaultlistId).Name, defaultlistId));
}
}

<4>  listBoxSeleted的上移与下移:

private void buttonUp_Click(object sender, EventArgs e)
{
int listboxLength = listBoxSelected.Items.Count;
int selectindex = listBoxSelected.SelectedIndex;
if (listBoxSelected.SelectedItem !=null)
{
if (listboxLength > selectindex && selectindex > )
{
object oTempItem = listBoxSelected.SelectedItem;
listBoxSelected.Items.RemoveAt(selectindex);
listBoxSelected.Items.Insert(selectindex - , oTempItem);
listBoxSelected.SelectedIndex = selectindex - ;
}
}
else
{
MessageBox.Show(Res.StringReminder);
}
} private void buttonDown_Click(object sender, EventArgs e)
{
int listboxLength = listBoxSelected.Items.Count;
int selectindex = listBoxSelected.SelectedIndex;
if (listBoxSelected.SelectedItem !=null)
{
if (listboxLength > selectindex && selectindex < listboxLength - )
{
object oTempItem = listBoxSelected.SelectedItem;
listBoxSelected.Items.RemoveAt(selectindex);
listBoxSelected.Items.Insert(selectindex + , oTempItem);
listBoxSelected.SelectedIndex = selectindex + ;
}
}
else
{
MessageBox.Show(Res.StringReminder);
}
}

<5> listBoxCategory中的项添加到listBoxSelected:

 private void buttonAdd_Click(object sender, EventArgs e)
{
listBoxSelected.DisplayMember = "CategoryName";
listBoxSelected.ValueMember = "id";
bool checklist = false;
if (listBoxCategory.SelectedItem !=null)
{
foreach(object obj in listBoxSelected.Items)
{
if (((CategoryItem)listBoxCategory.SelectedItem).CategoryName == ((CategoryItem)obj).CategoryName)
{
checklist = true;
break;
}
}
if(checklist==true)
{
MessageBox.Show(Res.StringRepeat);
}
else
{
for (int i = listBoxCategory.SelectedItems.Count - ; i >= ; i--)
{
listBoxCategory.SelectedItem = listBoxCategory.SelectedItems[i];
listBoxSelected.Items.Add(listBoxCategory.SelectedItem);
listBoxCategory.Items.Remove(listBoxCategory.SelectedItem);
}
} }
else
{
MessageBox.Show(Res.StringReminder);
}
}

<6> listBoxcategory中的项双击添加到listBoxSelected中:

private void listBoxCategory_DoubleClick(object sender, EventArgs e)
{
buttonAdd.PerformClick();
}

【ListBox】ListBox的相关操作的更多相关文章

  1. 从零自学Hadoop(20):HBase数据模型相关操作上

    阅读目录 序 介绍 命名空间 表 系列索引 本文版权归mephisto和博客园共有,欢迎转载,但须保留此段声明,并给出原文链接,谢谢合作. 文章是哥(mephisto)写的,SourceLink 序 ...

  2. 从零自学Hadoop(21):HBase数据模型相关操作下

    阅读目录 序 变量 数据模型操作 系列索引 本文版权归mephisto和博客园共有,欢迎转载,但须保留此段声明,并给出原文链接,谢谢合作. 文章是哥(mephisto)写的,SourceLink 序 ...

  3. 理解CSV文件以及ABAP中的相关操作

    在很多ABAP开发中,我们使用CSV文件,有时候,关于CSV文件本身的一些问题使人迷惑.它仅仅是一种被逗号分割的文本文档吗? 让我们先来看看接下来可能要处理的几个相关组件的词汇的语义. Separat ...

  4. Liunx下的有关于tomcat的相关操作 && Liunx 常用指令

    先记录以下liunx下的有关于tomcat的相关操作 查看tomcat进程: ps-ef|grep java (回车) 停止tomcat进程: kill -9 PID (进程号如77447) (回车) ...

  5. pip的相关操作

    >Python中的pip是什么?能够做些什么? pip是Python中的一个进行包管理的东西,能够下载包.安装包.卸载包......一些列操作 >怎么查看pip的相关信息 在控制台输入: ...

  6. python操作mysql数据库的相关操作实例

    python操作mysql数据库的相关操作实例 # -*- coding: utf-8 -*- #python operate mysql database import MySQLdb #数据库名称 ...

  7. php对二维数组进行相关操作(排序、转换、去空白等)

    php对二维数组进行相关操作(排序.转换.去空白等) 投稿:lijiao 字体:[增加 减小] 类型:转载 时间:2015-11-04   这篇文章主要介绍了php对二维数组进行相关操作,包括php对 ...

  8. SQL语言和DML相关操作以及相应的运算符

    SQL 1.结构化查询语言 2.特点 a.第四代编程语言,更接近自然语言 b必须有数据库系统解释执行 c.对象名,关键字不区分大小写 d.字符串必须要用单引号引起来,不能用双引号 e.每条语句最后用分 ...

  9. 如何给ActiveX控件添加“事件”“属性”“标准事件”“自定义事件”等一些相关操作

    上一篇小编带大家熟悉了一下ActiveX的建立以及相关的概念,(http://blog.csdn.net/u014028070/article/details/38424611) 本文介绍下如何给控件 ...

  10. CentOS学习笔记--基本命令--目录的相关操作

    Linux基本命令--目录的相关操作 常见的处理目录的命令吧: cd:变换目录 pwd:显示目前的目录 mkdir:创建一个新的目录 rmdir:删除一个空的目录 cd (变换目录) cd是Chang ...

随机推荐

  1. directive 指令一

    什么是Directive Directive将一段html,js封装在一起,形成一个可以复用的独立个体,具有特定的功能.angularjs中的指令通常是比较小的组件,它相当于是给我们提供了一些公共的自 ...

  2. 用Micro:bit做浇灌系统

    利用Micro:bit结合[土壤湿度感测棒]做一个简单的浇灌系统 一.测试土壤湿度感测棒 •材料:土壤湿度感测棒 (万能的淘宝上可以找到) •连接:将[土壤湿度感测棒]的一端接P0.另一端接GND 简 ...

  3. MySQL数据库之数据类型和完整性约束

    补充: select * from mysql.user #显示出来乱了 select * from mysql.user\G #加了\G后一行一行显示了 一.数据类型:分不同种类去存不同类型的数据 ...

  4. 同一个电脑配置两个Git问题

    拿到公司电脑后,正常配置gitlab,以及设置邮箱等等,可以使用公司邮箱,以及一系列设置 git config --global user.name "userName" git ...

  5. Unity Lighting - Light Probes 光照探针(十)

      Light Probes 光照探针 Only static objects are considered by Unity’s Baked or Precomputed Realtime GI s ...

  6. 【ZABBIX】Zabbix触发器的告警原理及创建方法

    概述:       触发器中的表达式使用很灵活,我们可以创建一个复杂的逻辑测试监控,触发器表达式形式如下: {<server>:<key>.<function>(& ...

  7. Python-2.7 配置tab自动补全功能

    作者博文地址:http://www.cnblogs.com/spiritman/ 之前一直使用shell编程,习惯了shell的 tab 自动补全功能,而Python的命令行却不支持 tab 自动补全 ...

  8. mac 的一些使用技巧

    1. mac有一个自带的服务器环境, 目录路径 /Library/WebServer/Documents 打开终端  a. 启动 sudo apachectl start b. 重新启动 sudo a ...

  9. Android 对话框(Dialogs)

    对话框是提示用户作出决定或输入额外信息的小窗口. 对话框不会填充屏幕,通常用于需要用户采取行动才能继续执行的模式事件. 1.对话框设计 如需了解有关如何设计对话框的信息(包括语言建议),请阅读对话框设 ...

  10. 01慕课网《进击Node.js基础(一)》Node.js安装,创建例子

    版本:偶数位为稳定版本,基数为非稳定版本 - 0.6.x - 0.7.x    - 0.8.x -0.9.x    -0.10.x  -0.11.x 概念:Node.js采用谷歌浏览器的V8引擎,用C ...