Comment puis-je redimensionner automatiquement une image dans ImageView afin qu'elle corresponde toujours au nœud parent?
Voici un petit exemple de code:
@Override
public void start(Stage stage) throws Exception {
BorderPane pane = new BorderPane();
ImageView img = new ImageView("http://...");
//didn't work for me:
//img.fitWidthProperty().bind(new SimpleDoubleProperty(stage.getWidth()));
pane.setCenter(img);
Scene scene = new Scene(pane);
stage.setScene(scene);
stage.show();
}
@Override
public void start(Stage stage) throws Exception {
BorderPane pane = new BorderPane();
ImageView img = new ImageView("http://...");
img.fitWidthProperty().bind(stage.widthProperty());
pane.setCenter(img);
Scene scene = new Scene(pane);
stage.setScene(scene);
stage.show();
}
C'est une meilleure solution que de lier la propriété width (car, souvent, lorsque vous liez un enfant à son conteneur, il peut ne pas être possible de réduire la taille du conteneur. À d'autres occasions, le conteneur pourrait même commencer automatiquement à grossir).
La solution ci-dessous consiste à remplacer un ImageView afin que nous puissions le laisser se comporter comme «redimensionnable», puis à fournir des implémentations pour les largeurs/hauteurs minimale, préférée et maximale. Il est également important de mettre en œuvre l’appel resize ().
class WrappedImageView extends ImageView
{
WrappedImageView()
{
setPreserveRatio(false);
}
@Override
public double minWidth(double height)
{
return 40;
}
@Override
public double prefWidth(double height)
{
Image I=getImage();
if (I==null) return minWidth(height);
return I.getWidth();
}
@Override
public double maxWidth(double height)
{
return 16384;
}
@Override
public double minHeight(double width)
{
return 40;
}
@Override
public double prefHeight(double width)
{
Image I=getImage();
if (I==null) return minHeight(width);
return I.getHeight();
}
@Override
public double maxHeight(double width)
{
return 16384;
}
@Override
public boolean isResizable()
{
return true;
}
@Override
public void resize(double width, double height)
{
setFitWidth(width);
setFitHeight(height);
}
}
Utilisez ScrollPane ou simplement Pane pour résoudre ce problème: Exemple:
img_view1.fitWidthProperty().bind(scrollpane_imageview1.widthProperty());
img_view1.fitHeightProperty().bind(scrollpane_imageview1.heightProperty());
Si vous souhaitez que ImageView s'intègre dans un cadre Windows, utilisez cette ligne de code: imageView.fitWidthProperty (). bind (scene.widthProperty ()).
Notez que j'utilise widthProperty de la scène et non de la scène . Exemple:
import Java.io.FileNotFoundException;
import javafx.application.Application;
import javafx.scene.Group;
import javafx.scene.Scene;
import javafx.scene.image.ImageView;
import javafx.stage.Stage;
public class MapViewer extends Application {
public static void main(String[] args) {
Application.launch(args);
}
@Override
public void start(Stage primaryStage) throws FileNotFoundException {
String strTitle = "Titulo de la Ventana";
int w_width = 800;
int w_height = 412;
primaryStage.setTitle(strTitle);
primaryStage.setWidth(w_width);
primaryStage.setHeight(w_height);
Group root = new Group();
Scene scene = new Scene(root);
final ImageView imv = new ImageView("file:C:/Users/utp/Documents/1.2008.png");
imv.fitWidthProperty().bind(scene.widthProperty());
imv.setPreserveRatio(true);
root.getChildren().add(imv);
primaryStage.setScene(scene);
primaryStage.show();
}
}
L'aspect radio de la scène (primaryStage) devrait être similaire à celui de l'image (1.2008.png)