namespace System.Windows.Forms {
[DefaultProperty("Text")]
+#if NET_2_0
+ [DefaultEvent("MouseDoubleClick")]
+#else
[DefaultEvent("MouseDown")]
+#endif
[Designer ("System.Windows.Forms.Design.NotifyIconDesigner, " + Consts.AssemblySystem_Design, "System.ComponentModel.Design.IDesigner")]
[ToolboxItemFilter("System.Windows.Forms", ToolboxItemFilterType.Allow)]
- public sealed class NotifyIcon : System.ComponentModel.Component {
+ public sealed class NotifyIcon : Component {
#region Local Variables
private ContextMenu context_menu;
private Icon icon;
#endregion // Local Variables
#region NotifyIconWindow Class
- internal class NotifyIconWindow : Control {
+ internal class NotifyIconWindow : Form {
NotifyIcon owner;
Rectangle rect;
is_visible = false;
rect = new Rectangle(0, 0, 1, 1);
- CreateControl();
+ FormBorderStyle = FormBorderStyle.None;
+
+ //CreateControl();
- Paint += new PaintEventHandler(HandlePaint);
SizeChanged += new EventHandler(HandleSizeChanged);
// Events that need to be sent to our parent
MouseUp +=new MouseEventHandler(HandleMouseUp);
MouseMove +=new MouseEventHandler(HandleMouseMove);
ContextMenu = owner.context_menu;
- }\r
-\r
- protected override CreateParams CreateParams {\r
- get {\r
- CreateParams cp;\r
-\r
- cp = base.CreateParams;\r
-\r
- cp.Parent = IntPtr.Zero;\r
- cp.Style = (int)WindowStyles.WS_POPUP;\r
- cp.Style |= (int)WindowStyles.WS_CLIPSIBLINGS;\r
-\r
- cp.ExStyle = (int)(WindowStyles.WS_EX_TOOLWINDOW);
-\r
- return cp;\r
- }\r
- }\r
-\r
- protected override void WndProc(ref Message m) {\r
- switch((Msg)m.Msg) {\r
- case Msg.WM_NCPAINT: {\r
- PaintEventArgs paint_event;
-
- paint_event = XplatUI.PaintEventStart(Handle, false);
- OnPaint(paint_event);
- XplatUI.PaintEventEnd(Handle, false);\r
- break;\r
- }\r
-\r
- case Msg.WM_USER: {\r
- switch ((Msg)m.LParam.ToInt32()) {\r
- case Msg.WM_LBUTTONDOWN: {\r
- HandleMouseDown(this, new MouseEventArgs(MouseButtons.Left, 1, Control.MousePosition.X, Control.MousePosition.Y, 0));\r
- return;\r
- }\r
-\r
- case Msg.WM_LBUTTONUP: {\r
- HandleMouseUp(this, new MouseEventArgs(MouseButtons.Left, 1, Control.MousePosition.X, Control.MousePosition.Y, 0));\r
- HandleClick(this, EventArgs.Empty);\r
- return;\r
- }\r
-\r
- case Msg.WM_LBUTTONDBLCLK: {\r
- HandleDoubleClick(this, EventArgs.Empty);\r
- return;\r
- }\r
-\r
- case Msg.WM_MOUSEMOVE: {\r
- HandleMouseMove(this, new MouseEventArgs(MouseButtons.None, 1, Control.MousePosition.X, Control.MousePosition.Y, 0));\r
- return;\r
- }\r
-\r
- case Msg.WM_RBUTTONDOWN: {\r
- HandleMouseDown(this, new MouseEventArgs(MouseButtons.Right, 1, Control.MousePosition.X, Control.MousePosition.Y, 0));\r
- return;\r
- }\r
-\r
- case Msg.WM_RBUTTONUP: {\r
- HandleMouseUp(this, new MouseEventArgs(MouseButtons.Right, 1, Control.MousePosition.X, Control.MousePosition.Y, 0));\r
- HandleClick(this, EventArgs.Empty);\r
- return;\r
- }\r
-\r
- case Msg.WM_RBUTTONDBLCLK: {\r
- HandleDoubleClick(this, EventArgs.Empty);\r
- return;\r
- }\r
- }\r
- return;\r
- }\r
- }\r
- base.WndProc (ref m);\r
- }\r
-\r
- internal void CalculateIconRect() {\r
- if (owner != null && owner.icon != null) {\r
- int x;
- int y;
- int size;\r
-\r
- // Icons are always square. Try to center them in the window\r
- if (ClientRectangle.Width < ClientRectangle.Height) {\r
- size = ClientRectangle.Width;\r
- } else {\r
- size = ClientRectangle.Height;\r
- }\r
- x = this.ClientRectangle.Width / 2 - size / 2;\r
- y = this.ClientRectangle.Height / 2 - size / 2;\r
- rect = new Rectangle(x, y, size, size);\r
-\r
- // Force our window to be square\r
- if (Width != size) {\r
- this.Width = size;\r
- }\r
-\r
- if (Height != size) {\r
- this.Height = size;\r
- }\r
- }\r
- }\r
-\r
- private void HandlePaint(object sender, PaintEventArgs e) {\r
- if (owner.icon != null) {\r
- e.Graphics.FillRectangle(ThemeEngine.Current.ResPool.GetSolidBrush(SystemColors.Window), rect);\r
- e.Graphics.DrawImage(owner.icon_bitmap, rect);\r
-\r
- }\r
- }\r
-\r
- private void HandleSizeChanged(object sender, EventArgs e) {\r
- CalculateIconRect();\r
- }\r
-\r
- private void HandleClick(object sender, EventArgs e) {\r
- if (owner.Click != null) {\r
- owner.Click(owner, e);\r
- }\r
- }\r
-\r
- private void HandleDoubleClick(object sender, EventArgs e) {\r
- if (owner.DoubleClick != null) {\r
- owner.DoubleClick(owner, e);\r
- }\r
- }\r
-\r
- private void HandleMouseDown(object sender, MouseEventArgs e) {\r
- if (owner.MouseDown != null) {\r
- owner.MouseDown(owner, e);\r
- }\r
- }\r
-
- private void HandleMouseUp(object sender, MouseEventArgs e) {\r
- if (owner.context_menu != null) {\r
- owner.context_menu.Show(this, new Point(e.X, e.Y));\r
- }\r
-\r
- if (owner.MouseUp != null) {\r
- owner.MouseUp(owner, e);\r
- }\r
- }\r
-\r
- private void HandleMouseMove(object sender, MouseEventArgs e) {\r
- if (owner.MouseMove != null) {\r
- owner.MouseMove(owner, e);\r
- }\r
- }\r
+ }
+
+ protected override CreateParams CreateParams {
+ get {
+ CreateParams cp;
+
+ cp = base.CreateParams;
+
+ cp.Parent = IntPtr.Zero;
+ cp.Style = (int)WindowStyles.WS_POPUP;
+ cp.Style |= (int)WindowStyles.WS_CLIPSIBLINGS;
+
+ cp.ExStyle = (int)(WindowExStyles.WS_EX_TOOLWINDOW);
+
+ return cp;
+ }
+ }
+
+ protected override void WndProc(ref Message m) {
+ switch((Msg)m.Msg) {
+ //
+ // NotifyIcon does CONTEXTMENU on mouse up, not down
+ // so we swallow the message here, and handle it on our own
+ //
+ case Msg.WM_CONTEXTMENU:
+ return;
+
+ case Msg.WM_USER: {
+ switch ((Msg)m.LParam.ToInt32()) {
+ case Msg.WM_LBUTTONDOWN: {
+ owner.OnMouseDown (new MouseEventArgs(MouseButtons.Left, 1, Control.MousePosition.X, Control.MousePosition.Y, 0));
+ return;
+ }
+
+ case Msg.WM_LBUTTONUP: {
+ owner.OnMouseUp (new MouseEventArgs(MouseButtons.Left, 1, Control.MousePosition.X, Control.MousePosition.Y, 0));
+ owner.OnClick (EventArgs.Empty);
+ return;
+ }
+
+ case Msg.WM_LBUTTONDBLCLK: {
+ owner.OnDoubleClick (EventArgs.Empty);
+ return;
+ }
+
+ case Msg.WM_MOUSEMOVE: {
+ owner.OnMouseMove (new MouseEventArgs(MouseButtons.None, 1, Control.MousePosition.X, Control.MousePosition.Y, 0));
+ return;
+ }
+
+ case Msg.WM_RBUTTONDOWN: {
+ owner.OnMouseDown (new MouseEventArgs(MouseButtons.Right, 1, Control.MousePosition.X, Control.MousePosition.Y, 0));
+ return;
+ }
+
+ case Msg.WM_RBUTTONUP: {
+ owner.OnMouseUp (new MouseEventArgs(MouseButtons.Right, 1, Control.MousePosition.X, Control.MousePosition.Y, 0));
+ owner.OnClick (EventArgs.Empty);
+ return;
+ }
+
+ case Msg.WM_RBUTTONDBLCLK: {
+ owner.OnDoubleClick (EventArgs.Empty);
+ return;
+ }
+ }
+ return;
+ }
+ }
+ base.WndProc (ref m);
+ }
+
+ internal void CalculateIconRect() {
+ int x;
+ int y;
+ int size;
+
+ // Icons are always square. Try to center them in the window
+ if (ClientRectangle.Width < ClientRectangle.Height) {
+ size = ClientRectangle.Width;
+ } else {
+ size = ClientRectangle.Height;
+ }
+ x = this.ClientRectangle.Width / 2 - size / 2;
+ y = this.ClientRectangle.Height / 2 - size / 2;
+ rect = new Rectangle(x, y, size, size);
+
+ Bounds = new Rectangle (0, 0, size, size);
+ }
+
+ internal override void OnPaintInternal (PaintEventArgs e) {
+ if (owner.icon != null) {
+ e.Graphics.FillRectangle(ThemeEngine.Current.ResPool.GetSolidBrush(SystemColors.Window), rect);
+ e.Graphics.DrawImage(owner.icon_bitmap,
+ rect,
+ new Rectangle (0, 0, owner.icon_bitmap.Width, owner.icon_bitmap.Height),
+ GraphicsUnit.Pixel);
+
+ }
+ }
+
+ internal void InternalRecreateHandle () {
+ base.RecreateHandle ();
+ }
+
+
+ private void HandleSizeChanged(object sender, EventArgs e) {
+ owner.Recalculate ();
+ }
+
+ private void HandleClick (object sender, EventArgs e)
+ {
+ owner.OnClick (e);
+ }
+
+ private void HandleDoubleClick (object sender, EventArgs e)
+ {
+ owner.OnDoubleClick (e);
+ }
+
+ private void HandleMouseDown (object sender, MouseEventArgs e)
+ {
+ owner.OnMouseDown (e);
+ }
+
+ private void HandleMouseUp (object sender, MouseEventArgs e)
+ {
+ owner.OnMouseUp (e);
+ }
+
+ private void HandleMouseMove (object sender, MouseEventArgs e)
+ {
+ owner.OnMouseMove (e);
+ }
}
#endregion // NotifyIconWindow Class
#endregion // Public Constructors
#region Private Methods
- private void ShowSystray(bool property_changed) {
- if (property_changed) {
- window.CalculateIconRect();
- }
+ private void OnClick (EventArgs e)
+ {
+ EventHandler eh = (EventHandler)(Events [ClickEvent]);
+ if (eh != null)
+ eh (this, e);
+ }
- if (systray_active) {
- if (property_changed) {
- UpdateSystray();
- }
- return;
- }
+ private void OnDoubleClick (EventArgs e)
+ {
+ EventHandler eh = (EventHandler)(Events [DoubleClickEvent]);
+ if (eh != null)
+ eh (this, e);
+ }
+
+ private void OnMouseDown (MouseEventArgs e)
+ {
+ MouseEventHandler eh = (MouseEventHandler)(Events [MouseDownEvent]);
+ if (eh != null)
+ eh (this, e);
+ }
+
+ private void OnMouseUp (MouseEventArgs e)
+ {
+ if ((e.Button & MouseButtons.Right) == MouseButtons.Right && context_menu != null)
+ context_menu.Show (window, new Point(e.X, e.Y));
+
+ MouseEventHandler eh = (MouseEventHandler)(Events [MouseUpEvent]);
+ if (eh != null)
+ eh (this, e);
+ }
- if (icon == null) {
+ private void OnMouseMove (MouseEventArgs e)
+ {
+ MouseEventHandler eh = (MouseEventHandler)(Events [MouseMoveEvent]);
+ if (eh != null)
+ eh (this, e);
+ }
+
+ private void Recalculate ()
+ {
+ window.CalculateIconRect ();
+
+ if (systray_active)
+ UpdateSystray ();
+ }
+
+ private void ShowSystray()
+ {
+ systray_active = true;
+
+ if (icon == null)
return;
- }
icon_bitmap = icon.ToBitmap();
- systray_active = true;
XplatUI.SystrayAdd(window.Handle, text, icon, out tooltip);
}
- private void HideSystray() {
+ private void HideSystray()
+ {
if (!systray_active) {
return;
}
XplatUI.SystrayRemove(window.Handle, ref tooltip);
}
- private void UpdateSystray() {
+ private void UpdateSystray()
+ {
if (icon_bitmap != null) {
icon_bitmap.Dispose();
}
#region Public Instance Properties
[DefaultValue(null)]
+#if NET_2_0
+ [Browsable (false)]
+#endif
public ContextMenu ContextMenu {
get {
return context_menu;
set {
if (icon != value) {
- if (icon != null) {
- icon.Dispose();
- }
icon = value;
- ShowSystray(true);
+ if (text == string.Empty && icon == null) {
+ HideSystray ();
+ }
+ else {
+ Recalculate ();
+ }
}
}
}
- [Localizable(true)]
+#if NET_2_0
+ [DefaultValue ("")]
+ [Editor ("System.ComponentModel.Design.MultilineStringEditor, " + Consts.AssemblySystem_Design,
+ typeof (System.Drawing.Design.UITypeEditor))]
+#endif
+ [Localizable (true)]
public string Text {
get {
return text;
if (text == string.Empty && icon == null) {
HideSystray();
} else {
- ShowSystray(true);
+ Recalculate ();
}
}
}
window.is_visible = value;
if (visible) {
- ShowSystray(false);
+ ShowSystray ();
} else {
HideSystray();
}
#endregion // Public Instance Properties
#region Protected Instance Methods
- protected override void Dispose(bool disposing) {\r
- if (icon != null) {\r
- icon.Dispose();\r
- }\r
-\r
- if (icon_bitmap != null) {\r
- icon_bitmap.Dispose();\r
- }\r
- base.Dispose (disposing);\r
- }\r
+ protected override void Dispose(bool disposing) {
+ if (icon_bitmap != null) {
+ icon_bitmap.Dispose();
+ }
+
+ if (disposing)
+ icon = null;
+
+ base.Dispose (disposing);
+ }
#endregion // Protected Instance Methods
#region Events
+ static object ClickEvent = new object ();
+ static object DoubleClickEvent = new object ();
+ static object MouseDownEvent = new object ();
+ static object MouseMoveEvent = new object ();
+ static object MouseUpEvent = new object ();
+
+#if NET_2_0
+ [MWFCategory("Action")]
+#else
[Category("Action")]
- public event EventHandler Click;
+#endif
+ public event EventHandler Click {
+ add { Events.AddHandler (ClickEvent, value); }
+ remove { Events.RemoveHandler (ClickEvent, value); }
+ }
+#if NET_2_0
+ [MWFCategory("Action")]
+#else
[Category("Action")]
- public event EventHandler DoubleClick;
+#endif
+ public event EventHandler DoubleClick {
+ add { Events.AddHandler (DoubleClickEvent, value); }
+ remove { Events.RemoveHandler (DoubleClickEvent, value); }
+ }
+
+ public event MouseEventHandler MouseDown {
+ add { Events.AddHandler (MouseDownEvent, value); }
+ remove { Events.RemoveHandler (MouseDownEvent, value); }
+ }
+
+ public event MouseEventHandler MouseMove {
+ add { Events.AddHandler (MouseMoveEvent, value); }
+ remove { Events.RemoveHandler (MouseMoveEvent, value); }
+ }
+
+ public event MouseEventHandler MouseUp {
+ add { Events.AddHandler (MouseUpEvent, value); }
+ remove { Events.RemoveHandler (MouseUpEvent, value); }
+ }
- public event MouseEventHandler MouseDown;
- public event MouseEventHandler MouseMove;
- public event MouseEventHandler MouseUp;
#endregion // Events
}
}