Tutorial JavaFX (Bahasa Indonesia)

Bagian 4: Memberikan gaya dengan CSS

Tangkapan layar AddressApp bagian 4

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 :

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.

Petunjuk: Akan membantu untuk melihat CSS baku, untuk melihat gaya mana yang perlu untuk dikesampingkan

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

  1. Buka berkas RootLayout.fxml di Scene Builder.

  2. Pilih akar BorderPane di Hierarchy. Dibawah kelompok Properties tambah berkas DarkTheme.css file as stylesheet.
    DarkTheme untuk RootLayout

Lampirkan CSS ke PersonEditDialog.fxml

  1. Buka berkas PersonEditDialog.fxml di Scene Builder. Pilih akar AnchorPane dan pilih DarkTheme.css in the kelompok Properties sebagai stylesheet.

  2. atar belakang masih berwarna putih, jadi tambah kelas gaya background ke akar AnchorPane.
    Menambah kelas gaya

  3. 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

  1. Buka berkas PersonOverview.fxml di Scene Builder. Pilih akar AnchorPane pada kelompok Hierarchy. Pada Properties tambahkan DarkTheme.css sebagai stylesheet.

  2. Anda seharusnay melihat beberapa perubahan saat ini. Tabel dan tombol berwarna hitam. Semua kelas gaya .table-view dan .button dari modena.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.

  3. Anda mungkin perlu menyesuaian ukuran dari tombol sehingga semua teks ditampilkan.

  4. Pilih AnchorPane yang tepat didalam SplitPane.
    Background Style Select

  5. Pada keompok Properties pilih background sebagai kelas gaya. Latarbelakang akan berwarna hitam.
    Background Style

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.

  1. Pilih label Person Details dan tambahkan label-header sebagai kelas gaya.
    Label Header Style

  2. Untuk tiap label di sisi kanan kolom (dimana rinncian person ditampilkan) tambah kelas gaya label-bright.
    Label Bright Style


Menambah Ikon Aplikasi

Saat ini aplikasi kita hanya memiliki ikon baku di palang judul dan palang tugas:

Default Icon

Akan lebih terlihat lebih baik jika memiliki ikon khusus:

Custom Icon

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 :

Custom Icon File

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.

Beberapa artikel menarik lainnya