👨‍💻 Kod Notları | JavaFX

JavaFx snippets ve kod notları

🎨 Kod Tarafında CSS Değiştirme

buttonDownload.setStyle("-fx-background-image: url('/images/verified.png')");

🚧 Thread ile Kodlama

JavaFX'de oluşturulan Thread, FX'in threadına uyumsuz olarak ilerleyebilmekte, bu durumda Not on FX application thread; currentThread = JavaFX Application Thread error? hatası gelemektedir.

  • FX (arayüzden) bağımsız Thread'lerdee sorun oluşmaz.

  • Arayüzü bağımlı Thread'lerde Platform.runAfter{() -> {}} yapısı kullanılır

  • Thread'i platformdan sonra başlat anlamına gelmektedir

new Thread(() -> {
Image resim = uzunSürenBirİşlem();
imageView.setImage(resim); // Bu udurmda thread ile FX yapısı kesişir ve hata verir
}).start();
new Thread(() -> {
Image resim = uzunSürenBirİşlem();
Platform.runAfter(() -> imageView.setImage(resim)); // Yapısı ile FX hazır olduktan sonra işlem yapılır
}).start();

✨ CSS ile Stil Oluşturma

  • Buton gibi alt öğrelere .buton css class'ı ile özellik tanımlayabilirsin

  • Her eleman içinde bulunduğu panelin css özelliğini taşır

🧱 FXML'de Kod Yapısı

<TextField prefWidth="50" text="${speedSlider.value}"/> <!-- Inline code -->
<Slider fx:id="speedSlider" orientation="HORIZONTAL" prefWidth="300"
min="60" max="100000" blockIncrement="100"/>

Slider'a göre Label'ı güncelleme

🍢 Slider Listener (Kaydırmalı çubuğun değişikliğine göre tepki verme)

Silder objesinden herhangi bir özelliği (...Property) alıp ona uygun listener ekleyebiliriz.

// Listener örneği
sliderQuality.valueProperty().addListener((observableValue, number, t1) -> {
updateFileSize();
});

Slider'a göre Label'ı güncelleme

🔳 Çerçeveleri Kaldırma

primaryStage.initStyle(StageStyle.TRANSPARENT);

👁‍🗨 Arkaplanı Transparant Yapma

  • İlk olarak .fxml dosyasındaki gerekli objeye style="-fx-background-color: transparent ;" özelliği ekleyin

  • Ardından kod tarafında alttaki düzeltmeyi yapın

primaryStage.setScene(new Scene(root));
primaryStage.getScene().setFill(Color.TRANSPARENT);

📋 Clipboard (Pano) İşlemleri

private void putClipboard(String clipboardString) {
StringSelection stringSelection = new StringSelection(clipboardString);
Clipboard clipboard = Toolkit.getDefaultToolkit().getSystemClipboard();
clipboard.setContents(stringSelection, null);
}
String getClipboard() throws IOException, UnsupportedFlavorException {
Clipboard clipboard = Toolkit.getDefaultToolkit().getSystemClipboard();
return (String) clipboard.getData(DataFlavor.stringFlavor);
}

🎴 ImageView Resmi Değiştirme

Bu işlem için resource dizini IntelliJ'de işaretlemeniz gerekmektedir.

import javafx.scene.image.Image;
// load an image in background, displaying a placeholder while it's loading
// (assuming there's an ImageView node somewhere displaying this image)
// The image is located in default package of the classpath
Image image1 = new Image("/flower.png", true);
// load an image and resize it to 100x150 without preserving its original
// aspect ratio
// The image is located in my.res package of the classpath
Image image2 = new Image("my/res/flower.png", 100, 150, false, false);
// load an image and resize it to width of 100 while preserving its
// original aspect ratio, using faster filtering method
// The image is downloaded from the supplied URL through http protocol
Image image3 = new Image("http://sample.com/res/flower.png", 100, 0, false, false);
// load an image and resize it only in one dimension, to the height of 100 and
// the original width, without preserving original aspect ratio
// The image is located in the current working directory
Image image4 = new Image("file:flower.png", 0, 100, false, false);

Oracle'ın resmi sitesinden alınmıştır.

📂 Dosya Sürükle Bırak İşlemleri

@FXML
private ImageView imageView;
@FXML
void handleDragOver(DragEvent event) {
if (event.getDragboard().hasFiles()) {
event.acceptTransferModes(TransferMode.ANY);
}
}
@FXML
void handleDragDropped(DragEvent event) throws FileNotFoundException {
List<File> files = event.getDragboard().getFiles();
Image img = new Image(new FileInputStream(files.get(0)));
imageView.setImage(img);
}