gpt4 book ai didi

JavaFx VBox 中心图像

转载 作者:太空宇宙 更新时间:2023-11-04 14:45:17 26 4
gpt4 key购买 nike

我在 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)

/image/B3DOK.png

我怎样才能做到这一点?

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

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

----------------带剪辑----------------

红色=原始图像

蓝色 = 图像的可见部分

/image/mYbyF.png

尼斯(D)

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

抱歉,通过链接,我无法直接放置图像

最佳答案

解决方案

Set a viewport图像上不是剪辑。

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

示例

这是一个示例。它不会完全符合您的要求,因为即使您问题中包含链接的图像,我也不太明白您想要做什么。但我认为它应该为您提供足够的背景信息,以便您可以学习完成您想要的事情。

该示例将 ImageView 创建为滚动 Pane 中的图形。 ImageView 将视口(viewport)应用于图像并以保留的比例缩放视口(viewport)。这允许显示更大图像的缩放部分。它有点像缩略图剪辑(单击缩略图可显示完整图像)。

home

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."
}

关于JavaFx VBox 中心图像,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24463064/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com