using System; using System.ComponentModel; using System.Windows.Forms; using System.Net; using System.IO; using System.IO.Compression; using System.Diagnostics; //using NonFormTimer = System.Threading.Timer; using NonFormTimer = System.Timers.Timer; using System.Threading.Tasks; using static DS4Windows.Global; namespace DS4Windows { public partial class WelcomeDialog : Form { public WelcomeDialog(bool loadConfig=false) { InitializeComponent(); Icon = Properties.Resources.DS4; if (loadConfig) { Global.FindConfigLocation(); Global.Load(); Global.SetCulture(Global.UseLang); } } private void bnFinish_Click(object sender, EventArgs e) { this.Close(); } private void linkBluetoothSettings_LinkClicked(object sender, LinkLabelLinkClickedEventArgs e) { Process.Start("control", "bthprops.cpl"); } bool driverinstalling = false; private void bnStep1_Click(object sender, EventArgs e) { WebClient wb = new WebClient(); if (!driverinstalling) { wb.DownloadFileAsync(new Uri("http://23.239.26.40/ds4windows/files/Virtual Bus Driver.zip"), exepath + "\\VBus.zip"); wb.DownloadProgressChanged += wb_DownloadProgressChanged; wb.DownloadFileCompleted += wb_DownloadFileCompleted; driverinstalling = true; } } private void wb_DownloadProgressChanged(object sender, DownloadProgressChangedEventArgs e) { bnStep1.Text = Properties.Resources.Downloading.Replace("*number*", e.ProgressPercentage.ToString()); } private void wb_DownloadFileCompleted(object sender, AsyncCompletedEventArgs e) { bnStep1.Text = Properties.Resources.OpeningInstaller; try { File.Delete(exepath + "\\ScpDriver.exe"); File.Delete(exepath + "\\ScpDriver.log"); Directory.Delete(exepath + "\\System", true); Directory.Delete(exepath + "\\DIFxAPI", true); } catch { } Directory.CreateDirectory(exepath + "\\Virtual Bus Driver"); try { ZipFile.ExtractToDirectory(exepath + "\\VBus.zip", exepath + "\\Virtual Bus Driver"); } //Saved so the user can uninstall later catch { } try { ZipFile.ExtractToDirectory(exepath + "\\VBus.zip", exepath); } //Made here as starting the scpdriver.exe via process.start, the program looks for file from where it was called, not where the exe is catch { } if (File.Exists(exepath + "\\ScpDriver.exe")) try { Process.Start(exepath + "\\ScpDriver.exe", "si"); bnStep1.Text = Properties.Resources.Installing; } catch { Process.Start(exepath + "\\Virtual Bus Driver"); } /*Timer timer = new Timer(); timer.Start(); timer.Tick += timer_Tick; */ NonFormTimer timer = new NonFormTimer(); timer.Elapsed += timer_Tick; timer.Start(); } bool waitForFile; DateTime waitFileCheck; private void timer_Tick(object sender, EventArgs e) { Process[] processes = Process.GetProcessesByName("ScpDriver"); if (processes.Length < 1) { if (!File.Exists(exepath + "\\ScpDriver.log") && !waitForFile) { waitForFile = true; waitFileCheck = DateTime.UtcNow; return; } if (waitForFile && waitFileCheck + TimeSpan.FromMinutes(2) < DateTime.UtcNow) { Process.Start(exepath + "\\Virtual Bus Driver"); File.Delete(exepath + "\\VBus.zip"); ((NonFormTimer)sender).Stop(); this.BeginInvoke((Action)(() => { bnStep1.Text = Properties.Resources.InstallFailed; }), null); return; } else if (waitForFile) return; string log = File.ReadAllText(exepath + "\\ScpDriver.log"); if (log.Contains("Install Succeeded")) this.BeginInvoke((Action)(() => { bnStep1.Text = Properties.Resources.InstallComplete; })); else { this.BeginInvoke((Action)(() => { bnStep1.Text = Properties.Resources.InstallFailed; })); Process.Start(exepath + "\\Virtual Bus Driver"); } try { File.Delete(exepath + "\\ScpDriver.exe"); File.Delete(exepath + "\\ScpDriver.log"); Directory.Delete(exepath + "\\System", true); Directory.Delete(exepath + "\\DIFxAPI", true); } catch { } File.Delete(exepath + "\\VBus.zip"); ((NonFormTimer)sender).Stop(); } } private void button2_Click(object sender, EventArgs e) { Process.Start("http://www.microsoft.com/accessories/en-gb/d/xbox-360-controller-for-windows"); } } }