WPF menyediakan pelbagai kaedah untuk mencipta pemapar imej asas untuk mencapai fungsi seperti menyorot imej, mengezum, paparan tindanan dan paparan imej asal. Walaupun kawalan terbina dalam seperti ViewBox
dan ImageBrush
boleh membantu dengan fungsi ini, artikel ini akan membimbing anda melalui pelaksanaan kod tersuai untuk lebih memahami cara ia berfungsi.
Untuk mengendalikan panning dan zum, kami akan mencipta kawalan tersuai yang dipanggil ZoomBorder
. Kelas ini merangkumi logik transformasi imej.
ZoomBorder
menggunakan UIElement
sebagai elemen kanak-kanak dan menggunakan transformasi untuk mencapai penskalaan dan panning. Kod ini mentakrifkan pengendali acara untuk roda tetikus, seret butang kiri dan pergerakan tetikus untuk melaksanakan fungsi ini.
Dalam tetingkap MainWindow
, anda boleh menggunakan ZoomBorder
untuk memaparkan dan memanipulasi imej. Atribut ZoomBorder
Child
hendaklah ditetapkan kepada imej yang anda mahu lihat.
child_MouseWheel
mengira faktor penskalaan berdasarkan kenaikan roda tetikus dan menggunakannya pada ScaleTransform
imej. Ia juga melaraskan TranslateTransform
untuk mengekalkan kedudukan terjemahan berbanding penuding tetikus.
child_MouseLeftButtonDown
dan child_MouseMove
mengendalikan panning. Apabila pengguna meninggalkan klik dan menyeret, TranslateTransform
imej dikemas kini untuk mengalihkan imej dengan sewajarnya.
Untuk memasukkan butang tetapan semula, anda menambah butang pada MainWindow
dan mengendalikan acara kliknya untuk memanggil kaedah ZoomBorder
Reset
.
Dengan melaksanakan penyesuaian ZoomBorder
dalam WPF, anda boleh mencipta pemapar imej yang ringkas tetapi cekap dengan fungsi sorot dan zum. Pendekatan ini memberikan fleksibiliti dan kawalan yang lebih besar ke atas pengalaman pengguna daripada menggunakan kawalan yang dipratentukan seperti ViewBox
.
Atas ialah kandungan terperinci Bagaimana untuk Mencipta Pemapar Imej Pan dan Zum dalam WPF Menggunakan Kawalan Tersuai?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!