Rumah  >  Artikel  >  Java  >  Bagaimanakah saya boleh mengubah saiz Kanvas secara automatik agar sesuai dengan induknya dalam JavaFX?

Bagaimanakah saya boleh mengubah saiz Kanvas secara automatik agar sesuai dengan induknya dalam JavaFX?

Mary-Kate Olsen
Mary-Kate Olsenasal
2024-10-28 16:12:01650semak imbas

How can I make a Canvas automatically resize to fit its parent in JavaFX?

Mengubah Saiz Kanvas Secara Automatik agar Sesuai dengan Induk Terlampir

Mengubah saiz Kanvas untuk dipadankan dengan dimensi induk penutupnya adalah penting untuk antara muka pengguna yang dinamik. JavaFX menyediakan beberapa pendekatan untuk mencapai ini, salah satunya menggunakan kelas bersarang yang mengatasi kaedah layoutChildren().

Pendekatan Menggunakan CanvasPane

Kelas CanvasPane ialah Anak Tetingkap tersuai yang membalut Kanvas dan memastikan dimensi Kanvas sentiasa sepadan dengan saiz Anak Tetingkap yang disertakan. Buat contoh CanvasPane, menghantar dimensi Kanvas awal yang dikehendaki sebagai argumen. Dengan mengatasi kaedah layoutChildren(), algoritma reka letak CanvasPane melaraskan kedudukan dan saiz Canvas secara automatik untuk mengisi ruang yang tersedia.

Contoh Kod

<code class="java">public class CanvasPane extends Pane {

    private final Canvas canvas;

    public CanvasPane(double width, double height) {
        canvas = new Canvas(width, height);
        getChildren().add(canvas);
    }

    public Canvas getCanvas() {
        return canvas;
    }

    @Override
    protected void layoutChildren() {
        super.layoutChildren();
        // Retrieve the enclosing Pane's dimensions after layout calculations
        double x = snappedLeftInset();
        double y = snappedTopInset();
        double w = snapSize(getWidth()) - x - snappedRightInset();
        double h = snapSize(getHeight()) - y - snappedBottomInset();
        
        // Update the Canvas's layout and dimensions
        canvas.setLayoutX(x);
        canvas.setLayoutY(y);
        canvas.setWidth(w);
        canvas.setHeight(h);
    }
}</code>

Mengikat kepada Induk

Dalam coretan kod yang disediakan, Kanvas ditambahkan pada CanvasPane, yang kemudiannya ditambahkan pada Stage. CanvasPane terikat pada dimensi Stage menggunakan pengikatan CSS3, dengan itu memastikan Kanvas sentiasa memenuhi ruang Stage yang tersedia.

Menggunakan Fungsi Java 9 Snap

JavaFX yang disediakan 8 termasuk kaedah snapSize() dan isResizable() yang tidak digunakan lagi. Dalam Java 9 dan lebih baru, gunakan snapSizeX() dan snapSizeY() untuk mendapatkan semula saiz pilihan dan leverage bind(Observable[]) untuk mencapai kefungsian yang serupa.

Dengan menggunakan pendekatan ini, Kanvas anda akan mengubah saiz dirinya secara automatik untuk dipadankan dimensi nod induk, menyediakan antara muka pengguna yang lebih responsif dan fleksibel.

Atas ialah kandungan terperinci Bagaimanakah saya boleh mengubah saiz Kanvas secara automatik agar sesuai dengan induknya dalam JavaFX?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
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