繁体   English   中英

JavaFx8 VBox中心图片

[英]JavaFx8 VBox center image

我在ScrollPane中有一个JavaFx VBox:

VBox container = new VBox();
container.setAlignment(Pos.CENTER);

...

scrollPane.setContent(container);
scrollPane.setFitToWidth(true);
scrollPane.setHbarPolicy(ScrollBarPolicy.NEVER);
scrollPane.setVbarPolicy(ScrollBarPolicy.NEVER);
scrollPane.setMinWidth(150);
scrollPane.setPannable(true);

这个VBox的大小永远不会改变,我里面有一些标签,一个标签有一个用户图像,就像下一个图像(A)

图像被调整为某些高度,但我不知道该图像的大小,因此,如果图像的宽度大于VBox的宽度,则会发生这种情况(部分图像隐藏)(B)

但是我不想要这样,我想要类似下面的图像:(如果图像宽度大于VBox宽度,则隐藏图像的侧面)[C)

http://i.stack.imgur.com/B3DOK.png

我该怎么做?

我试图将一个矩形作为剪辑,在这个矩形中,我想显示图像的中心,但是同样发生了。

imageView.setClip(new Rectangle(centerX - recSize, centerY - recSize, recSize*2, recSize*2));

---------------带短片----------------

红色=原始图像

蓝色=可见图像的一部分

http://i.stack.imgur.com/mYbyF.png

尼斯(d)

不好:(E)(由于图像标签未正确居中。)

对不起,链接,我不能直接放置图像

在图像上设置视口而不是剪辑。

imageView.setViewport(
     new Rectangle2D(500, 320, 420, 300)
);

样品

这是一个样本。 它不会完全符合您的要求,因为即使您的问题中包含链接的图像,我也无法完全理解您要做什么。 但是我认为它应该为您提供足够的背景信息,使您可以学习完成所需的工作。

该示例在滚动窗格中创建一个图像视图作为图形。 图像视图将视口应用于图像,并以保留比例缩放视口。 这允许显示更大图像的缩放部分。 有点像缩略图剪辑(单击缩略图以显示完整图像)。

家

import javafx.application.Application;
import javafx.geometry.*;
import javafx.scene.*;
import javafx.scene.control.*;
import javafx.scene.effect.*;
import javafx.scene.image.*;
import javafx.scene.layout.VBox;
import javafx.scene.paint.Color;
import javafx.scene.text.*;
import javafx.stage.*;

// display a captioned image in a viewport.
// click the image to get an expanded view.
public class LabelWithImage extends Application {
    private static final double IMAGE_WIDTH = 150;

    @Override
    public void start(Stage stage) {
        Image image = new Image(IMAGE_LOC);
        ImageView imageView = new ImageView(
                image
        );
        imageView.setViewport(
                new Rectangle2D(500, 320, 420, 300)
        );
        imageView.setFitWidth(IMAGE_WIDTH);
        imageView.setPreserveRatio(true);

        Label labeledImage = createCaptionedImage(
                imageView,
                "Village Home"
        );

        addGlowOnMouseOver(labeledImage);
        labeledImage.setOnMouseClicked(event -> {
            displayFullImage(stage, image);
        });

        VBox vbox = new VBox( // vbox just there to mimic question askers structure.
                labeledImage
        );
        vbox.setPadding(new Insets(10));

        ScrollPane scrollPane = makeScrollable(vbox);

        Scene scene = new Scene(
                scrollPane
        );

        stage.setScene(scene);
        stage.show();

        stage.setMaxWidth(stage.getWidth());
        stage.setMaxHeight(stage.getHeight());
    }

    private void displayFullImage(Stage stage, Image image) {
        Stage displayStage = new Stage();

        displayStage.initStyle(StageStyle.UTILITY);
        displayStage.initModality(Modality.APPLICATION_MODAL);
        displayStage.initOwner(stage);
        displayStage.setScene(
                new Scene(
                        new Group(
                                new ImageView(
                                        image
                                )
                        )
                )
        );
        displayStage.show();
    }

    private void addGlowOnMouseOver(Node node) {
        Glow glow = new Glow();
        DropShadow shadow = new DropShadow(20, Color.GOLD);
        glow.setInput(shadow);

        node.setOnMousePressed(event -> node.setEffect(null));
        node.setOnMouseEntered(event -> node.setEffect(glow));
        node.setOnMouseExited(event -> node.setEffect(null));
    }

    private ScrollPane makeScrollable(Node node) {
        ScrollPane scrollPane = new ScrollPane(node);

        scrollPane.setHbarPolicy(ScrollPane.ScrollBarPolicy.NEVER);
        scrollPane.setVbarPolicy(ScrollPane.ScrollBarPolicy.NEVER);
        scrollPane.setPannable(true);

        return scrollPane;
    }

    private Label createCaptionedImage(ImageView imageView, String caption) {
        Label labeledImage = new Label(caption);

        labeledImage.setFont(Font.font("Athelas", FontPosture.ITALIC, 20));
        labeledImage.setStyle("-fx-background-color: cornsilk");
        labeledImage.setPadding(new Insets(0, 0, 5, 0));
        labeledImage.setGraphic(
                imageView
        );
        labeledImage.setContentDisplay(ContentDisplay.TOP);

        return labeledImage;
    }

    public static void main(String[] args) {
        launch(args);
    }

    private static final String IMAGE_LOC =
            "http://www.imgion.com/images/01/beautiful-village-home.jpg";
            // image courtesy of http://www.imgion.com which provides
            // "free images on large topics to share with your friends and on your blogs."
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM