目录
问题内容
解决方法
首页 Java JAVA:按下按钮时在边框窗格中移动对象

JAVA:按下按钮时在边框窗格中移动对象

Feb 10, 2024 pm 01:40 PM
点击事件

php小编新一今天为大家介绍一种有趣的JAVA编程技巧:按下按钮时在边框窗格中移动对象。这种技巧可以为用户界面增加一些交互性,让用户能够通过点击按钮来移动对象。这种功能的实现方法相对简单,只需要通过监听按钮的点击事件,并在事件处理方法中更新对象的位置即可。通过这种方式,我们可以为用户提供更加生动、有趣的界面体验。下面我们就来详细介绍一下这种技巧的实现过程。

问题内容

我正在做一项家庭作业,我需要在窗格中创建一个圆圈并使用屏幕底部的按钮移动它。我能够让圆圈和按钮出现在窗格中,但是当我按下按钮时,圆圈不会移动。

我的主要方法如下:

import javafx.application.application;
import javafx.event.actionevent;
import javafx.event.eventhandler;
import javafx.geometry.insets;
import javafx.geometry.pos;
import javafx.scene.scene;
import javafx.scene.control.button;
import javafx.scene.layout.borderpane;
import javafx.scene.layout.hbox;
import javafx.scene.layout.pane;
import javafx.scene.paint.color;
import javafx.scene.shape.circle;
import javafx.stage.stage;


public class moveball extends application {  
  @override
  public void start(stage primarystage) {
    circle ball = new circle(10);
    button btup = new button("up");
    button btdown = new button("down");
    button btleft = new button("left");
    button btright = new button("right");
    
    
    hbox pane = new hbox();
    borderpane bpane = new borderpane();
    
    
    
    ball.setfill(color.red);
    ball.setstroke(color.black);
    pane.setspacing(10);
    pane.setalignment(pos.center);
    pane.getchildren().addall(btup, btdown, btleft, btright);
    bpane.setcenter(ball);
    bpane.setbottom(pane);
    
    btup.setonaction((actionevent e) -> ballcontrol.moveup(ball));
    btdown.setonaction((actionevent e) -> ballcontrol.movedown(ball));
    btleft.setonaction((actionevent e) -> ballcontrol.moveleft(ball));
    btright.setonaction((actionevent e) -> ballcontrol.moveright(ball));
    
    
  
  scene scene = new scene(bpane, 400, 400);
  primarystage.setscene(scene);
  primarystage.settitle("move the ball");
  primarystage.show();
  }
  
  public static void main (string[] args)  
  {  
      launch(args);  
  }  
  
  
}
登录后复制

实际移动圆的方法在这里:

class BallControl{
  public static void moveUp(Circle circle){
    if(circle.getCenterY() - circle.getRadius() - 10 < 0) return;
      circle.setCenterY(circle.getCenterY() - 10);
  }
      
  public static void moveDown(Circle circle){
    if(circle.getCenterY() + circle.getRadius() + 10 > 400) return;
    circle.setCenterY(circle.getCenterY() + 10);
  }
          
  public static void moveLeft(Circle circle){
    if(circle.getCenterX() - circle.getRadius() - 10 < 0) return;
    circle.setCenterX(circle.getCenterX() - 10);
  }
              
    public static void moveRight(Circle circle){
      if(circle.getCenterX() + circle.getRadius() + 10 > 400) return;
      circle.setCenterX(circle.getCenterX() + 10);
    }
}
登录后复制

ballcontrol 方法的目的是检查移动圆是否会将其延伸到窗口边界之外,如果不会,则移动它。但按下按钮时,圆圈永远不会移动。

解决方法

borderpane 是一种“布局窗格”,这意味着它将根据自己的算法布局其子节点。特别是,如果该节点可调整大小,并且在其最小、最大和首选大小指定的约束范围内,则 borderpane 将扩展 center 区域中的节点以填充整个区域,然后将其在该区域内居中。 circle 不可调整大小,因此它仅在该区域居中。

修改圆的 centerxcentery 坐标在这里不会有帮助:圆的布局边界将是一个大约 20x20 像素的矩形(因为半径为 10,所以这是包含圆的最小矩形;“大约”在这里是因为笔划可能需要一些额外的空间)。该矩形将具有一个从中心半径开始并延伸到中心+半径的坐标系,但随后它将根据边框窗格的布局策略在中心区域居中。实际上,圆心的坐标发生了变化,但这些坐标仅在圆本身的坐标系内,而不在边框窗格的坐标系内。

一种解决方案是将圆圈包裹在不执行布局的常规 pane 中,并将 pane 放置在 borderpane 的中心。 pane 的大小是可调整的,因此 borderpane 会将其大小调整为中心区域的完整大小。 pane 不会对圆进行布局,因此它保留在 pane 中,并将 pane 放置在 borderpane 的中心。 pane 的大小是可调整的,因此 borderpane 会将其大小调整为中心区域的完整大小。 pane 不会对圆进行布局,因此它保留在 centerxcentery 定义的坐标上,而无需任何其他布局。 (实际上,您使圆的坐标系与窗格的坐标系相同。)这是我在下面的代码中使用的解决方案。

另一个解决方案是操作圆的 translatextranslatey 属性。这些变换在布局之后应用。然而,使用此解决方案,防止圆脱离其容器的边界变得更加复杂。 (我没有在下面的代码中展示这个解决方案。)

请参阅布局文档 了解更多详情。

这里是使此工作正常进行的修改。请注意,我还修改了边界的计算方式,因此即使调整窗口大小,它仍然有效。

package org.jamesd.examples.movingball;

import javafx.application.Application;
import javafx.event.ActionEvent;
import javafx.geometry.Pos;
import javafx.scene.Scene;
import javafx.scene.control.Button;
import javafx.scene.layout.BorderPane;
import javafx.scene.layout.HBox;
import javafx.scene.layout.Pane;
import javafx.scene.paint.Color;
import javafx.scene.shape.Circle;
import javafx.stage.Stage;


public class MoveBall extends Application {
    @Override
    public void start(Stage primaryStage) {
        Circle ball = new Circle(200, 200, 10);
        Button btUp = new Button("Up");
        Button btDown = new Button("Down");
        Button btLeft = new Button("Left");
        Button btRight = new Button("Right");


        HBox controls = new HBox();
        BorderPane bPane = new BorderPane();



        ball.setFill(Color.RED);
        ball.setStroke(Color.BLACK);
        controls.setSpacing(10);
        controls.setAlignment(Pos.CENTER);
        controls.getChildren().addAll(btUp, btDown, btLeft, btRight);

        Pane ballPane = new Pane(ball);
        bPane.setCenter(ballPane);
        bPane.setBottom(controls);

        btUp.setOnAction((ActionEvent e) -> moveUp(ball));
        btDown.setOnAction((ActionEvent e) -> moveDown(ball));
        btLeft.setOnAction((ActionEvent e) -> moveLeft(ball));
        btRight.setOnAction((ActionEvent e) -> moveRight(ball));



        Scene scene = new Scene(bPane, 400, 400);
        primaryStage.setScene(scene);
        primaryStage.setTitle("Move the Ball");
        primaryStage.show();
    }

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

    public void moveUp(Circle circle){
        if(circle.getCenterY() - circle.getRadius() - 10 < 0) return;
        circle.setCenterY(circle.getCenterY() - 10);
    }

    public void moveDown(Circle circle){
        if(circle.getCenterY() + circle.getRadius() + 10 > circle.getParent().getBoundsInLocal().getHeight()) return;
        circle.setCenterY(circle.getCenterY() + 10);
    }

    public void moveLeft(Circle circle){
        System.out.println(circle.getBoundsInLocal());
        if(circle.getCenterX() - circle.getRadius() - 10 < 0) return;
        circle.setCenterX(circle.getCenterX() - 10);
    }

    public void moveRight(Circle circle){
        if(circle.getCenterX() + circle.getRadius() + 10 > circle.getParent().getBoundsInLocal().getWidth()) return;
        circle.setCenterX(circle.getCenterX() + 10);
    }
}
登录后复制

以上是JAVA:按下按钮时在边框窗格中移动对象的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

利用Golang开发功能强大的桌面应用 利用Golang开发功能强大的桌面应用 Mar 19, 2024 pm 05:45 PM

利用Golang开发功能强大的桌面应用随着互联网的不断发展,人们已经离不开各种类型的桌面应用程序。而对于开发人员来说,如何利用高效的编程语言来开发功能强大的桌面应用至关重要。本文将介绍如何利用Golang(Go语言)来开发功能强大的桌面应用,并提供一些具体的代码示例。Golang是一种由Google开发的开源编程语言,它具有简洁、高效、并发性强等特点,非常适

layui登陆页面怎么设置跳转 layui登陆页面怎么设置跳转 Apr 04, 2024 am 03:12 AM

layui 登录页面跳转设置步骤:添加跳转代码:在登录表单提交按钮点击事件中添加判断,成功登录后通过 window.location.href 跳转到指定页面。修改 form 配置:在 lay-filter="login" 的 form 元素中添加 hidden 输入字段,name 为 "redirect",value 为目标页面地址。

vue中图片怎么添加碰事件 vue中图片怎么添加碰事件 May 02, 2024 pm 10:21 PM

如何为 Vue 中的图片添加点击事件?导入 Vue 实例。创建 Vue 实例。在 HTML 模板中添加图片。使用 v-on:click 指令添加点击事件。在 Vue 实例中定义 handleClick 方法。

鸿蒙 HarmonyOS 与 Go 语言开发 鸿蒙 HarmonyOS 与 Go 语言开发 Apr 08, 2024 pm 04:48 PM

鸿蒙HarmonyOS与Go语言开发简介鸿蒙HarmonyOS是华为开发的分布式操作系统,而Go是一种现代化的编程语言,两者的结合为开发分布式应用提供了强大的解决方案。本文将介绍如何在HarmonyOS中使用Go语言进行开发,并通过实战案例加深理解。安装与设置要使用Go语言开发HarmonyOS应用,你需要首先安装GoSDK和HarmonyOSSDK。具体步骤如下:#安装GoSDKgogetgithub.com/golang/go#设置PATH

PHP技巧:快速实现返回上一页功能 PHP技巧:快速实现返回上一页功能 Mar 09, 2024 am 08:21 AM

PHP技巧:快速实现返回上一页功能在网页开发中,经常会遇到需要实现返回上一页的功能。这样的操作可以提高用户体验,让用户更加方便地在网页之间进行导航。在PHP中,我们可以通过一些简单的代码来实现这一功能。本文将介绍如何快速实现返回上一页功能,并提供具体的PHP代码示例。在PHP中,我们可以使用$_SERVER['HTTP_REFERER']来获取上一页的URL

C++ 函数在并发编程中的事件驱动机制? C++ 函数在并发编程中的事件驱动机制? Apr 26, 2024 pm 02:15 PM

并发编程中的事件驱动机制通过在事件发生时执行回调函数来响应外部事件。在C++中,事件驱动机制可用函数指针实现:函数指针可以注册回调函数,在事件发生时执行。lambda表达式也可以实现事件回调,允许创建匿名函数对象。实战案例使用函数指针实现GUI按钮点击事件,在事件发生时调用回调函数并打印消息。

JavaScript 获取网页元素详解 JavaScript 获取网页元素详解 Apr 09, 2024 pm 12:45 PM

答案:JavaScript提供了多种获取网页元素的方法,包括使用id、标签名、类名和CSS选择器。详细描述:getElementById(id):根据唯一id获取元素。getElementsByTagName(tag):获取具有指定标签名的元素组。getElementsByClassName(class):获取具有指定类名的元素组。querySelector(selector):使用CSS选择器获取第一个匹配元素。querySelectorAll(selector):使用CSS选择器获取所有匹配

用 Python Tkinter 征服 GUI 世界:完整指南 用 Python Tkinter 征服 GUI 世界:完整指南 Mar 24, 2024 am 09:26 AM

Tkinter是python标准库中一个功能强大的GUI工具包,用于创建跨平台的图形用户界面(GUI)。它基于Tcl/Tk工具包,提供简单直观的语法,使Python开发人员能够轻松快速地创建复杂的用户界面。Tkinter的优势跨平台兼容性:Tkinter应用程序可在windows、Mac和linux等所有主要操作系统上运行。简单易用:其语法清晰且易于学习,使初学者和经验丰富的开发人员都能轻松掌握。可扩展性:Tkinter提供了各种小部件和控件,使开发人员能够创建各种各样的用户界面。集成性:它与P