将 ImageViews 设置为按钮背景失败

Setting ImageViews as button background failing

上下文:我正在创建一个益智游戏作为项目的一部分,我已经完成了逻辑,只想为我的按钮设置背景。

我在此处找到的用于创建 BackgroundImages 的代码,当它设置背景时,每个按钮都会接收 ImageView 列表中的第一个元素。

这是显示每个按钮在 ImageView 列表中接收元素 0 的结果,下面我显示了所有 4 个元素只是为了检查我是否正确填充了 ImageView 列表。

List<Button> pieces = new ArrayList<>();
List<ImageView> images = new ArrayList<>();
VBox layout = new VBox();
HBox original = new HBox();
Image image = new Image("jalter.png");  
HBox imagesList = new HBox();   



for(int i = 0; i < 4; i++) { 
  pieces.add(new Button(String.valueOf(i+1)));
  pieces.get(i).setPrefSize(150,150);  

  images.add(new ImageView(image));  
  images.get(i).setViewport(new Rectangle2D(
  getX(toGridXY(i)) * 150,
  getY(toGridXY(i)) * 150,
  150,
  150));    

  BackgroundImage backgroundImage = new                     
  BackgroundImage
  (images.get(i).getImage(), 
  BackgroundRepeat.NO_REPEAT, 
  BackgroundRepeat.NO_REPEAT, 
  BackgroundPosition.DEFAULT, 
  BackgroundSize.DEFAULT);  
  Background background = new 
  Background(backgroundImage);      
  pieces.get(i).setBackground(background);      
}

您正在将每个背景设置为具有完全相同图像的背景。 ImageView.getImage() 只是去 return 你传递的原始图像;它不会将该图像裁剪到图像视图的视口。

相反,您可以使用原始图像的 pixelReader 创建一个新的 Image,并在 WritableImage 的构造函数中提供裁剪区域:

for(int i = 0; i < 4; i++) { 
  Button button = new Button(String.valueOf(i+1));
  pieces.add(button);
  button.setPrefSize(150,150);  

  Image croppedImage = new WritableImage(image.getPixelReader(),
    getX(toGridXY(i)) * 150,
    getY(toGridXY(i)) * 150,
    150,
    150);

  BackgroundImage backgroundImage = new BackgroundImage(
    croppedImage,
    BackgroundRepeat.NO_REPEAT, 
    BackgroundRepeat.NO_REPEAT, 
    BackgroundPosition.DEFAULT, 
    BackgroundSize.DEFAULT);  
  Background background = new Background(backgroundImage);      
  button.setBackground(background);      
}