web-dev-qa-db-fra.com

Redimensionner les images pour les adapter au nœud parent

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();
}
31
rbs
@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();
}
53
The Unfun Cat

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);
    }
}
8
user458577

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());
4
Akshay Goyal

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)

1
dew