Search code examples
javadrag-and-dropjavafx-8gridpane

JavaFX Drag&Drop events on Gridpanes


I tried to do a Drag&Drop-Event in a grid pane, but it didn't work. The drag is detected but neither the drag over nor the drop event. What I'm doing wrong?

Here is the code I tried:

public class FXMLDocumentController implements Initializable {

    @FXML
    private GridPane grid;

    @Override
    public void initialize(URL url, ResourceBundle rb) {
        StackPane sourcePane = new StackPane(new Text("Source"));    
        StackPane targetPane = new StackPane(new Text("Target"));        

        sourcePane.setOnDragDetected(new EventHandler<MouseEvent>() {
            @Override
            public void handle(MouseEvent event) {
                sourcePane.startDragAndDrop(TransferMode.ANY);
                System.out.println("Drag detected");
                event.consume();
            }
        });


        targetPane.setOnDragOver(new EventHandler<DragEvent>() {
            @Override
            public void handle(DragEvent event) {
                event.acceptTransferModes(TransferMode.ANY);
                System.out.println("Drag over detected");
                event.consume();
            }
        });

        targetPane.setOnDragDropped(new EventHandler<DragEvent>() {
            @Override
            public void handle(DragEvent event) {
                event.acceptTransferModes(TransferMode.ANY);
                System.out.println("Drop detected");
                event.consume();
            }
        });

        grid.add(sourcePane, 1, 1);
        grid.add(targetPane, 0, 1);
    }        
}

Solution

  • You need to add some content in the after startDragAndDrop() eg. :

        sourcePane.setOnDragDetected(new EventHandler<MouseEvent>() {
            @Override
            public void handle(MouseEvent event) {
                Dragboard db = sourcePane.startDragAndDrop(TransferMode.ANY);
                ClipboardContent content = new ClipboardContent();
                content.putString("Hello!");
                db.setContent(content);
                System.out.println("Drag detected");
                event.consume();
            }
        });
    

    See Oracle's page on DragEvent:
    https://docs.oracle.com/javase/8/javafx/api/javafx/scene/input/DragEvent.html