JavaFX resize canvas in fxml

后端 未结 2 1560
粉色の甜心
粉色の甜心 2021-01-15 17:13

I\'m trying to resize a canvas in Javafx. I am using scene builder and fxml. So far, when the user clicks on the canvas the canvas turns black, and when I resize the screen

2条回答
  •  无人共我
    2021-01-15 17:53

    First some Javadocs :)

    A Canvas node is constructed with a width and height that specifies the size of the image into which the canvas drawing commands are rendered. All drawing operations are clipped to the bounds of that image.

    So every time the user resize the window we need to change the width of the canvas and then we need to re-draw the canvas.

    Lets start by adding a fx:id to the root layout.

    
        
            
        
    
    

    Next step is to add a change listener to the root layout which will set the new height and width to the canvas and then redraw it. We can do it inside the initialize() of the controller.

    public class Controller implements Initializable {
    
        @FXML
        AnchorPane anchorPane;
    
        @FXML
        private Canvas mainCanvas;
    
        @FXML
        public GraphicsContext gc;
    
        public void initGraphics() {
            gc = mainCanvas.getGraphicsContext2D();
        }
    
        public void drawClicked() {
            gc.clearRect(0, 0, mainCanvas.getWidth(), mainCanvas.getHeight());
            gc.setFill(Color.BLACK);
            gc.fillRect(0, 0, mainCanvas.getWidth(), mainCanvas.getHeight());
        }
    
        @Override
        public void initialize(URL url, ResourceBundle rb) {
            initGraphics();
    
            anchorPane.prefWidthProperty().addListener((ov, oldValue, newValue) -> {
                mainCanvas.setWidth(newValue.doubleValue());
                drawClicked();
            });
    
            anchorPane.prefHeightProperty().addListener((ov, oldValue, newValue) -> {
                mainCanvas.setHeight(newValue.doubleValue());
                drawClicked();
            });
        }
    }
    

    I haven't created a new method for reDraw() since your drawClicked() wasn't doing anything. But, you can separate both the methods once it makes more sense.

    The last thing is to bind to root layout's prefWidthProperty() and prefHeightProperty() to the scene's width and height respectively.

    public class Main extends Application {
        public static void main(String[] args) {
            launch(args);
        }
        @Override
        public void start(Stage stage) throws IOException {
            AnchorPane root = FXMLLoader.load(getClass().getResource("MainFXML.fxml"));
    
            Scene scene = new Scene(root);
    
            stage.setTitle("DrawFx");
            stage.setScene(scene);
            stage.show();
    
            root.prefWidthProperty().bind(scene.widthProperty());
            root.prefHeightProperty().bind(scene.heightProperty());
        }
    }
    

提交回复
热议问题