我有一个列表视图,我使人们有可能通过重新排列拖和下降的元素,它工作正常,但我想用我自己的自定义的替换两个默认的图标。 我曾尝试与这两个的ListCell本身或其父母即的setCursor(Cursor.HAND)的setCursor(新ImageCursor(图片)),但没有得到体现拖动过程中,只有后,这不是我想要的。 任何人都知道如何去吗?
EDIT1:这个问题有没有关系如何创建一个重新排序,能够列表视图。 它是关于如何将ListView项的拖放和下降过程中更改默认光标。 这不是重复
如何创建JavaFX中重排,能够TableView中 ,因为它也有拖欧米茄下降过程中非常相同的默认光标的图标。
EDIT2:影响Windows和Linux操作系统:ES根据我的调查结果,不支持Mac OS X.
截图拖N -降不准图标
截图拖N -降允许图标
package sample;
import javafx.application.Application;
import javafx.collections.FXCollections;
import javafx.collections.ObservableList;
import javafx.scene.Scene;
import javafx.scene.SnapshotParameters;
import javafx.scene.control.ListCell;
import javafx.scene.control.ListView;
import javafx.scene.image.WritableImage;
import javafx.scene.input.*;
import javafx.scene.layout.Pane;
import javafx.stage.Stage;
public class Main extends Application {
@Override
public void start(Stage stage) throws Exception{
Pane pane = new Pane();
ObservableList<String> items = FXCollections.observableArrayList("test1", "test2", "test3", "test4");
ListView<String> lw = new ListView<>();
lw.setCellFactory(param -> new MyListCell());
lw.setItems(items);
pane.getChildren().add(lw);
stage.setTitle("RearrangeListView");
stage.setScene(new Scene(pane, 300, 150));
stage.show();
}
private class MyListCell extends ListCell<String> {
public MyListCell() {
setOnDragDetected(event -> {
if (getItem() == null) {
return;
}
if (event.getButton() == MouseButton.PRIMARY) {
WritableImage image = snapshot(new SnapshotParameters(), null);
Dragboard dragboard = startDragAndDrop(TransferMode.MOVE);
ClipboardContent content = new ClipboardContent();
content.putString("abc");
dragboard.setDragView(image);
dragboard.setContent(content);
//setCursor(Cursor.HAND);
event.consume();
}
});
setOnDragOver(event -> {
if (event.getGestureSource() != this && event.getDragboard().hasString()) {
event.acceptTransferModes(TransferMode.MOVE);
}
event.consume();
});
setOnDragEntered(event -> {
if (event.getGestureSource() != this && event.getDragboard().hasString()) {
setOpacity(0.3);
}
});
setOnDragExited(event -> {
if (event.getGestureSource() != this && event.getDragboard().hasString()) {
setOpacity(1);
}
});
setOnDragDropped(event -> {
if (getItem() == null) {
return;
}
Dragboard db = event.getDragboard();
boolean success = false;
if (db.hasString()) {
ObservableList<String> items = getListView().getItems();
String source = ((MyListCell) event.getGestureSource()).getItem();
String target = ((MyListCell) event.getGestureTarget()).getItem();
int sourceIdx = items.indexOf(source);
int targetIdx = items.indexOf(target);
//swap
items.set(sourceIdx, target);
items.set(targetIdx, source);
success = true;
}
event.setDropCompleted(success);
event.consume();
});
setOnDragDone(DragEvent::consume);
}
@Override
protected void updateItem(String item, boolean empty) {
super.updateItem(item, empty);
if (empty || item == null) {
setText(null);
} else {
setText(item);
}
}
}
public static void main(String[] args) {
launch(args);
}
}