C# 事件错误地触发 Windows 窗体

发布于 2024-10-15 02:58:50 字数 3186 浏览 7 评论 0原文

我试图了解这里发生了什么。我有一个 CheckedListBox,其中包含一些勾选的项目和一些未勾选的项目。我正在尝试找到一种方法来确定控件选择中的增量。我已经尝试过一些像这样的麻烦 - 但只能在部分时间起作用,我确信有一个更优雅的解决方案。一个可能相关的问题是 myCheckBox_ItemCheck 事件在表单加载时触发 - 在我有机会执行 ItemCheck 之前。到目前为止,这是我所拥有的:

    void clbProgs_ItemCheck(object sender, ItemCheckEventArgs e)
    {
         // i know its awful

        System.Windows.Forms.CheckedListBox cb = (System.Windows.Forms.CheckedListBox)sender;

        string sCurrent = e.CurrentValue.ToString();
        int sIndex = e.Index;
        AbstractLink lk = (AbstractLink)cb.Items[sIndex];

        List<ILink> _links = clbProgs.DataSource as List<ILink>;

        foreach (AbstractLink lkCurrent in _links)
        {

            if (!lkCurrent.IsActive)
            {
                if (!_groupValues.ContainsKey(lkCurrent.Linkid))
                {
                    _groupValues.Add(lkCurrent.Linkid, lkCurrent);
                }
            }
        }

        if (_groupValues.ContainsKey(lk.Linkid))
        {
            AbstractLink lkDirty = (AbstractLink)lk.Clone();

            CheckState newValue = (CheckState)e.NewValue;
            if (newValue == CheckState.Checked)
            {
                lkDirty.IsActive = true;

            }
            else if (newValue == CheckState.Unchecked)
            {
                lkDirty.IsActive = false;
            }

            if (_dirtyGroups.ContainsKey(lk.Linkid))
            {
                _dirtyGroups[lk.Linkid] = lkDirty;
            }
            else
            {
                CheckState oldValue = (CheckState)e.NewValue;
                if (oldValue == CheckState.Checked)
                {
                    lkDirty.IsActive = true;

                }
                else if (oldValue == CheckState.Unchecked)
                {
                    lkDirty.IsActive = false;
                }

                _dirtyGroups.Add(lk.Linkid, lk);
            }

        }
        else
        {
            if (!lk.IsActive)
            {
                _dirtyGroups.Add(lk.Linkid, lk);
            }
            else
            {
                _groupValues.Add(lk.Linkid, lk);
            }
        }
    }

然后单击保存按钮 - 我在发送到数据库之前检查更改的内容:

    private void btSave_Click(object sender, EventArgs e)
    {

        List<AbstractLink> originalList = new List<AbstractLink>(_groupValues.Values);
        List<AbstractLink> changedList = new List<AbstractLink>(_dirtyGroups.Values);

        IEnumerable<AbstractLink> dupes = originalList.ToArray<AbstractLink>().Intersect(changedList.ToArray<AbstractLink>());

        foreach (ILink t in dupes)
        {
            MessageBox.Show("Changed");
        }
        if (dupes.Count() == 0)
        {
            MessageBox.Show("No Change");
        }
    }

了解更多信息。 AbstractLink 类型的定义使用:

    public bool Equals(ILink other)
    {
        if (Object.ReferenceEquals(other, null)) return false;
        if (Object.ReferenceEquals(this, other)) return true;
        return IsActive.Equals(other.IsActive) && Linkid.Equals(other.Linkid);
    }

I'm trying to understand what's happening here. I have a CheckedListBox which contains some ticked and some un-ticked items. I'm trying to find a way of determining the delta in the selection of controls. I've tried some cumbersome like this - but only works part of the time, I'm sure there's a more elegant solution. A maybe related problem is the myCheckBox_ItemCheck event fires on form load - before I have a chance to perform an ItemCheck. Here's what I have so far:

    void clbProgs_ItemCheck(object sender, ItemCheckEventArgs e)
    {
         // i know its awful

        System.Windows.Forms.CheckedListBox cb = (System.Windows.Forms.CheckedListBox)sender;

        string sCurrent = e.CurrentValue.ToString();
        int sIndex = e.Index;
        AbstractLink lk = (AbstractLink)cb.Items[sIndex];

        List<ILink> _links = clbProgs.DataSource as List<ILink>;

        foreach (AbstractLink lkCurrent in _links)
        {

            if (!lkCurrent.IsActive)
            {
                if (!_groupValues.ContainsKey(lkCurrent.Linkid))
                {
                    _groupValues.Add(lkCurrent.Linkid, lkCurrent);
                }
            }
        }

        if (_groupValues.ContainsKey(lk.Linkid))
        {
            AbstractLink lkDirty = (AbstractLink)lk.Clone();

            CheckState newValue = (CheckState)e.NewValue;
            if (newValue == CheckState.Checked)
            {
                lkDirty.IsActive = true;

            }
            else if (newValue == CheckState.Unchecked)
            {
                lkDirty.IsActive = false;
            }

            if (_dirtyGroups.ContainsKey(lk.Linkid))
            {
                _dirtyGroups[lk.Linkid] = lkDirty;
            }
            else
            {
                CheckState oldValue = (CheckState)e.NewValue;
                if (oldValue == CheckState.Checked)
                {
                    lkDirty.IsActive = true;

                }
                else if (oldValue == CheckState.Unchecked)
                {
                    lkDirty.IsActive = false;
                }

                _dirtyGroups.Add(lk.Linkid, lk);
            }

        }
        else
        {
            if (!lk.IsActive)
            {
                _dirtyGroups.Add(lk.Linkid, lk);
            }
            else
            {
                _groupValues.Add(lk.Linkid, lk);
            }
        }
    }

Then onclick of a save button - I check whats changed before sending to database:

    private void btSave_Click(object sender, EventArgs e)
    {

        List<AbstractLink> originalList = new List<AbstractLink>(_groupValues.Values);
        List<AbstractLink> changedList = new List<AbstractLink>(_dirtyGroups.Values);

        IEnumerable<AbstractLink> dupes = originalList.ToArray<AbstractLink>().Intersect(changedList.ToArray<AbstractLink>());

        foreach (ILink t in dupes)
        {
            MessageBox.Show("Changed");
        }
        if (dupes.Count() == 0)
        {
            MessageBox.Show("No Change");
        }
    }

For further info. The definition of type AbstractLink uses:

    public bool Equals(ILink other)
    {
        if (Object.ReferenceEquals(other, null)) return false;
        if (Object.ReferenceEquals(this, other)) return true;
        return IsActive.Equals(other.IsActive) && Linkid.Equals(other.Linkid);
    }

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

做个少女永远怀春 2024-10-22 02:58:50

我认为在 ItemCheck 事件中执行此操作没有什么意义。只需在保存时计算增量即可。消除了一堆代码和虚假事件带来的麻烦。

There's little point that I see to do this in the ItemCheck event. Just calculate the delta when you save. Cuts out a bunch of code and trouble with spurious events.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文