Pembahasan di bagian 4
- Memberi gaya CSS
- Menambah Ikon Aplikasi
Memberi gaya CSS
Di JavaFX anda bisa memberi gaya pada antarmuka pengguna menggunakan Cascading Style Sheet (CSS). Ini adalah hal yang sangat hebat, tidak pernah semudah ini untuk mengubah sesuaikan tampilan JavaFX.
Ditutorial ini kita akan membuat DarkTheme terinspirasi oleh desain Windows 8 Metro. Css untuk tombol berdasarkan JMetro - Windows 8 Metro controls on Java oleh Pedro Duque Vieira.
Membuat Terbiasa dengan CSS
Jika anda ingin memberi gaya pada aplikasi JavaFX anda seharusnya memiliki pengetahuan dasar mengenai CSS secara umum. Tempat yang bagus untuk memulainya adalah CSS tutorial.
Untuk lebih banyak informasi terkait CSS di JavaFX :
- Skinning JavaFX Applications with CSS - Tutorial oleh Oracle
- JavaFX CSS Reference - Referensi Resmi
JavaFX CSS Baku
Sumber CSS baku dalam JavaFX 8 di panggil modena.css
. Berkas css ini dapat di temukan pada berkas jfxrt.jar
bertempat di folder java yang berlokasi di /jdk1.8.x/jre/lib/ext/jfxrt.jar
.
Unzip the jfxrt.jar
. Anda akan menemukan modena.css
didalam com/sun/javafx/scene/control/skin/modena/
Gaya baku ini selalu diterapkan ke aplikasi JavaFX. Dengan menambah CSS yang disesuaikan kita dapat mengesampingkan gaya baku dari modena.css
.
Melampirkan CSS
Tambahkan CSS berikut yang bernama DarkTheme.css
kedalam paket view.
DarkTheme.css
.background { -fx-background-color: #1d1d1d; } .label { -fx-font-size: 11pt; -fx-font-family: "Segoe UI Semibold"; -fx-text-fill: white; -fx-opacity: 0.6; } .label-bright { -fx-font-size: 11pt; -fx-font-family: "Segoe UI Semibold"; -fx-text-fill: white; -fx-opacity: 1; } .label-header { -fx-font-size: 32pt; -fx-font-family: "Segoe UI Light"; -fx-text-fill: white; -fx-opacity: 1; } .table-view { -fx-base: #1d1d1d; -fx-control-inner-background: #1d1d1d; -fx-background-color: #1d1d1d; -fx-table-cell-border-color: transparent; -fx-table-header-border-color: transparent; -fx-padding: 5; } .table-view .column-header-background { -fx-background-color: transparent; } .table-view .column-header, .table-view .filler { -fx-size: 35; -fx-border-width: 0 0 1 0; -fx-background-color: transparent; -fx-border-color: transparent transparent derive(-fx-base, 80%) transparent; -fx-border-insets: 0 10 1 0; } .table-view .column-header .label { -fx-font-size: 20pt; -fx-font-family: "Segoe UI Light"; -fx-text-fill: white; -fx-alignment: center-left; -fx-opacity: 1; } .table-view:focused .table-row-cell:filled:focused:selected { -fx-background-color: -fx-focus-color; } .split-pane:horizontal > .split-pane-divider { -fx-border-color: transparent #1d1d1d transparent #1d1d1d; -fx-background-color: transparent, derive(#1d1d1d,20%); } .split-pane { -fx-padding: 1 0 0 0; } .menu-bar { -fx-background-color: derive(#1d1d1d,20%); } .context-menu { -fx-background-color: derive(#1d1d1d,50%); } .menu-bar .label { -fx-font-size: 14pt; -fx-font-family: "Segoe UI Light"; -fx-text-fill: white; -fx-opacity: 0.9; } .menu .left-container { -fx-background-color: black; } .text-field { -fx-font-size: 12pt; -fx-font-family: "Segoe UI Semibold"; } /* * Metro style Push Button * Author: Pedro Duque Vieira * http://pixelduke.wordpress.com/2012/10/23/jmetro-windows-8-controls-on-java/ */ .button { -fx-padding: 5 22 5 22; -fx-border-color: #e2e2e2; -fx-border-width: 2; -fx-background-radius: 0; -fx-background-color: #1d1d1d; -fx-font-family: "Segoe UI", Helvetica, Arial, sans-serif; -fx-font-size: 11pt; -fx-text-fill: #d8d8d8; -fx-background-insets: 0 0 0 0, 0, 1, 2; } .button:hover { -fx-background-color: #3a3a3a; } .button:pressed, .button:default:hover:pressed { -fx-background-color: white; -fx-text-fill: #1d1d1d; } .button:focused { -fx-border-color: white, white; -fx-border-width: 1, 1; -fx-border-style: solid, segments(1, 1); -fx-border-radius: 0, 0; -fx-border-insets: 1 1 1 1, 0; } .button:disabled, .button:default:disabled { -fx-opacity: 0.4; -fx-background-color: #1d1d1d; -fx-text-fill: white; } .button:default { -fx-background-color: -fx-focus-color; -fx-text-fill: #ffffff; } .button:default:hover { -fx-background-color: derive(-fx-focus-color,30%); }
Kita sekarang perlu melampirkan CSS ke Scene. Kita dapat melakukan ini melalui kode, tetapi kita akan menggunakan Scene Builder untuk menambah ke berkas fxml:
Melampirkan CSS ke RootLayout.fxml
-
Buka berkas
RootLayout.fxml
di Scene Builder. -
Pilih akar
BorderPane
di Hierarchy. Dibawah kelompok Properties tambah berkasDarkTheme.css
file as stylesheet.
Lampirkan CSS ke PersonEditDialog.fxml
-
Buka berkas
PersonEditDialog.fxml
di Scene Builder. Pilih akarAnchorPane
dan pilihDarkTheme.css
in the kelompok Properties sebagai stylesheet. -
atar belakang masih berwarna putih, jadi tambah kelas gaya
background
ke akarAnchorPane
.
-
Pilih tombol OK dan pilih Default Button di tampilan Properties. Ini akan merubah warnah dan membuat tombol baku ketika tombol enter ditekan oleh pengguna.
Lampirkan CSS ke PersonOverview.fxml
-
Buka berkas
PersonOverview.fxml
di Scene Builder. Pilih akarAnchorPane
pada kelompok Hierarchy. Pada Properties tambahkanDarkTheme.css
sebagai stylesheet. -
Anda seharusnay melihat beberapa perubahan saat ini. Tabel dan tombol berwarna hitam. Semua kelas gaya
.table-view
dan.button
darimodena.css
diterapkan ke tabel dan tombol. Karena kita telah mendefinisikan ulang (dan dengan demikian diganti) beberapa dari gaya di penyesuaian CSS kita, gaya baru akan diterapkan secara otomatis. -
Anda mungkin perlu menyesuaian ukuran dari tombol sehingga semua teks ditampilkan.
-
Pilih
AnchorPane
yang tepat didalamSplitPane
.
-
Pada keompok Properties pilih
background
sebagai kelas gaya. Latarbelakang akan berwarna hitam.
Label dengan Gaya yang berbeda
Saat ini semua label pada sisi kanan memliki ukuran yang sama. Sudah ada beberapa gaya yang didefinisikan dalam berkas CSS bernama.label-header
dan .label-bright
kita akan gunakan ini sebagai gaya.
-
Pilih label Person Details dan tambahkan
label-header
sebagai kelas gaya.
-
Untuk tiap label di sisi kanan kolom (dimana rinncian person ditampilkan) tambah kelas gaya
label-bright
.
Menambah Ikon Aplikasi
Saat ini aplikasi kita hanya memiliki ikon baku di palang judul dan palang tugas:
Akan lebih terlihat lebih baik jika memiliki ikon khusus:
Berkas Ikon
Tempat yang memungkinkan untuk mendapatkan ikon2 ada di Icon Finder. Saya telah mengunduhe address book icon.
Buat sebuah folder didalam proyek AddressApp bernama resources dan subfolder bernama images.Taruh ikon dalam images folder. Struktur folder anda akan terlihat seperti :
Atur Ikon Ke Scene
Untuk mengatur ikon pada scene, tambahkan baris berikut pada metode start(...)
didalam MainApp.java
MainApp.java
this.primaryStage.getIcons().add(new Image("file:resources/images/address_book_32.png"));
Keseluruhan metode start(...)
terlihat seperti ini :
public void start(Stage primaryStage) { this.primaryStage = primaryStage; this.primaryStage.setTitle("AddressApp"); // Set the application icon. this.primaryStage.getIcons().add(new Image("file:resources/images/address_book_32.png")); initRootLayout(); showPersonOverview(); }
Anda tentunya juga dapat menambah ikon pada stage dari dialog pembaharuan person:
Berikutnya?
Didalam Tutorial Bagian 5 kita akan menggunakan XML sebagai penyimpanan data.