Rumah > pembangunan bahagian belakang > C++ > Bagaimana untuk Memperkenalkan Kelewatan dalam Operasi WPF Tanpa Menyekat UI?

Bagaimana untuk Memperkenalkan Kelewatan dalam Operasi WPF Tanpa Menyekat UI?

Mary-Kate Olsen
Lepaskan: 2024-11-04 02:18:01
asal
241 orang telah melayarinya

How to Introduce Delays in WPF Operations Without Blocking the UI?

Memperkenalkan Kelewatan dalam Operasi WPF

Objektif anda untuk melaksanakan kelewatan sebelum menavigasi ke tetingkap berikutnya boleh dicapai melalui beberapa pendekatan dalam WPF.

Masalah Gambaran Keseluruhan:

Menggunakan Thread.Sleep untuk menggantung urutan sebelum menavigasi membawa kepada penyekatan UI, menyebabkan elemen UI dipaparkan secara ringkas sebelum navigasi berlaku.

Penyelesaian:

Untuk mengelakkan sekatan benang, anda harus menggunakan teknik menunggu tak segerak seperti pemasa penghantar atau Tugas. Kelewatan.

Kaedah 1: DispatcherTimer

Buat pemasa dengan selang 2 saat dan tambah pengendali acara Tick yang akan menghentikan pemasa dan paparkan halaman kedua apabila selang masa berlalu:

tbkLabel.Text = "two seconds delay";

var timer = new DispatcherTimer { Interval = TimeSpan.FromSeconds(2) };
timer.Start();
timer.Tick += (sender, args) =>
{
    timer.Stop();
    var page = new Page2();
    page.Show();
};
Salin selepas log masuk

Kaedah 2: Task.Delay

Guna Task.Delay untuk menggantung operasi tak segerak selama 2 saat dan kemudian memaparkan halaman seterusnya:

tbkLabel.Text = "two seconds delay";

Task.Delay(2000).ContinueWith(_ =>
{
    var page = new Page2();
    page.Show();
});
Salin selepas log masuk

Kaedah 3: Async/ Tunggu (untuk .NET 4.5 dan Ke Atas)

Gaji async/tunggu untuk mencapai menunggu tak segerak dalam kaedah dan elakkan sekatan benang:

public async void TheEnclosingMethod()
{
    tbkLabel.Text = "two seconds delay";

    await Task.Delay(2000);
    var page = new Page2();
    page.Show();
}
Salin selepas log masuk

Atas ialah kandungan terperinci Bagaimana untuk Memperkenalkan Kelewatan dalam Operasi WPF Tanpa Menyekat UI?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan