aboutsummaryrefslogtreecommitdiff
path: root/ShiftOS.WinForms/Applications/CoherenceOverlay.cs
diff options
context:
space:
mode:
authorMichael <[email protected]>2017-01-08 09:57:10 -0500
committerMichael <[email protected]>2017-01-08 09:57:10 -0500
commitf30dcf5ef41d54c588d7b42c48be8d941abba72e (patch)
tree7705f99b965673b1c034ac2b1c56e65072c827df /ShiftOS.WinForms/Applications/CoherenceOverlay.cs
parent69dfad54724d4176dfce238a8d7e73970e6eef24 (diff)
downloadshiftos_thereturn-f30dcf5ef41d54c588d7b42c48be8d941abba72e.tar.gz
shiftos_thereturn-f30dcf5ef41d54c588d7b42c48be8d941abba72e.tar.bz2
shiftos_thereturn-f30dcf5ef41d54c588d7b42c48be8d941abba72e.zip
Initial upload
Diffstat (limited to 'ShiftOS.WinForms/Applications/CoherenceOverlay.cs')
-rw-r--r--ShiftOS.WinForms/Applications/CoherenceOverlay.cs99
1 files changed, 99 insertions, 0 deletions
diff --git a/ShiftOS.WinForms/Applications/CoherenceOverlay.cs b/ShiftOS.WinForms/Applications/CoherenceOverlay.cs
new file mode 100644
index 0000000..1eaa89d
--- /dev/null
+++ b/ShiftOS.WinForms/Applications/CoherenceOverlay.cs
@@ -0,0 +1,99 @@
+using System;
+using System.Collections.Generic;
+using System.ComponentModel;
+using System.Drawing;
+using System.Data;
+using System.Linq;
+using System.Text;
+using System.Threading.Tasks;
+using System.Windows.Forms;
+using ShiftOS.Engine;
+using System.Threading;
+
+namespace ShiftOS.WinForms.Applications
+{
+ public partial class CoherenceOverlay : UserControl, IShiftOSWindow
+ {
+ public CoherenceOverlay(IntPtr handle, CoherenceCommands.RECT rect)
+ {
+ InitializeComponent();
+ this.Load += (o, a) =>
+ {
+ try
+ {
+ int left = this.ParentForm.Left;
+ int top = this.ParentForm.Top;
+ int oldwidth = this.ParentForm.Width;
+ int oldheight = this.ParentForm.Height;
+
+ var t = new Thread(new ThreadStart(() =>
+ {
+ while (CoherenceCommands.GetWindowRect(handle, ref rect))
+ {
+
+ if (left != rect.Left - SkinEngine.LoadedSkin.LeftBorderWidth)
+ {
+ this.Invoke(new Action(() =>
+ {
+ this.ParentForm.Left = rect.Left - SkinEngine.LoadedSkin.LeftBorderWidth;
+ left = rect.Left - SkinEngine.LoadedSkin.LeftBorderWidth;
+ }));
+ }
+ if (top != rect.Top - SkinEngine.LoadedSkin.TitlebarHeight)
+ {
+ this.Invoke(new Action(() =>
+ {
+
+ this.ParentForm.Top = rect.Top - SkinEngine.LoadedSkin.TitlebarHeight;
+ top = rect.Top - SkinEngine.LoadedSkin.TitlebarHeight;
+ }));
+ }
+ int width = (rect.Right - rect.Left) + 1;
+ int height = (rect.Bottom - rect.Top) + 1;
+
+ if (oldheight != SkinEngine.LoadedSkin.TitlebarHeight + height + SkinEngine.LoadedSkin.BottomBorderWidth)
+ {
+ this.Invoke(new Action(() =>
+ {
+ this.ParentForm.Height = SkinEngine.LoadedSkin.TitlebarHeight + height + SkinEngine.LoadedSkin.BottomBorderWidth;
+ oldheight = SkinEngine.LoadedSkin.TitlebarHeight + height + SkinEngine.LoadedSkin.BottomBorderWidth;
+ }));
+ }
+ if (oldwidth != SkinEngine.LoadedSkin.LeftBorderWidth + width + SkinEngine.LoadedSkin.RightBorderWidth)
+ {
+ this.Invoke(new Action(() =>
+ {
+ this.ParentForm.Width = SkinEngine.LoadedSkin.LeftBorderWidth + width + SkinEngine.LoadedSkin.RightBorderWidth;
+ oldwidth = SkinEngine.LoadedSkin.LeftBorderWidth + width + SkinEngine.LoadedSkin.RightBorderWidth;
+ }));
+ }
+ }
+ }));
+ t.IsBackground = true;
+ t.Start();
+ }
+ catch
+ {
+
+ }
+ };
+ }
+
+ public void OnLoad()
+ {
+ }
+
+ public void OnSkinLoad()
+ {
+ }
+
+ public bool OnUnload()
+ {
+ return true;
+ }
+
+ public void OnUpgrade()
+ {
+ }
+ }
+}