MediaView JavaFX FXML上的按钮

时间:2015-05-10 20:40:44

标签: java javafx javafx-2 javafx-8 fxml

我如何在MediaView组件上创建一个按钮,例如视频中心的播放按钮,点击时会消失。我正在使用FXML,所以如果你能用它来给我一个答案,那就更好了。

1 个答案:

答案 0 :(得分:2)

您可以在Button上同时在媒体播放器上轻松添加一个StackPane

然后在按钮上添加一个方法,所以当它点击按钮时它会被隐藏并且视频开始播放。

我还会添加一种方法,在视频结束后再次显示该按钮,让您重新开始。

这是FXML:

<AnchorPane prefHeight="480.0" prefWidth="640.0" xmlns="http://javafx.com/javafx/8" xmlns:fx="http://javafx.com/fxml/1" fx:controller="Controller">
    <children>
        <StackPane>
           <children>
              <MediaView>
                  <mediaPlayer>
                      <MediaPlayer fx:id="mediaPlayer" autoPlay="false">
                          <media>
                              <Media source="http://download.oracle.com/otndocs/products/javafx/oow2010-2.flv" />
                          </media>
                      </MediaPlayer>
                  </mediaPlayer>    
              </MediaView>
              <Button fx:id="button" mnemonicParsing="false" onAction="#playAndHide" text="Play Video" />
           </children>
        </StackPane>
    </children>
</AnchorPane>

这是Controller类:

@FXML private Button button;
@FXML private MediaPlayer mediaPlayer;

@Override
public void initialize(URL url, ResourceBundle rb) {
    mediaPlayer.setOnEndOfMedia(()->button.setVisible(true));
}    

@FXML
public void playAndHide(ActionEvent event){
    button.setVisible(false);
    mediaPlayer.seek(Duration.ZERO);
    mediaPlayer.play();
}