关于javafxhbox的信息

博主:adminadmin 2023-01-12 07:12:07 615

本篇文章给大家谈谈javafxhbox,以及对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。

本文目录一览:

初学了一段时间Java。想做一个应用程序,程序只需要播放一个本地视频,MP4格式,求教怎么做

使用javafx的Media,MediaPlayer,MediaView。代码如下:

import java.io.File;

import javafx.application.Application;

import javafx.beans.binding.Bindings;

import javafx.beans.property.ReadOnlyProperty;

import javafx.beans.value.ObservableValue;

import javafx.event.ActionEvent;

import javafx.geometry.Pos;

import javafx.scene.Scene;

import javafx.scene.control.Button;

import javafx.scene.control.Menu;

import javafx.scene.control.MenuBar;

import javafx.scene.control.MenuItem;

import javafx.scene.control.Slider;

import javafx.scene.image.Image;

import javafx.scene.image.ImageView;

import javafx.scene.layout.BorderPane;

import javafx.scene.layout.HBox;

import javafx.scene.layout.Pane;

import javafx.scene.layout.VBox;

import javafx.scene.media.Media;

import javafx.scene.media.MediaPlayer;

import javafx.scene.media.MediaPlayer.Status;

import javafx.scene.media.MediaView;

import javafx.stage.FileChooser;

import javafx.stage.FileChooser.ExtensionFilter;

import javafx.stage.Stage;

import javafx.util.Duration;

public class App extends Application {

private MediaView mediaView;

private Slider processSlider;

private static final Object AUTO = new Object(), MANUAL = new Object();

public static void main(String[] args) {

launch(args);

}

@Override

public void start(Stage primaryStage) throws Exception {

primaryStage.setTitle("javafx视频播放器");

        

        BorderPane root = new BorderPane();

        // 菜单栏

        initMenu(root);

        // 视频播放控件

        mediaView = initMediaView(root);

        // 视频功能控件

        initMediaControllView(root);

        

        primaryStage.setScene(new Scene(root, 600, 400));

        primaryStage.setOnCloseRequest(event - System.exit(0));

        primaryStage.show();

}

private MenuBar initMenu(final BorderPane parent) {

        Menu menu = new Menu("菜单");

        MenuItem item = new MenuItem("打开");

        item.setOnAction(event - {

         FileChooser chooser = new FileChooser();

         chooser.setTitle("选择视频文件");

         chooser.getExtensionFilters().add(new ExtensionFilter("视频文件", "*.mp4", "*.flv"));

         File file = chooser.showOpenDialog(parent.getScene().getWindow());

         if (file != null) {

         MediaPlayer player = mediaView.getMediaPlayer();

         // 关闭当前的player

         if (player != null) {

         player.stop();

         player.dispose();

         }

         processSlider.setValue(0);

         // 创建一个新的player并自动播放

         player = new MediaPlayer(new Media(file.toURI().toString()));

         player.currentTimeProperty().addListener(this::mediaProcessChanged);

         player.setAutoPlay(true);

         mediaView.setMediaPlayer(player);

         }

        });

        menu.getItems().add(item);

        

        item = new MenuItem("退出");

        item.setOnAction(event - parent.getScene().getWindow().hide());

        menu.getItems().add(item);

        

        MenuBar menuBar = new MenuBar(menu);

        parent.setTop(menuBar);

        return menuBar;

}

private MediaView initMediaView(final BorderPane parent) {

        MediaView view = new MediaView();

        Pane pane = new Pane(view);

        parent.setCenter(pane);

        // 视频宽高可随着窗口变化而自动缩放

        view.fitWidthProperty().bind(Bindings.selectDouble(view.parentProperty(), "width"));

        view.fitHeightProperty().bind(Bindings.selectDouble(view.parentProperty(), "height"));

        view.setPreserveRatio(true);

        

return view;

}

private void initMediaControllView(final BorderPane parent) {

VBox bottom = new VBox(10);

bottom.setAlignment(Pos.CENTER);

parent.setBottom(bottom);

Slider slider = new Slider(0, 100, 0);

slider.valueProperty().addListener(this::processSliderChanged);

// slider.setOnMouseClicked(this::processSliderClicked);

bottom.getChildren().add(slider);

processSlider = slider;

HBox hbox = new HBox(10);

bottom.getChildren().add(hbox);

hbox.setAlignment(Pos.CENTER);

Button btn = new Button(null, new ImageView(loadImage("pause.png")));

btn.setOnAction(this::pauseOrPlay);

hbox.getChildren().add(btn);

btn = new Button(null, new ImageView(loadImage("stop.png")));

btn.setOnAction(this::stopPlay);

hbox.getChildren().add(btn);

}

private static Image loadImage(String resPath) {

return new Image(Thread.currentThread().getContextClassLoader().getResourceAsStream(resPath));

}

private void pauseOrPlay(ActionEvent event) {

MediaPlayer player = mediaView.getMediaPlayer();

if (player == null) {

return;

}

Status status = player.getStatus();

if (status == Status.READY || status == Status.PAUSED) {

player.play();

((Button) event.getTarget()).setGraphic(new ImageView(loadImage("pause.png")));

} else if (status == Status.PLAYING) {

player.pause();

((Button) event.getTarget()).setGraphic(new ImageView(loadImage("play.png")));

}

}

private void stopPlay(ActionEvent event) {

MediaPlayer player = mediaView.getMediaPlayer();

if (player == null) {

return;

}

player.stop();

}

// private void processSliderClicked(MouseEvent event) {

// Slider slider = (Slider) event.getSource();

// if (mediaView.getMediaPlayer() != null) {

// Duration d = mediaView.getMediaPlayer().getTotalDuration().multiply(slider.getValue() / slider.getMax());

// mediaView.getMediaPlayer().seek(d);

// }

// }

private void processSliderChanged(ObservableValue? extends Number observable, Number oldValue, Number newValue) {

Slider slider = (Slider) ((ReadOnlyProperty? extends Number) observable).getBean();

if (slider.getUserData() == AUTO) { // 进度条是自动改变的,因此不用设置播放器

slider.setUserData(null);

return;

}

if (mediaView.getMediaPlayer() != null) {

slider.setUserData(MANUAL);

Duration d = mediaView.getMediaPlayer().getTotalDuration().multiply(newValue.doubleValue() / slider.getMax());

mediaView.getMediaPlayer().seek(d);

}

}

private void mediaProcessChanged(ObservableValue? extends Duration observable, Duration oldValue, Duration newValue) {

if (processSlider.getUserData() == MANUAL) { // 手动点击进度条

processSlider.setUserData(null);

return;

}

MediaPlayer player = (MediaPlayer) ((ReadOnlyProperty? extends Duration) observable).getBean();

processSlider.setUserData(AUTO);

processSlider.setValue(newValue.toMillis() / player.getTotalDuration().toMillis() * 100);

}

}

java 如何开发3d可视化

使用之前

在开始使用 ThingJS 之前,需要先了解JavaScript,我们假设您已经掌握JS。

创建项目

创建项目之前需登录ThingJS账号,如果您尚未登录账号或页面出现“登录已过期,请重新登录!”的提示,为保证项目的正确保存及运行,请您在账号登录之后再创建项目。您可通过以下三种方式创建项目:

选择菜单区域的“文件 - 新建项目”选项

点击工具栏“新建”图标,图标如右图所示:

请点击输入图片描述

请点击输入图片描述

使用快捷键“Ctrl+P”

编辑项目

在线开发为用户提供了相应的快捷代码和官方示例,如果你正在用 ThingJS在线开发页面,可以通过以下两种方式来编辑项目:

点击在线开发页面菜单区域的快捷代码选项中的子项,编辑区将自动插入相应代码

请点击输入图片描述

选择在线开发官方示例中的其中任意一个示例,点击相应示例,编辑区将显示相应代码

后续操作详见 在线开发 - 应用开发 - 在线开发网页链接

保存项目

可通过以下四种方式保存项目:

选择菜单区域的“文件 - 保存”选项

点击工具栏“保存”图标,图标如右图所示:

请点击输入图片描述

请点击输入图片描述

使用快捷键“Ctrl+S”

运行项目

在线开发环境提供了以下几种方式运行项目:

使用快捷方式“Ctrl+R/Enter”或点击工具栏中的“运行”图标,3d容器区域将运行编辑器相应的代码。图标如右图所示:

请点击输入图片描述

请点击输入图片描述

选择菜单区域的“工具 - 设置”选型,出现的设置面板,点击开启“自动保存执行”

请点击输入图片描述

Java如何让多个图片都按照一定轨迹下落

图片的位移(下落),可以通过修改图片的x,y坐标来实现, 在Swing/Html中,我们可以使用Timer定时(比如每隔100毫秒)去修改图片的x,y坐标即可实现,

多个图片都按照一定的轨迹移动,那都按照自己的轨迹的算法,去定时修改x,y坐标即可.

JavaFX是java先进的图形界面框架, 里面有3D和各种动画, 所以按照轨迹移动,都能轻松实现

JavaFX参考代码如下

import javafx.animation.Animation;

import javafx.animation.Interpolator;

import javafx.animation.PathTransition;

import javafx.animation.RotateTransition;

import javafx.application.Application;

import javafx.geometry.Insets;

import javafx.scene.Group;

import javafx.scene.Scene;

import javafx.scene.control.Button;

import javafx.scene.image.ImageView;

import javafx.scene.layout.HBox;

import javafx.scene.shape.MoveTo;

import javafx.scene.shape.Path;

import javafx.scene.shape.QuadCurveTo;

import javafx.stage.Stage;

import javafx.util.Duration;

public class PathAnimateDemo extends Application {

public static void main(String[] args) {

launch(args);

}

@Override

public void start(Stage primaryStage) throws Exception {

ImageView imv=new ImageView(getClass().getResource("ball.png").toExternalForm());

Path path = new Path();// 路径;运动轨迹

MoveTo mt = new MoveTo(20, 50);

QuadCurveTo quadTo2 = new QuadCurveTo(175, 190, 350, 30);

path.getElements().addAll(mt, quadTo2);

HBox hbox = new HBox(10);

Button btnStart = new Button("开始");

Button btnPause = new Button("暂停");

Button btnResume = new Button("继续");

Button btnStop = new Button("结束");

hbox.getChildren().addAll(btnStart, btnPause, btnResume, btnStop);

hbox.setPadding(new Insets(20));

hbox.setLayoutX(80);

hbox.setLayoutY(230);

Group root = new Group();

root.getChildren().addAll(imv, path, hbox); // 不添加path.就可以不显示path了

Scene scene = new Scene(root, 430, 300);

primaryStage.setTitle("JavaFX");

primaryStage.setScene(scene);

primaryStage.show();

//旋转动画设置

RotateTransition rt=new RotateTransition(Duration.millis(1000),imv);

rt.setInterpolator(Interpolator.LINEAR);

rt.setFromAngle(0);

rt.setToAngle(360);

rt.setCycleCount(Animation.INDEFINITE);

rt.play();

//路径动画设置

PathTransition pt = new PathTransition(Duration.millis(800), path, imv);// 路径动画

pt.setCycleCount(Animation.INDEFINITE);

pt.setAutoReverse(true);

btnStart.setOnAction(e - {

pt.playFromStart();// 从头开始播放

});

//----按钮的响应设置---

btnPause.setOnAction(e - {

pt.pause();

});

btnResume.setOnAction(e - {

pt.play(); // 播放

});

btnStop.setOnAction(e - {

pt.jumpTo(new Duration(0));// 跳到第0秒处

pt.stop();

});

}

}

关于javafx中TextArea不能随着界面变化改变大小的问题

要用布局管理器,textarea是子组件,具体怎么用,要看你的界面中使用了哪些组件,组件之间的关系是怎样的,希望达到的效果是怎么样的。

如果是像你图中的效果,你可以使用BorderPane,再建一个contentpane作为borderpane的center,这样contentpane就会随着整体界面大小自动缩放。

然后再将3个area或者再加一个button放在contentpane中,如果你希望3个area可以拖动,就再用spliterpane包着area,如果不希望拖动,就用hbox和vbox控制area就可以了。

javafx hbox怎么设为两行

logo_16;images/.class外面套一个Group.addAll(new ImageView(new Image(this。 group.getResourceAsStream(".getChildren(),borderPane).png")))

javafxhbox的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于、javafxhbox的信息别忘了在本站进行查找喔。