質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
JavaFX

JavaFXとは、Java仮想マシン上で動作するリッチインターネットアプリケーション (RIA) のGUIライブラリです。Swingとは異なり、FXMLと呼ばれる XMLとCSSを併用してデザインを記述します。

CSS

CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。

Q&A

解決済

1回答

2196閲覧

JavaFX CSSでフラットツールバーみたいなマウスポインターが置いていない状態では平面的なデザインを再現するには?

mr0237

総合スコア164

JavaFX

JavaFXとは、Java仮想マシン上で動作するリッチインターネットアプリケーション (RIA) のGUIライブラリです。Swingとは異なり、FXMLと呼ばれる XMLとCSSを併用してデザインを記述します。

CSS

CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。

0グッド

0クリップ

投稿2016/10/22 07:04

編集2016/10/23 03:05

###前提・実現したいこと
JavaFX CSSでフラットツールバーみたいなマウスポインターが置いていない状態では平面的なデザインを再現するには?

###発生している問題・エラーメッセージ

JavaFX CSSでポインターをWindowsのツールバーのようなボタンの上に置くとそのボタンだけが立体表示される
フラットツールバーを作りたいのですが、マウスポインターを置くと立体的な表示するところまではできました。↓

JAVAFX

1.button:hover { 2 -fx-effect: dropshadow( three-pass-box , rgba(0,0,0,0.6) , 5, 0.0 , 0 , 1 ); 3}

しかし、ポインターをボタンの上に置いてない状態、いわゆる平面的なデザインがうまくいきません。

JAVAFX

1-fx-background-color:transparent = rgba(0,0,0,0);

↑の方法でやると、平面的なデザインと言いますか、何もない状態になるのです。
しかし、ボタン上にマウスポインターを置くと立体表示(ボタンが表示)されないのです。

平面的なデザインでマウスポインターを置くと立体的な表示するにはどのように書けばいいのでしょうか?

よろしくお願いします。

###補足情報(言語/FW/ツール等のバージョンなど)

言語:JAVAFX ツール:Scene Builder

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

JavaFXは選択されているテーマ(java8のデフォルトはmodena)に応じてデフォルトのスタイルシートが適用されるのですがスタイルシートはjfxrt.jarのcom.sun.javafx.scene.control.skin.<テーマ名>のパッケージ内に置かれているようです。このスタイルシートは例えばEclipseのパッケージエクスプローラーなどから参照することができます。また、Scene Builder上でViewメニューのShow CSS Analizerを選ぶと、画面下の方に選択中のノードのスタイルが一覧で表示されるのですが、こちらの一覧にはスタイル毎にデフォルトのスタイルシートの値が有効なのか自分で指定したスタイルシートが有効なのか、またその値は何かなどが確認できます。

これらをみるとわかってくるのですが、デフォルトのボタンの各部分の色や形は主としてこのデフォルトのスタイルシートで設定されていることがわかります。

ボタンの-fx-background-colorも背景やボーダーなどの色がデフォルトスタイルシートで設定されています。しかしこれを自分のcssでtransparentに書き換えてしまうと全ての色が透明になってしまうためボタン名以外は見えなくなります。

そんなわけでシーンビルダーでボタンに設定されているデフォルトのスタイルがどうなっているかを確認しつつ、望みのスタイルになるように調整していくといった方法で進めるとやりやすいように感じました。

投稿2016/10/23 18:40

KSwordOfHaste

総合スコア18394

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問