So recently i have been working on a project and I need textfields to get the username and the password of the user.
I have tried using *-fx-background-insets: 0 0 0 0, 0, 0, 0;
to hide the border but the border on top still persists.
Here is the code:
-fx-background: whitesmoke; -fx-background-insets: 0 0 0 0, 0, 0, 0; -fx-background-radius: 0 ;
And here is the result. As you can see the border on top still persists:
Here is a style I got from https://dx.dragan.ba/javafx-textfield-custom-css/. It gets rid of all the borders except the bottom border.
CSS
* {
-fx-primary-color: #007acc;
-fx-secondary-color: #4B6EAF;
-fx-grey-color: #b9b9b9;
-fx-focus-color: -fx-secondary-color;
}
.root{
-fx-background-color: -fx-primary-color, white;
}
.text-field {
-fx-accent: -fx-primary-color;
-fx-background-color: -fx-grey-color, white;
-fx-background-insets: 0, 0 0 1 0;
-fx-background-radius: 0;
}
.text-field:focused {
-fx-background-color: -fx-primary-color, white;
}
Output
Overall, css seems to be working for everything but the buttons. I originally had this all in FXML but was told to switch it to straight JavaFX. Trying to get my buttons to follow their css again.
Is there a way to set button IDs in FX?
Any help would be appreciated, I've done a lot of looking through the documentation and some tutorials, but haven't been able to figure it out.
Here is my button code:
public class MainViewController extends Application {
private Button getStarted, getLoad, getHelp, returnToStart;
private TextArea tips;
private Pane mainPane, storyPane, helpPane;
public MainViewController() {
getStarted = new Button("S T A R T");
getLoad = new Button("L O A D");
getHelp = new Button("H E L P");
returnToStart = new Button("R T R N");
tips = new TextArea();
mainPane = new Pane();
storyPane = new Pane();
helpPane = new Pane();
//Main Pane Layouts
getStarted.setLayoutX(370);
getStarted.setLayoutY(164);
getStarted.setPrefHeight(35);
getStarted.setPrefWidth(110);
getStarted.getStyleClass().add("resources/css/MainView.css");
getLoad.setLayoutX(370);
getLoad.setLayoutY(215);
getLoad.setPrefHeight(35);
getLoad.setPrefWidth(110);
getLoad.getStyleClass().add("resources/css/MainView.css");
getHelp.setLayoutX(370);
getHelp.setLayoutY(266);
getHelp.setPrefHeight(35);
getHelp.setPrefWidth(110);
getHelp.getStyleClass().add("resources/css/MainView.css");
mainPane.getChildren().addAll(getStarted, getLoad, getHelp);
//Help Pane Layouts
returnToStart.setLayoutX(356);
returnToStart.setLayoutY(266);
returnToStart.setPrefHeight(35);
returnToStart.setPrefWidth(110);
}
#Override
public void start(Stage stage) throws Exception {
Scene mainView = new Scene(mainPane, 488, 322);
stage.setScene(mainView);
mainView.getStylesheets().add("resources/css/MainView.css");
stage.setTitle("Return to Monke");
stage.setResizable(false);
stage.getIcons().add(new Image("resources/images/monke_icon.png"));
stage.show();
Media opening = new Media(new File("src/resources/files/Opening.mp3").toURI().toString());
MediaPlayer openPlay = new MediaPlayer(opening);
openPlay.play();
openPlay.setCycleCount(MediaPlayer.INDEFINITE);
openPlay.setAutoPlay(true);
Media story = new Media(new File("src/resources/files/insert.mp3").toURI().toString());
MediaPlayer storyPlay = new MediaPlayer(story);
}
public static void main(String[] args) {
launch(args);
}
}
Here is my css:
.root {
-fx-background-image: url("../images/rtm.gif");
-fx-background-size: 100% 100%;
-fx-fill-width: 50%;
-fx-fill-heigt: 50%;
}
#Button {
-fx-font-family: "Roboto";
-fx-text-fill: black;
-fx-padding: 8 15 15 15;
-fx-background-insets: 0,0 0 5 0, 0 0 6 0, 0 0 7 0;
-fx-background-radius: 10;
-fx-background-color:
linear-gradient(from 0% 93% to 0% 100%, #9922a3 0%, #903482 100%),
#9d0096,
#c609d8,
radial-gradient(center 50% 50%, radius 100%, #a31e9d, #cb21a8);
-fx-effect: dropshadow( gaussian , rgba(0,0,0,0.75) , 4,0,0,1 );
-fx-font-weight: bold;
-fx-font-size: 1.1em;
-fx-opacity: 0.6;
}
#Button:hover {
-fx-background-color:
linear-gradient(from 0% 93% to 0% 100%, #903482 0%, #9922a3 100%),
#9d0096,
#c609d8,
radial-gradient(center 50% 50%, radius 100%, #d538bb, #c52da5);
}
#Button:pressed {
-fx-padding: 10 15 13 15;
-fx-background-insets: 2 0 0 0,2 0 3 0, 2 0 4 0, 2 0 5 0;
}
#Button Text {
-fx-fill: white;
-fx-effect: dropshadow(gaussian, #a30000, 0, 0, 0, 2);
}
#Load {
-fx-font-family: "Roboto";
-fx-text-fill: black;
-fx-padding: 8 15 15 15;
-fx-background-insets: 0,0 0 5 0, 0 0 6 0, 0 0 7 0;
-fx-background-radius: 10;
-fx-background-color:
linear-gradient(from 0% 93% to 0% 100%, #0AFA18 0%, #00CD0C 100%),
#019B0A,
#7AFF81,
radial-gradient(center 50% 50%, radius 100%, #0AFA18, #00CD0C);
-fx-effect: dropshadow( gaussian , rgba(0,0,0,0.75) , 4,0,0,1 );
-fx-font-weight: bold;
-fx-font-size: 1.1em;
-fx-opacity: 0.6;
}
#Load:hover {
-fx-background-color:
linear-gradient(from 0% 93% to 0% 100%, #9FFF84 0%, #81D26A 100%),
#60A54C,
#60A54C,
radial-gradient(center 50% 50%, radius 100%, #9FFF84, #60A54C);
}
#Load:pressed {
-fx-padding: 10 15 13 15;
-fx-background-insets: 2 0 0 0,2 0 3 0, 2 0 4 0, 2 0 5 0;
}
#Load Text {
-fx-fill: white;
-fx-effect: dropshadow(gaussian, #a30000, 0, 0, 0, 2);
}
#Help {
-fx-font-family: "Roboto";
-fx-text-fill: black;
-fx-padding: 8 15 15 15;
-fx-background-insets: 0,0 0 5 0, 0 0 6 0, 0 0 7 0;
-fx-background-radius: 10;
-fx-background-color:
linear-gradient(from 0% 93% to 0% 100%, #0086FC 0%, #0073D7 100%),
#0060B4,
#0060B4,
radial-gradient(center 50% 50%, radius 100%, #0086FC, #0060B4);
-fx-effect: dropshadow( gaussian , rgba(0,0,0,0.75) , 4,0,0,1 );
-fx-font-weight: bold;
-fx-font-size: 1.1em;
-fx-opacity: 0.6;
}
#Help:hover {
-fx-background-color:
linear-gradient(from 0% 93% to 0% 100%, #72BDFF 0%, #60A0D8 100%),
#4F86B6,
#4F86B6,
radial-gradient(center 50% 50%, radius 100%, #72BDFF, #4F86B6);
}
#Help:pressed {
-fx-padding: 10 15 13 15;
-fx-background-insets: 2 0 0 0,2 0 3 0, 2 0 4 0, 2 0 5 0;
}
#Help Text {
-fx-fill: white;
-fx-effect: dropshadow(gaussian, #a30000, 0, 0, 0, 2);
}```
Figured it out.
It's getStyleClass("name of CSS button")
I'm creating rulers using javafx by modifying css of javafx slider and I created something like this:
And I was trying to make this:
So I tried to rotate sliders by calling setRotate() method but it becomes like this:
Here is my code for sliders:
Slider hRuler = new Slider(0, 160, 10);
hRuler.showTickMarksProperty().setValue(true);
hRuler.showTickLabelsProperty().setValue(true);
hRuler.setRotate(180);
Slider vRuler = new Slider(0, 100, 10);
vRuler.setOrientation(Orientation.VERTICAL);
vRuler.showTickMarksProperty().setValue(true);
vRuler.showTickLabelsProperty().setValue(true);
vRuler.setRotate(180);
And here is my css code for sliders:
.slider > .thumb,
.slider > .thumb:hover,
.slider:focused > .thumb{
-fx-background-color: #ff6a6a;
-fx-background-insets: 2 0 -23 0;
-fx-padding: 1 1 0 1;
-fx-background-radius: 0;
}
.slider:vertical > .thumb,
.slider:vertical > .thumb:hover,
.slider:vertical:focused > .thumb{
-fx-background-color: #ff6a6a;
-fx-background-insets: 0 -23 0 2;
-fx-padding: 1 0 1 1;
-fx-background-radius: 0;
}
.slider > .track,
.slider:vertical > .track {
-fx-background-color: transparent;
-fx-background-insets: 0;
-fx-background-radius: 0;
-fx-padding: 0;
}
.slider > .axis {
-fx-tick-mark-stroke: transparent;
-fx-tick-label-font-size: 0.833333em;
-fx-tick-label-fill: #9a9a9a;
-fx-background-color: #333;
}
Please suggest me how can I flip axis or rotate labels of these slider so that I can achieve expected results.
Basically, you have to set the side property of the axis (for left and top). The steps that are involved:
let the slider have a custom style, f.i. axis-top/axis-left
in css, define a rule for the axis contained in such a slider to set its side to top/left
The code:
Slider hRuler = new Slider(0, 160, 10);
hRuler.showTickMarksProperty().setValue(true);
hRuler.showTickLabelsProperty().setValue(true);
hRuler.getStyleClass().add("axis-top");
Slider vRuler = new Slider(0, 100, 10);
vRuler.setOrientation(Orientation.VERTICAL);
vRuler.showTickMarksProperty().setValue(true);
vRuler.showTickLabelsProperty().setValue(true);
vRuler.getStyleClass().add("axis-left");
In css:
.slider.axis-top > .axis {
-fx-side: TOP;
}
.slider.axis-left > .axis {
-fx-side: LEFT;
}
This can certainly be optimized, but should get you started.
I want to make a custom checkbox, but my mark is limited by box size. Is there a way to extend it outside bounds?
CSS code for checkbox:
.check-box{
-fx-font-family: "Segoe UI Light";
-fx-font-size: 18;
-fx-text-fill:#01449f;}
.check-box .box{
-fx-outer-border: #cadbec;
-fx-body-color: white;
-fx-background-color:
-fx-outer-border,
-fx-body-color;
-fx-background-insets: 0, 1;
-fx-background-radius: 2px, 0px;}
.check-box .mark {
-fx-shape:"M14.596,2.055L12.455,0C9.687,2.884,6.011,6.714,5.158,7.602L2.055,4.624L0,6.765l5.242,5.037l0.003-0.004
l0.003,0.004L14.596,2.055z";}
.check-box:selected .mark {
-fx-background-color: #0181e2;}
You can scale the graphic:
.check-box .mark {
-fx-shape:"M14.596,2.055L12.455,0C9.687,2.884,6.011,6.714,5.158,7.602L2.055,4.624L0,6.765l5.242,5.037l0.003-0.004
l0.003,0.004L14.596,2.055z";
-fx-scale-x: 2;
-fx-scale-y: 2;
}
EDIT
To move the tick, you can translate it:
.check-box .mark {
-fx-shape:"M14.596,2.055L12.455,0C9.687,2.884,6.011,6.714,5.158,7.602L2.055,4.624L0,6.765l5.242,5.037l0.003-0.004
l0.003,0.004L14.596,2.055z";
-fx-scale-x: 2;
-fx-scale-y: 2;
-fx-translate-x: 5px;
-fx-translate-y: -3px;
}
I have a label in JavaFX application that i need to apply a double underline too. I know this aint possible to do with a basic property, but instead i have applied the following css to the label, which gives it a "effect" of a double underline
.double-underline {
-fx-border-color: #FFFFFF;
-fx-border-width: 0 0 1 0;
-fx-underline: true;
}
Now this does give me the effect i want, but i need to if possible, increase the spacing between the text and the actual underline. How can i do this?
This would be easier if there was a "double" border style that i could apply, but there isnt that i know of
Here is what it looks like now
and i would like it too look more like this
Thanks in advance
You can adjust the position of the border with CSS:
.double-underline {
-fx-border-color: black;
-fx-border-width: 0 0 1 0;
-fx-underline: true;
-fx-padding: 0 0 -1 0;
}
EDIT: As Uluk Biy says, the above snippet will join the border to the actual underline. So this will do what you want:
.double-underline {
-fx-border-color: black, transparent, black;
-fx-border-width: 0 0 1 0, 0 0 1 0, 0 0 1 0;
-fx-border-insets: 0 0 1 0, 0 0 2 0, 0 0 3 0;
}
Instead of using an underlined label, configure a double border, and just play with the insets.