diff options
| author | lempamo <[email protected]> | 2017-10-23 12:01:44 -0400 |
|---|---|---|
| committer | lempamo <[email protected]> | 2017-10-23 12:01:44 -0400 |
| commit | 5e91513731ab83f356fd3cb4d2a13c93e933419a (patch) | |
| tree | b2402ea1db05e2e46bab58a272379fdb7a90a6ce /Histacom2.Engine/WindowManager.cs | |
| parent | a9fc08f91fb2e33303ddb6e1e7359ce9539720ed (diff) | |
| download | histacom2-5e91513731ab83f356fd3cb4d2a13c93e933419a.tar.gz histacom2-5e91513731ab83f356fd3cb4d2a13c93e933419a.tar.bz2 histacom2-5e91513731ab83f356fd3cb4d2a13c93e933419a.zip | |
winxp template needs fixing
Diffstat (limited to 'Histacom2.Engine/WindowManager.cs')
| -rw-r--r-- | Histacom2.Engine/WindowManager.cs | 69 |
1 files changed, 62 insertions, 7 deletions
diff --git a/Histacom2.Engine/WindowManager.cs b/Histacom2.Engine/WindowManager.cs index 4f4951c..ca0c782 100644 --- a/Histacom2.Engine/WindowManager.cs +++ b/Histacom2.Engine/WindowManager.cs @@ -36,11 +36,6 @@ namespace Histacom2.Engine app = new WinClassic(); break; } - case "XP": - { - // app = new WinXP(); - break; - } default: { app = new WinClassic(); @@ -111,9 +106,69 @@ namespace Histacom2.Engine return app; } - // A THING TM + public WinXP InitXP(UserControl content, string title, Image icon, bool MaxButton, bool MinButton, bool ShowApplicationAsDialog = false, bool resize = true) + { + WinXP app = new WinXP(); + + app.Text = title; + app.programname.Text = title; + app.Width = content.Width + 8; + app.Height = content.Height + 26; + // Initialize Font + pfc.AddFontFile(SaveSystem.GameDirectory + "\\Data\\LeviWindows.ttf"); + Font fnt = new Font(pfc.Families[0], 16F, FontStyle.Regular, GraphicsUnit.Point, ((0))); + app.fnt = fnt; + app.Title.Font = new Font(pfc.Families[0], 16F, FontStyle.Bold, GraphicsUnit.Point, ((0))); + // Setup UC + content.Parent = app.programContent; + content.BringToFront(); + content.Dock = DockStyle.Fill; + app.progContent = content; + + // Check if icon is null + if (icon == null) + { + app.programIcon.Hide(); + app.programIcon.Image = Engine.Properties.Resources.nullIcon; + app.programname.Location = new Point(2, 1); + } + else app.programIcon.Image = icon; + + // Check if Max button is enabled and set proper X for Min button + if (MaxButton == false) + { + app.maximizebutton.Visible = false; + app.minimizebutton.Location = new Point(app.closebutton.Location.X - 14, app.minimizebutton.Location.Y); + } + + // Check if Min button is enabled + if (MinButton == false) + { + app.minimizebutton.Visible = false; + app.minimizebutton.Location = new Point(app.minimizebutton.Location.X, app.minimizebutton.Location.Y); + } + + //Resize + app.resizable = resize; + + // Convert an image to an icon (for the taskbar) + if (icon != null) + { + Bitmap theBitmap = new Bitmap(icon, new Size(icon.Width, icon.Height)); + IntPtr Hicon = theBitmap.GetHicon(); // Get an Hicon for myBitmap. + Icon newIcon = Icon.FromHandle(Hicon); // Create a new icon from the handle. + app.Icon = newIcon; + } - // A THING TM + // Set some values (for the taskbar) + app.Tag = TaskBarController.AvalibleApplicationID; + app.Text = title; + + // Show the app + app.TopMost = true; + if (ShowApplicationAsDialog == false) { app.Show(); } else { app.ShowDialog(); } + return app; + } public WinClassic StartInfobox95(string title, string text, InfoboxType type, InfoboxButtons btns) { |
