2 using System.Drawing;
\r
3 using System.Windows.Forms;
\r
4 using System.Threading;
\r
5 using NaGet.SubCommands;
\r
8 namespace AppliStation.Util
\r
11 /// Description of ExecutionProgressViewer.
\r
13 public partial class ExecutionProgressViewer : Form
\r
15 private NaGetTaskSet taskSet;
\r
17 private Thread tasksetRunningThread = null;
\r
22 private enum ActionOnDoneFlags {
\r
25 AutoCloseOnSuccess = 2,
\r
31 private ActionOnDoneFlags ActionOnDone = ActionOnDoneFlags.FlashWindow;
\r
33 public ExecutionProgressViewer()
\r
36 // The InitializeComponent() call is required for Windows Forms designer support.
\r
38 InitializeComponent();
\r
40 this.Icon = Icon.ExtractAssociatedIcon(Application.ExecutablePath);
\r
41 toolTip.SetToolTip(autoCloseCheckBox,
\r
42 string.Format("エラーがなく正常に終了した場合、{0}秒後に自動的にこのダイアログを閉じます", autoCloseTimer.Interval/1000));
\r
45 private void onDownloadEvent(object sender, DownloadEventArgs a)
\r
47 if (InvokeRequired) {
\r
48 Invoke(new EventHandler<DownloadEventArgs>(onDownloadEvent), sender, a);
\r
53 if (a.TaskProgressPercent >= 0) {
\r
54 progressBarSub.Value = (int) a.TaskProgressPercent;
\r
55 progressBarSub.Style = ProgressBarStyle.Continuous;
\r
57 progressBarSub.Style = ProgressBarStyle.Marquee;
\r
61 case DownloadEventType.INITED:
\r
62 case DownloadEventType.CONNECTED:
\r
63 progressSubLabel.Text = a.TaskMessage;
\r
65 progressBarSub.Visible = true;
\r
66 progressSubLabel.Visible = true;
\r
68 case DownloadEventType.DOWNLOADING:
\r
69 progressSubLabel.Text = a.TaskMessage;
\r
71 case DownloadEventType.COMPLETED:
\r
72 progressBarSub.Visible = false;
\r
73 progressSubLabel.Visible = false;
\r
75 case DownloadEventType.ERROR:
\r
76 progressBarSub.Visible = false;
\r
77 progressSubLabel.Visible = false;
\r
79 logBox.SelectionColor = System.Drawing.Color.Red;
\r
80 logBox.AppendText(" [エラー] " + a.TaskMessage + System.Environment.NewLine);
\r
81 logBox.SelectionColor = logBox.ForeColor;
\r
86 #region NaGetTaskSet関連
\r
88 private void onTaskSetRaised(object sender, NaGetTaskSetEventArgs e)
\r
90 NaGetTaskSet taskSet = (NaGetTaskSet) sender;
\r
92 if (e.TaskProgressPercent >= 0) {
\r
93 progressBar.Value = (int) e.TaskProgressPercent;
\r
94 progressBar.Style = ProgressBarStyle.Continuous;
\r
96 progressBar.Style = ProgressBarStyle.Marquee;
\r
99 cancelButton.Enabled = taskSet.Running && taskSet.Cancelable;
\r
102 case NaGetTaskSetEventType.COMPLETED:
\r
103 logBox.AppendText("完了." + System.Environment.NewLine);
\r
104 if (taskSet.Done) {
\r
105 okButton.Enabled = true;
\r
106 cancelButton.Enabled = false;
\r
108 // タスクが完了したらしばらく待って閉じるために、自動クローズタイマーを起動する
\r
109 autoCloseTimer.Start();
\r
112 case NaGetTaskSetEventType.STARTED_TASKSET:
\r
113 progressLabel.Text = taskSet.TaskSetNames[taskSet.CurrentTaskSetIndex];
\r
114 logBox.AppendText(" " + e.TaskMessage + System.Environment.NewLine);
\r
116 case NaGetTaskSetEventType.COMPLETED_TASKSET:
\r
117 if (progressBarSub.Visible) progressBarSub.Hide();
\r
118 if (progressSubLabel.Visible) progressSubLabel.Hide();
\r
120 NativeMethods.ProgressBar_SetState(progressBar, 1); // VistaProgress色:ノーマル
\r
122 logBox.AppendText(string.Format(" ... 完了. [{0}%]", (int) e.TaskProgressPercent));
\r
123 logBox.AppendText(System.Environment.NewLine);
\r
125 case NaGetTaskSetEventType.INFO:
\r
126 logBox.AppendText(" " + e.TaskMessage + System.Environment.NewLine);
\r
128 case NaGetTaskSetEventType.ERROR:
\r
129 logBox.SelectionColor = System.Drawing.Color.Red;
\r
130 logBox.AppendText(" [エラー] " + e.TaskMessage + System.Environment.NewLine);
\r
131 logBox.SelectionColor = logBox.ForeColor;
\r
133 NativeMethods.ProgressBar_SetState(progressBar, 2); // VistaProgress色:エラー
\r
135 autoCloseCheckBox.Enabled = false;
\r
136 okButton.Enabled = true;
\r
137 cancelButton.Enabled = false;
\r
139 case NaGetTaskSetEventType.CANCELED:
\r
140 logBox.SelectionColor = System.Drawing.Color.Red;
\r
141 logBox.AppendText(e.TaskMessage + System.Environment.NewLine);
\r
142 logBox.SelectionColor = logBox.ForeColor;
\r
144 NativeMethods.ProgressBar_SetState(progressBar, 1); // VistaProgress色:中断
\r
145 NativeMethods.ProgressBar_SetState(progressBarSub, 1); // VistaProgress色:中断
\r
147 autoCloseCheckBox.Enabled = false;
\r
148 okButton.Enabled = true;
\r
149 cancelButton.Enabled = false;
\r
151 case NaGetTaskSetEventType.WARNING:
\r
152 logBox.SelectionColor = System.Drawing.Color.Red;
\r
153 logBox.AppendText(" [エラー] " + e.TaskMessage + System.Environment.NewLine);
\r
154 logBox.SelectionColor = logBox.ForeColor;
\r
156 NativeMethods.ProgressBar_SetState(progressBar, 2); // VistaProgress色:エラー
\r
158 autoCloseCheckBox.Enabled = false;
\r
163 logBox.ScrollToCaret();
\r
166 if (taskSet.Done) {
\r
167 if ((ActionOnDone & ActionOnDoneFlags.FlashWindow) != 0) {
\r
168 NativeMethods.Form_FlashWindow(this,
\r
169 NativeMethods.FlashFlag.All | NativeMethods.FlashFlag.TimerNoFG,
\r
172 if (okButton.Enabled && (ActionOnDone & ActionOnDoneFlags.AutoCloseOnSuccess) != 0) {
\r
173 this.DialogResult = DialogResult.OK;
\r
180 private NaGetTaskQueryResult onTaskQueryRaised(object sender, NaGetTaskQueryArgs e)
\r
182 MessageBoxButtons buttons = MessageBoxButtons.OKCancel;
\r
183 if (e.SelectionFlag == (NaGetTaskQueryResult.CONTINUE | NaGetTaskQueryResult.RETRY | NaGetTaskQueryResult.CANCEL)) {
\r
184 buttons = MessageBoxButtons.AbortRetryIgnore;
\r
185 } else if (e.SelectionFlag == (NaGetTaskQueryResult.RETRY | NaGetTaskQueryResult.CANCEL)) {
\r
186 buttons = MessageBoxButtons.RetryCancel;
\r
187 } else if (e.SelectionFlag == NaGetTaskQueryResult.CONTINUE) {
\r
188 buttons = MessageBoxButtons.OK;
\r
191 DialogResult result = MessageBox.Show(e.Message, this.Text, buttons);
\r
194 case DialogResult.OK:
\r
195 case DialogResult.Ignore:
\r
196 return NaGetTaskQueryResult.CONTINUE;
\r
197 case DialogResult.Cancel:
\r
198 case DialogResult.Abort:
\r
199 return NaGetTaskQueryResult.CANCEL;
\r
200 case DialogResult.Retry:
\r
201 return NaGetTaskQueryResult.RETRY;
\r
203 return NaGetTaskQueryResult.CANCELED_AUTOMATICALLY;
\r
207 public void SetTaskSet(NaGetTaskSet taskSet)
\r
209 this.taskSet = taskSet;
\r
211 taskSet.TaskSetRaised += delegate(object sender, NaGetTaskSetEventArgs e) {
\r
212 if (InvokeRequired) {
\r
213 Invoke(new EventHandler<NaGetTaskSetEventArgs>(onTaskSetRaised), taskSet, e);
\r
215 onTaskSetRaised(taskSet, e);
\r
219 System.Reflection.PropertyInfo fDownloader = taskSet.GetType().GetProperty("Downloader");
\r
220 if (fDownloader != null && (fDownloader.PropertyType == typeof(Downloader))) {
\r
221 ((Downloader) fDownloader.GetValue(taskSet, null)).DownloadEventRaised += onDownloadEvent;
\r
224 taskSet.TaskQueryRaised += onTaskQueryRaised;
\r
227 public void StartTaskSet()
\r
229 tasksetRunningThread = new Thread(taskSet.Run);
\r
230 // スレッドをSTAにしないとCOMアクセスできず、ウイルススキャンができない。
\r
231 tasksetRunningThread.SetApartmentState(ApartmentState.STA);
\r
232 tasksetRunningThread.Start();
\r
237 void OkButtonClick(object sender, EventArgs e)
\r
239 if (taskSet == null || taskSet.Done) {
\r
245 void CancelButtonClick(object sender, EventArgs e)
\r
247 if (InvokeRequired) {
\r
248 Invoke(new EventHandler(CancelButtonClickConcrete), sender, e);
\r
250 CancelButtonClickConcrete(sender,e);
\r
254 void CancelButtonClickConcrete(object sender, EventArgs e)
\r
256 autoCloseCheckBox.Enabled = false;
\r
257 if (taskSet != null && taskSet.Running && taskSet.Cancelable) {
\r
258 cancelButton.Enabled = false;
\r
260 NativeMethods.ProgressBar_SetState(progressBar, 3); // VistaProgress色:中断
\r
266 void ExecutionProgressViewerShown(object sender, EventArgs e)
\r
268 this.BringToFront();
\r
271 void ExecutionProgressViewerFormClosed(object sender, FormClosedEventArgs e)
\r
273 autoCloseTimer.Enabled = false;
\r
276 void AutoCloseTimerTick(object sender, EventArgs e)
\r
278 autoCloseTimer.Stop();
\r
280 if (InvokeRequired) {
\r
281 Invoke(new EventHandler(AutoCloseTimerTickConcrete), sender, e);
\r
283 AutoCloseTimerTickConcrete(sender,e);
\r
287 void AutoCloseTimerTickConcrete(object sender, EventArgs e)
\r
289 // autoCloseCheckBoxが有効(正常終了)かつチェックのときに限り、OKボタンを自動的にクリック
\r
290 if (autoCloseCheckBox.Enabled && autoCloseCheckBox.Checked && okButton.Enabled) {
\r
291 OkButtonClick(sender, e);
\r
292 } else if (! autoCloseCheckBox.Enabled) {
\r
293 // タイマーの時間がすぎて、そのとき自動で閉じないようにしていしてあるならば、手動で閉じるように
\r
294 autoCloseCheckBox.Enabled = false;
\r