1

マウスを押している間、2つの図形を線で結びたいです。ドキュメントが言うように、pressed-draged-release モデルを使用してそれを行うことはできないため、ドラッグ アンド ドロップ方式を使用する必要があります。 ? mouseMove で線を引きますが、これらのデフォルトのアイコンは必要ありません。

それを示す簡単なプログラムを含めます-実行して、ある円を別の円にドラッグしてみてください。

/*
* To change this template, choose Tools | Templates
* and open the template in the editor.
*/
package onreleased;

import javafx.application.Application;
import javafx.event.EventHandler;
import javafx.scene.Scene;
import javafx.scene.control.Label;
import javafx.scene.input.*;
import javafx.scene.layout.Pane;
import javafx.scene.paint.Color;
import javafx.scene.shape.Circle;
import javafx.stage.Stage;

/**
*
* @author mmk
*/
public class DaDIcons extends Application {

    /**
    * @param args the command line arguments
    */
    public static void main(String[] args) {
        launch(args);
    }

    @Override
    public void start(Stage primaryStage) {
        primaryStage.setTitle("Hello World!");


        final Label label = new Label("started");
        label.setLayoutY(100);

        Pane pane = new Pane();
        Circle red = createCircle(40, 40, 30, Color.RED, label);
        Circle blue = createCircle(160, 40, 30, Color.BLUE, label);

        pane.setOnDragOver(new EventHandler<DragEvent>() {

            @Override
            public void handle(DragEvent event) {

                System.out.println("foo");

            }
        });

        pane.getChildren().addAll(red, blue, label);

        primaryStage.setScene(new Scene(pane, 300, 250));
        primaryStage.show();
    }

    private Circle createCircle(double x, double y, double r, final Color color, final Label statusLabel) {

        final Circle circle = new Circle(x, y, r);
        circle.setFill(color);

        circle.setOnDragOver(new EventHandler<DragEvent>() {

            @Override
            public void handle(DragEvent event) {
                statusLabel.setText(color.toString() + " over");
                System.out.println("foo");
                if (event.getGestureSource() != circle) {


                    event.acceptTransferModes(TransferMode.ANY);
                }
            }
        });

        circle.setOnDragDropped(new EventHandler<DragEvent>() {

            @Override
            public void handle(DragEvent arg0) {
                statusLabel.setText(color.toString() + " dropped");
            }
        });

        circle.setOnDragDetected(new EventHandler<MouseEvent>() {

            @Override
            public void handle(MouseEvent arg0) {
                circle.startDragAndDrop(TransferMode.ANY);
                Dragboard db = circle.startDragAndDrop(TransferMode.ANY);

                /*
                * Put a string on a dragboard
                */
                ClipboardContent content = new ClipboardContent();
                content.putString("foo");
                db.setContent(content);


                statusLabel.setText(color.toString() + " xxxxxxxxxxxxxxxxxxxxxxx");
            }
        });

        circle.setOnDragEntered(null);

        return circle;

    }
}
4

1 に答える 1

0

Cursorドラッグ アンド ドロップ アクションを管理できます。アクションセットで、 アクションで逆にし
ます。 カーソル アイコンを表示する代わりに、dn ドロップ中にマウス座標で画像を表示できます。circle.setOnDragDetected()circle.setCursor(Cursor.NONE);
circle.setOnDragDropped()circle.setCursor(Cursor.DEFAULT);

于 2012-04-16T08:47:40.300 に答える