C# 自定义控件实现ChackBox的Checked效果

研究好久,想实现自定义属性变更后图片也随之变更。
由于是组合控件(pictureBox、lable)两个控件组成。
实现效果Checked属性发生变更true(false)显示不同的两个图片。
下面的代码只能实现点击控件发生的变化,实际上更改图片说明
这里的属性不会变更图片。目前想实现图中的属性true(false)变更后图片也随之变更

图片说明

    public partial class CheckedExChagedEventArgs : UserControl
    {
        public delegate void ClickEventHandler(object sender, EventArgs e);
        public new event ClickEventHandler Click;

        public CheckedExChagedEventArgs()
        {
            InitializeComponent();
        }
        /// <summary>
        /// 与控件关联的文本
        /// </summary>
        [DefaultValue("")]
        [DisplayName("文本内容")]
        [Description("属性:L_Text")]
        public string L_Text
        {
            get { return l_box.Text; }
            set { l_box.Text = value; }
        }
        [Category("重要属性")]
        [Description("组件是否处于选中状态")]
        public bool Checked { get; set; }

        public void ChackBox_MouseDown(object sender, MouseEventArgs e)
        {
            if (Checked)
            {
                Checked = false;
                p_chack.BackgroundImage = Properties.Resources.未选中;
            }
            else
            {
                Checked = true;
                p_chack.BackgroundImage = Properties.Resources.选中;
            }
        }

        private void ChackBox_Click(object sender, EventArgs e)
        {
            this.Refresh();
            this.Click?.Invoke(this, e);
        }
    }

那你不能直接{get;set;}
你要写成
private bool checkEd;
[Category("重要属性")]
[Description("组件是否处于选中状态")]
public bool Checked
{
get
{
return this.checkEd;
}
set
{
p_chack.BackgroundImage = value ? Properties.Resources.选中 : Properties.Resources.未选中;
checkEd = value;
}
}