zoukankan      html  css  js  c++  java
  • 跨线程为控件赋值并保持listview选中状态以及在可见区域显示

    本例主要功能为跨线程为控件赋值,并且实现listview控件保持选中状态以及在可见区域显示

            /// <summary>
            /// 为控件赋值的委托
            /// </summary>
            /// <param name="realTimeRecord"></param>
            delegate void SetListViewCallback2(List<CheckedItRecord> checkedItRecordList);

           int itemIndex = -1;//初始化listview选中项的索引

    #region 跨线程绑定发布列表
    /// <summary>
    /// 跨线程绑定发布列表
    /// </summary>
    /// <param name="realTimeRecord"></param>
    private void SetListViewPublish(List<CheckedItRecord> checkedItRecordList)
    {
    // InvokeRequired需要比较调用线程ID和创建线程ID
    // 如果它们不相同则返回true
    if (this.listViewPublish.InvokeRequired)
    {
    SetListViewCallback2 d
    = new SetListViewCallback2(SetListViewPublish);
    this.Invoke(d, new object[] { checkedItRecordList });
    }
    else
    {
    listViewPublish.Items.Clear();
    foreach (CheckedItRecord checkedItRecord in checkedItRecordList)
    {
    ListViewItem lvitem
    = new ListViewItem();
    lvitem.Tag
    = checkedItRecord.DeviceID.ToString();
    lvitem.SubItems[
    0].Text = (Convert.ToString(checkedItRecord.BeginTime));
    lvitem.SubItems.Add(Convert.ToString(checkedItRecord.EndTime));
    lvitem.SubItems.Add(checkedItRecord.Editor);
    List
    <CommonInfo> stateInfoListTemp = stateInfoList.FindAll(delegate(CommonInfo obj) { return obj.Code == Convert.ToString((int)checkedItRecord.SendState); });
    lvitem.SubItems.Add(stateInfoListTemp[
    0].Type);
    lvitem.SubItems.Add(checkedItRecord.EditTime);
    lvitem.SubItems.Add(Convert.ToString(checkedItRecord.SendTime));
    lvitem.SubItems.Add(checkedItRecord.SendInfoID.ToString());
    lvitem.SubItems.Add(checkedItRecord.InfoID.ToString());
    listViewPublish.Items.Add(lvitem);
    }
    if (this.itemIndex != -1)
    {
    //保证listview选中状态及可见性
    this.listViewPublish.Items[this.itemIndex].Selected = true;
    this.listViewPublish.Items[this.itemIndex].EnsureVisible();
    }
    }
    }
    #endregion
  • 相关阅读:
    Angular5的new feature
    Angular集成UEditor
    Angular集成admin-lte框架
    Angular TypeScript开发环境集成jQuery扩展插件
    如何在 Docker 容器中运行 Kali Linux 2.0
    信息系统安全等级保护基本要求
    Angular学习笔记
    Ubuntu16.04部署phantomjs的一个问题
    仿探探卡片滑动vue封装并发布到npm
    使用vscode,新建.vue文件,tab自动生成vue代码模板
  • 原文地址:https://www.cnblogs.com/smartsensor/p/2031835.html
Copyright © 2011-2022 走看看