一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術(shù)|正則表達(dá)式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務(wù)器之家 - 編程語言 - Java教程 - JavaFX實(shí)現(xiàn)UI美觀效果代碼實(shí)例

JavaFX實(shí)現(xiàn)UI美觀效果代碼實(shí)例

2020-07-31 15:03HiIT青年 Java教程

這篇文章主要介紹了JavaFX實(shí)現(xiàn)UI美觀效果代碼實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下

相對(duì)于Swing來說,JavaFX在UI上改善了很多,不僅可以通過FXML來排版布局界面,同時(shí)也可以通過CSS樣式表來美化UI。
其實(shí)在開發(fā)JavaFX應(yīng)用的時(shí)候,可以將FXML看做是HTML,這樣跟CSS結(jié)合起來就跟開發(fā)WEB應(yīng)用差不多,只不過兩者之間的語法有點(diǎn)差異。

1. JavaFX CSS語法

JavaFX CSS樣式跟HTML中的CSS樣式很大程度上是相似的,比如class選擇器、組合選擇符、偽元素等。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
.root {
 -fx-body-color : #F5F5F5;
 -fx-outer-border : #cecece;
}
 
VBox > .text-area.first {
 -fx-border-radius: 4 4 0 0;
 -fx-background-radius: 4 4 0 0;
}
 
.arrow-button:pressed {
 -fx-background-color: #e6e6e6;
 -fx-border-color: #acacac;
 -fx-effect: innershadow(gaussian, #adadad, 10, 0, 0, 3);
}

但有一點(diǎn)不同的是,JavaFX的CSS樣式語法都是以“-fx-”作為前綴。

比如:

?
1
2
3
4
5
6
7
8
/* 在CSS中,樣式是這樣寫的 */
min-height: 46;
max-height: 46;
font-size: 18;
/* 而在JavaFX中CSS必須這樣寫 */
-fx-min-height: 46;
-fx-max-height: 46;
-fx-font-size: 18;

其實(shí),如果了解CSS,想要編寫JavaFX的CSS難度并不是很大。

2. 用CSS美化控件

在沒有經(jīng)過CSS美化之前的JavaFX控件,其實(shí)跟Swing的控件差別不大,所以想要讓控件更加美觀還是要用CSS來修飾一下。
下面通過簡(jiǎn)單的樣式,來美化一下之前的按鈕:

<Button text="Go."
style="-fx-min-height: 30; -fx-min-width: 80;-fx-background-color: #337ab7;">
</Button>

效果圖:

JavaFX實(shí)現(xiàn)UI美觀效果代碼實(shí)例

可以看到使用CSS美化過的按鈕要比之前的按鈕好看多了。

3. 使用CSS樣式表美化控件

雖然在控件上加上CSS樣式可以達(dá)到美化控件的效果,但是跟寫CSS一樣,這樣的寫CSS樣式很不利于維護(hù)。
更好的方式的使用CSS文件統(tǒng)一維護(hù)樣式,然后通過class選擇器將樣式綁定在控件上。

首先編程css樣式

在AppUI.fxml相同的目錄下創(chuàng)建AppUI.css,內(nèi)容如下:

?
1
2
3
4
5
6
.go {
 -fx-text-fill: white;
 -fx-min-height: 30;
 -fx-min-width: 80;
 -fx-background-color: #337ab7;
}

修改FXML引入樣式

這里單獨(dú)為AppUI.fxml引入樣式,所以這需要在BorderPane的stylesheets屬性指定AppUI.css即可。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
<BorderPane prefHeight="400.0" prefWidth="600.0"
      stylesheets="@AppUI.css" xmlns="http://javafx.com/javafx/8.0.172-ea"
      xmlns:fx="http://javafx.com/fxml/1" fx:controller="com.itqn.gui.javafx.wx.ui.AppUI">
 <center>
  <VBox alignment="CENTER" spacing="10.0">
   <Label fx:id="text"/>
   <Button onAction="#click" text="Go." styleClass="go">
    <!--
    <styleClass>
     <String fx:value="btn"/>
     <String fx:value="btn-info"/>
    </styleClass>
     -->
   </Button>
  </VBox>
 </center>
</BorderPane>

注意這里使用的是styleClass,而不是style,另外如果需要指定多個(gè)class樣式的話,應(yīng)該采用styleClass子元素,而不是styleClass屬性。

修改maven pom.xml

跟之前一樣,要讓css編譯到classpath下面,需要在maven pom.xml配置include。

?
1
2
3
4
5
6
7
8
9
10
11
<build>
 <resources>
  <resource>
   <directory>src/main/java</directory>
   <includes>
    <include>**/*.fxml</include>
    <include>**/*.css</include>
   </includes>
  </resource>
 </resources>
</build>

在實(shí)際開發(fā)中,可以使用現(xiàn)有的開源框架來美化JavaFX應(yīng)用,沒有自己從零開始編寫自己的樣式。
這里推薦兩個(gè)JavaFX CSS開源框架:

  • bootstrapfx (MIT協(xié)議)
  • jbootx (沒有聲明開源協(xié)議)

bootstrapfx 目前最新的版本是0.2.4,使用它非常方便,只需要在maven引入依賴,然后在場(chǎng)景中添加對(duì)應(yīng)的樣式表即可。

首先引入maven依賴

修改maven pom.xml 加入如下依賴

?
1
2
3
4
5
<dependency>
 <groupId>org.kordamp.bootstrapfx</groupId>
 <artifactId>bootstrapfx-core</artifactId>
 <version>0.2.4</version>
</dependency>

然后在場(chǎng)景(scene)中引入樣式表

這里跟上面使用樣式表的方式有點(diǎn)不同,在scene引入樣式表后,所有scene里面的容器和控件都能使用。
而單獨(dú)為fxml引入樣式表,僅能在當(dāng)前fxml中使用。

stage.setScene(scene);
stage.getScene().getStylesheets().add("org/kordamp/bootstrapfx/bootstrapfx.css");
stage.show();

在fxml中使用bootstrapfx樣式

?
1
2
3
4
5
6
<Button text="Go.">
 <styleClass>
  <String fx:value="btn"/>
  <String fx:value="btn-success"/>
 </styleClass>
</Button>

效果圖:

JavaFX實(shí)現(xiàn)UI美觀效果代碼實(shí)例

另外:jbootx的使用方式也是一樣的,當(dāng)然也可以不引入依賴,直接將樣式表放在resources目錄,然后直接添加到場(chǎng)景中。

jbootx的使用示例這里就不展開了,下面展示一下jbootx的效果圖。

效果圖1:

JavaFX實(shí)現(xiàn)UI美觀效果代碼實(shí)例

效果圖2:

JavaFX實(shí)現(xiàn)UI美觀效果代碼實(shí)例

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持服務(wù)器之家。

原文鏈接:https://www.cnblogs.com/itqn/p/13381560.html

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 国产欧美久久一区二区 | 精品国产乱码久久久久久免费 | 国产精品亚洲精品观看不卡 | 日本伊人色综合网 | 亚裔aⅴ艳星katsuni | 吉泽明步高清无码中文 | 国产免费久久精品44 | 色婷婷天天综合在线 | 日韩欧美一区二区三区 | 被夫上司强迫中文 | 国内精品视频九九九九 | 男女操bb | 26uuu成人人网图片 | 五月桃花网婷婷亚洲综合 | 精品午夜久久网成年网 | 石原莉奈adn093店长未婚妻 | 暖暖在线日本 | 亚洲区精品久久一区二区三区 | 性欧美sexvideo另类 | 亚洲男男video| 岛国虐乳紧缚媚药调教 | 999热这里只有精品 999久久久免费精品国产牛牛 | 日本高清二三四本2021 | 国产成人免费高清激情视频 | 久久xxxx| 日本视频在线免费观看 | 热久久亚洲 | 亚洲va欧美va国产va天堂影 | 亚洲第一永久色 | 久久精品国产亚洲AV蜜臀 | 日韩毛片高清在线看 | 调教女帝 | 国产欧美成人免费观看 | 亚洲入口| 国产欧美又粗又猛又爽老 | 日本一区二区三区在线 观看网站 | 女学生被老师调教在教室 | 国产欧美日韩图片一区二区 | 日本色吧| 侵犯小男生免费视频网站 | 无人区在线观看免费视频国语 |