研究好久,想实现自定义属性变更后图片也随之变更。
由于是组合控件(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);
}
}