Responding to custom property changes.

  • Thread starter Thread starter Guest
  • Start date Start date
G

Guest

I have implemented DashStyle and LineThickness for custom circle control as
follows:

Public Property DashStyle() As DashStyle
Get
Return m_DashStyle
End Get
Set(ByVal Value As DashStyle)
m_DashStyle = Value
End Set
End Property

<DefaultValue(1)> _
Public Property LineThickness() As Integer
Get
Return m_intLineThickness
End Get
Set(ByVal Value As Integer)
m_intLineThickness = Value
End Set
End Property

Now how can I make changes to these property take effect at design and run
time.

At design time any changes to these two property doesn’t take effect. The
circle remains same at design time.
 
How do you draw the circle? If you do it in Paint event then you could trigger
it by calling Invalidate() method after the property changes, i.e.
....
Set(ByVal Value As DashStyle)
m_DashStyle = Value
Invalidate()
End Set
 
Thanks Alexander.

Someone suggested me using Refresh() method after property changes. Does
refresh works differently from invalidate()?
 
Thanks Alexander.
Someone suggested me using Refresh() method after property changes.
Does refresh works differently from invalidate()?

This is what Refresh does:

public virtual void Refresh()
{
this.Invalidate(true);
this.Update();
}

It marks the control as invalid and then forces the redraw, while just calling
Invalidate() "enqeues" the redraw.

I guess there's no real difference in your case.

Alexander
 
Thanks

Alexander Shirshov said:
This is what Refresh does:

public virtual void Refresh()
{
this.Invalidate(true);
this.Update();
}

It marks the control as invalid and then forces the redraw, while just calling
Invalidate() "enqeues" the redraw.

I guess there's no real difference in your case.

Alexander
 
Back
Top