Индикатор выполнения пропускается с 0% до 100% без обновления между - PullRequest
0 голосов
/ 25 июня 2019

Я внедряю ProgressBar, который обновляется после каждого выполненного задания (всего 5 заданий).Он должен обновляться на 20% после каждого выполненного задания.Нажатие кнопки запускает запуск задач, но когда она нажата, индикатор выполнения перемещается с 0% до 100% без промежуточного обновления.Thread.Sleep (1000) добавлялся перед каждым шагом значения прогресса, чтобы имитировать время, которое займет каждая задача.Я хочу, чтобы индикатор выполнения работал перед добавлением кода для каждой задачи.

Я пытался добавить событие AvaloniaPropertyChanged, но, похоже, это не меняет проблему.

MainWindow.xaml:

<ProgressBar Name="RunProgress" Value="{Binding Progress}" IsIndeterminate="False" Minimum="0" Maximum="100" Height="30"/>
<TextBlock Text="{Binding ElementName=RunProgress, Path=Value, StringFormat={}{0:0}%}" HorizontalAlignment="Center" VerticalAlignment="Center" />

MainWindow.xaml.cs:

//boolean variables for whether or not that process is completed (false if not done, true if done)
bool MasterLimitsRead = false;
bool MasterOrganized = false;
bool LimitsOrganized = false;
bool RemovedFailed = false;
bool OutputCreated = false;

//holds descriptions of the 5(+1) operations the program runs through including description for Done
string[] operation =
{
   "Reading the master and limits file text",
   "Organizing the master data",
   "Organizing the limits",
   "Identifying and removing failed devices",
   "Creating the output",
   "Done"
};

context.CurrentOp = operation[0];

Thread.Sleep(1000);
MasterLimitsRead = true;
if(MasterLimitsRead == true)
{
   context.Progress += 20;
   context.CurrentOp = operation[1];
}

Thread.Sleep(1000);
MasterOrganized = true;
if(MasterOrganized == true)
{
   context.Progress += 20;
   context.CurrentOp = operation[2];
}

Thread.Sleep(1000);
LimitsOrganized = true;
if(LimitsOrganized == true)
{
   context.Progress += 20;
   context.CurrentOp = operation[3];
}

Thread.Sleep(1000);
RemovedFailed = true;
if(RemovedFailed == true)
{
   context.Progress += 20;
   context.CurrentOp = operation[4];
}

Thread.Sleep(1000);
OutputCreated= true;
if(OutputCreated== true)
{
   context.Progress += 20;
   context.CurrentOp = operation[5];
}

MainWindowViewModel.cs:

private string currentOp = string.Empty;   //variable to store current operation, initialized to empty string
public string CurrentOp
{
   get => currentOp;
   set
   {
      if (value != currentOp)
      {
         currentOp = value;
         OnPropertyChanged();
      }
    }
}

private string progress = 0;   //variable to store ProgressBar value in percent, initialized to 0
public string CurrentOp
{
   get => currentOp;
   set
   {
      if (value != currentOp)
      {
         currentOp = value;
         OnPropertyChanged();
      }
    }
}

public event PropertyChangedEventHandler PropertyChanged;

protected virtual void OnPropertyChanged([CallerMemberName] string propertyName = null)
{
   if(PropertyChanged != null)
   {
      PropertyChanged?.Invoke(this, new PropertyChangedEventArgs(propertyName));
   }
}

Ожидается: индикатор выполнения должен увеличиваться с 0% до 100% на 20% после завершения каждой задачи (имитируется задержка в 1 секунду Thread.Sleep (1000))

Фактически: индикатор выполнения начинается с 0%, затем при нажатии кнопки останавливает взаимодействие пользовательского интерфейса для5 секунд, затем обновляет индикатор выполнения до 100%.Я хочу, чтобы он обновлялся при каждом увеличении значения индикатора выполнения.

1 Ответ

0 голосов
/ 25 июня 2019

Вызывая Sleep, вы блокируете поток пользовательского интерфейса.Если поток пользовательского интерфейса заблокирован, обновлений пользовательского интерфейса не будет.Для имитации длительных задач используйте await Task.Delay(TimeSpan.FromSeconds(1)).

...