java - CSS 解析文件 JavaFX 时出错,但我不知道出了什么问题

标签 java css eclipse javafx

从我的程序中我收到此错误: Eclipse console output

我想做的就是使用按钮上的悬停效果将文本变成白色。 这是我的代码: Main.java:

import java.util.Date;

import javafx.application.Application;
import javafx.collections.FXCollections;
import javafx.collections.ObservableList;
import javafx.event.EventHandler;
import javafx.fxml.FXMLLoader;
import javafx.scene.Scene;
import javafx.scene.control.TableView;
import javafx.scene.input.MouseEvent;
import javafx.scene.layout.Pane;
import javafx.scene.layout.VBox;
import javafx.stage.Stage;

public class Main extends Application {


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

@Override
public void start(Stage primaryStage) throws Exception {
    Pane mainPane = (Pane) FXMLLoader.load(Main.class.getResource("Main.fxml"));
    primaryStage.setScene(new Scene(mainPane));
    primaryStage.show();
    }

}

这是我的 Main.fxml 文件:

<?xml version="1.0" encoding="UTF-8"?>

<?import javafx.scene.image.*?>
<?import javafx.scene.shape.*?>
<?import javafx.scene.effect.*?>
<?import javafx.scene.text.*?>
<?import javafx.geometry.*?>
<?import javafx.scene.control.*?>
<?import java.lang.*?>
<?import javafx.scene.layout.*?>

<Pane maxHeight="-Infinity" maxWidth="-Infinity" minHeight="-Infinity" minWidth="-Infinity" prefHeight="318.0" prefWidth="1000.0" stylesheets="@myStyle.css" xmlns="http://javafx.com/javafx/8" xmlns:fx="http://javafx.com/fxml/1" fx:controller="MyController">
   <children>
      <TextField fx:id="tf_input" alignment="BOTTOM_RIGHT" editable="true" layoutX="450.0" layoutY="22.0" prefHeight="35.0" prefWidth="300.0" styleClass="display">
         <font>
            <Font name="Lucida Console" size="20.0" />
         </font>
         <effect>
            <DropShadow />
         </effect>
      </TextField>
      <Button fx:id="bOne" layoutX="472.0" layoutY="102.0" mnemonicParsing="false" onAction="#click1" prefHeight="35.0" prefWidth="64.0" text="1" />
      <Button fx:id="bTwo" layoutX="536.0" layoutY="102.0" mnemonicParsing="false" onAction="#click2" prefHeight="35.0" prefWidth="64.0" text="2" />
      <Button fx:id="bThree" layoutX="600.0" layoutY="102.0" mnemonicParsing="false" onAction="#click3" prefHeight="35.0" prefWidth="64.0" text="3" />
      <Button fx:id="bSix" layoutX="600.0" layoutY="137.0" mnemonicParsing="false" onAction="#click6" prefHeight="35.0" prefWidth="64.0" text="6" />
      <Button fx:id="bFive" layoutX="536.0" layoutY="137.0" mnemonicParsing="false" onAction="#click5" prefHeight="35.0" prefWidth="64.0" text="5" />
      <Button fx:id="bFour" layoutX="472.0" layoutY="137.0" mnemonicParsing="false" onAction="#click4" prefHeight="35.0" prefWidth="64.0" text="4" />
      <Button fx:id="bNine" layoutX="600.0" layoutY="172.0" mnemonicParsing="false" onAction="#click9" prefHeight="35.0" prefWidth="64.0" text="9" />
      <Button fx:id="bEight" layoutX="536.0" layoutY="172.0" mnemonicParsing="false" onAction="#click8" prefHeight="35.0" prefWidth="64.0" text="8" />
      <Button fx:id="bSeven" layoutX="472.0" layoutY="172.0" mnemonicParsing="false" onAction="#click7" prefHeight="35.0" prefWidth="64.0" text="7" />
      <Button fx:id="bB" layoutX="536.0" layoutY="207.0" mnemonicParsing="false" onAction="#clickB" prefHeight="35.0" prefWidth="64.0" text="B" />
      <Button fx:id="bA" layoutX="472.0" layoutY="207.0" mnemonicParsing="false" onAction="#clickA" prefHeight="35.0" prefWidth="64.0" text="A" />
      <Button fx:id="bZero" layoutX="472.0" layoutY="68.0" mnemonicParsing="false" onAction="#click0" prefHeight="35.0" prefWidth="64.0" text="0" />
      <Button fx:id="bE" layoutX="536.0" layoutY="242.0" mnemonicParsing="false" onAction="#clickE" prefHeight="35.0" prefWidth="64.0" text="E" />
      <Button fx:id="bD" layoutX="472.0" layoutY="242.0" mnemonicParsing="false" onAction="#clickD" prefHeight="35.0" prefWidth="64.0" text="D" />
      <Button fx:id="bC" layoutX="600.0" layoutY="207.0" mnemonicParsing="false" onAction="#clickC" prefHeight="35.0" prefWidth="64.0" text="C" />
      <Button fx:id="bF" layoutX="600.0" layoutY="242.0" mnemonicParsing="false" onAction="#clickF" prefHeight="35.0" prefWidth="64.0" text="F" />
      <Button fx:id="bPlus" layoutX="664.0" layoutY="102.0" mnemonicParsing="false" onAction="#clickplus" prefHeight="35.0" prefWidth="64.0" text="+" />
      <Button fx:id="bMinus" layoutX="664.0" layoutY="137.0" mnemonicParsing="false" onAction="#clickminus" prefHeight="35.0" prefWidth="64.0" text="-" />
      <Button fx:id="bDivide" layoutX="664.0" layoutY="207.0" mnemonicParsing="false" onAction="#clickdivide" prefHeight="35.0" prefWidth="64.0" text="/" />
      <Button fx:id="bTimes" layoutX="664.0" layoutY="172.0" mnemonicParsing="false" onAction="#clicktimes" prefHeight="35.0" prefWidth="64.0" text="*" />
      <Button fx:id="bEquals" layoutX="664.0" layoutY="242.0" mnemonicParsing="false" onAction="#clickequals" prefHeight="35.0" prefWidth="64.0" text="=" />
      <Label alignment="CENTER" layoutX="798.0" layoutY="21.0" prefHeight="23.0" prefWidth="161.0" styleClass="display" text="Output:">
         <font>
            <Font name="Lucida Console" size="20.0" />
         </font>
      </Label>
          <TextField fx:id="tf_output" alignment="BOTTOM_RIGHT" editable="false" layoutX="769.0" layoutY="68.0" prefHeight="153.0" prefWidth="219.0" styleClass="display">
         <font>
            <Font name="Lucida Console" size="20.0" />
         </font>
         <effect>
            <InnerShadow />
         </effect>
      </TextField>
      <Button fx:id="bAc" layoutX="600.0" layoutY="68.0" mnemonicParsing="false" onAction="#clickclear" prefHeight="35.0" prefWidth="64.0" text="AC" />
      <Button fx:id="bDel" layoutX="536.0" layoutY="68.0" mnemonicParsing="false" onAction="#clickdel" prefHeight="35.0" prefWidth="64.0" text="DEL" />
      <Button fx:id="bSquare" layoutX="664.0" layoutY="68.0" mnemonicParsing="false" onAction="#clicksquare" prefHeight="35.0" prefWidth="64.0" text="^2" />
      <RadioButton fx:id="Insixteen" layoutX="50.0" layoutY="121.0" mnemonicParsing="false" onAction="#clickin16" selected="true" text="Base 16 (Hex)" />
      <RadioButton fx:id="Inten" layoutX="50.0" layoutY="87.0" mnemonicParsing="false" onAction="#clickin10" text="Base 10 (Denary)" />
      <RadioButton fx:id="Intwo" layoutX="50.0" layoutY="53.0" mnemonicParsing="false" onAction="#clickin2" text="Base 2 (Binary)" />
      <Label alignment="BOTTOM_RIGHT" layoutX="50.0" layoutY="22.0" prefHeight="21.0" prefWidth="136.0" text="Base Input:" underline="true">
         <font>
            <Font name="Lucida Console" size="20.0" />
         </font>
      </Label>
      <Label alignment="BOTTOM_RIGHT" layoutX="234.0" layoutY="22.0" prefHeight="21.0" prefWidth="147.0" text="Base Output:" underline="true">
         <font>
            <Font name="Lucida Console" size="20.0" />
         </font>
      </Label>
      <RadioButton fx:id="Outtwo" layoutX="234.0" layoutY="53.0" mnemonicParsing="false" onAction="#clickout2" text="Base 2 (Binary)" />
      <RadioButton fx:id="Outten" layoutX="234.0" layoutY="87.0" mnemonicParsing="false" onAction="#clickout10" selected="true" text="Base 10 (Denary)" />
      <RadioButton fx:id="Outsixteen" layoutX="234.0" layoutY="121.0" mnemonicParsing="false" onAction="#clickout16" text="Base 16 (Hex)" />
   </children>
</Pane>

这是 MyController.java:

import javafx.event.ActionEvent;
import javafx.fxml.FXML;
import javafx.scene.control.Button;
import javafx.scene.control.RadioButton;
import javafx.scene.control.TextField;

public class MyController {

@FXML
private RadioButton Inten;

@FXML
private Button bMinus;

@FXML
private Button bTimes;

@FXML
private Button bOne;

@FXML
private Button bSix;

@FXML
private Button bDivide;

@FXML
private Button bEquals;

@FXML
private TextField tf_output;

@FXML
private Button bThree;

@FXML
private Button bPlus;

@FXML
private RadioButton Outten;

@FXML
private Button bA;

@FXML
private RadioButton Intwo;

@FXML
private Button bB;

@FXML
private Button bC;

@FXML
private Button bD;

@FXML
private Button bE;

@FXML
private Button bF;

@FXML
private Button bDel;

@FXML
private Button bZero;

@FXML
private Button bAc;

@FXML
private TextField tf_input;

@FXML
private Button bTwo;

@FXML
private RadioButton Outtwo;

@FXML
private Button bSquare;

@FXML
private RadioButton Outsixteen;

@FXML
private Button bFour;

@FXML
private Button bFive;

@FXML
private Button bEight;

@FXML
private Button bSeven;

@FXML
private RadioButton Insixteen;

@FXML
private Button bNine;

@FXML
void click1(ActionEvent event) {

}

@FXML
void click2(ActionEvent event) {

}

@FXML
void click3(ActionEvent event) {

}

@FXML
void click6(ActionEvent event) {

}

@FXML
void click5(ActionEvent event) {

}

@FXML
void click4(ActionEvent event) {

}

@FXML
void click9(ActionEvent event) {

}

@FXML
void click8(ActionEvent event) {

}

@FXML
void click7(ActionEvent event) {

}

@FXML
void clickB(ActionEvent event) {

}

@FXML
void clickA(ActionEvent event) {

}

@FXML
void click0(ActionEvent event) {

}

@FXML
void clickE(ActionEvent event) {

}

@FXML
void clickD(ActionEvent event) {

}

@FXML
void clickC(ActionEvent event) {

}

@FXML
void clickF(ActionEvent event) {

}

@FXML
void clickplus(ActionEvent event) {

}

@FXML
void clickminus(ActionEvent event) {

}

@FXML
void clickdivide(ActionEvent event) {

}

@FXML
void clicktimes(ActionEvent event) {

}

@FXML
void clickequals(ActionEvent event) {

}

@FXML
void clickclear(ActionEvent event) {

}

@FXML
void clickdel(ActionEvent event) {

}

@FXML
void clicksquare(ActionEvent event) {

}

@FXML
void clickin16(ActionEvent event) {

}

@FXML
void clickin10(ActionEvent event) {

}

@FXML
void clickin2(ActionEvent event) {

}

@FXML
void clickout2(ActionEvent event) {

}

@FXML
void clickout10(ActionEvent event) {

}

@FXML
void clickout16(ActionEvent event) {

}

}

最后这是我的 myStyle.css 文件:

@charset "ISO-8859-1";
.button:hover{
    -fx-text-fill: #fffff;
}

到目前为止,我只有一个月的时间来编程,所以请不要批评我的代码或我容易犯的错误。提前感谢您帮助解决问题,我使用场景生成器和 CSS 样式表不到一天,但我需要快速取得进展,因为我已经有近 5 年没有像今年剩下的时间那样编程了。

最佳答案

JavaFX CSS 不支持完整的 CSS 规范;只是其中的一个子集。特别是唯一的“@-Rules”listed as supported@import@font-face。因此,第一行的 @charset 规则不受支持。

删除 CSS 文件的第一行(包含 @charset)将使 CSS 文件能够被解析。

此外,您还说过希望文本在悬停时变成白色:您需要 #ffffff (六个“f”);你有#fffff(只有五个“f”)。

关于java - CSS 解析文件 JavaFX 时出错,但我不知道出了什么问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46932089/

相关文章:

html - 由于div在里面的绝对位置,section高度为0

eclipse e4 - 如何在值更改后注入(inject)来自 ConfigurationScope 的首选项值?

java - 使用 Java/Scala 解析与硬件的 ASCII 通信?

java - 捕获 Throwable 或 Exception 为空

css - Bootstrap 中的偏移量不起作用。

html - 如何覆盖 Bootstrap 面板标题颜色

java web应用程序-servlet检测请求

java - 重命名包后Eclipse “Error: Could not find or load main class”

java - Hibernate限制中限制 'equals id'区分大小写

java - 如何在visualvm中启用跟踪分析?