{"id":274,"date":"2013-03-25T23:44:17","date_gmt":"2013-03-25T22:44:17","guid":{"rendered":"http:\/\/www.jensd.de\/wordpress\/?p=274"},"modified":"2013-04-05T15:42:32","modified_gmt":"2013-04-05T13:42:32","slug":"custom-component-selectablepane","status":"publish","type":"post","link":"https:\/\/www.jensd.de\/wordpress\/?p=274","title":{"rendered":"Custom Component: SelectableTitledPane"},"content":{"rendered":"<p>I&#8217;m working on a form to provide search criteria to find pictures in <strong><em>picmodo<\/em><\/strong>.<br \/>\nMy goal is to provide a very easy to use interface.  <\/p>\n<p>Each search criteria is represented by a <strong><code>SelectableTitledPane<\/code><\/strong> which contains the parameter settings.<br \/>\nBasically I have set a <code>CheckBox<\/code> as graphic component of a <code>TitlePane<\/code> and modified the CSS of the Default-Skin <code>com.sun.javafx.scene.control.skin.TitledPaneSkin<\/code>.<\/p>\n<p><a href=\"http:\/\/www.jensd.de\/wordpress\/wp-content\/uploads\/2013\/03\/picmodo_suche.png\"><img loading=\"lazy\" decoding=\"async\" data-attachment-id=\"290\" data-permalink=\"https:\/\/www.jensd.de\/wordpress\/?attachment_id=290\" data-orig-file=\"https:\/\/www.jensd.de\/wordpress\/wp-content\/uploads\/2013\/03\/picmodo_suche.png\" data-orig-size=\"279,490\" data-comments-opened=\"1\" data-image-meta=\"{&quot;aperture&quot;:&quot;0&quot;,&quot;credit&quot;:&quot;&quot;,&quot;camera&quot;:&quot;&quot;,&quot;caption&quot;:&quot;&quot;,&quot;created_timestamp&quot;:&quot;0&quot;,&quot;copyright&quot;:&quot;&quot;,&quot;focal_length&quot;:&quot;0&quot;,&quot;iso&quot;:&quot;0&quot;,&quot;shutter_speed&quot;:&quot;0&quot;,&quot;title&quot;:&quot;&quot;}\" data-image-title=\"picmodo search panel\" data-image-description=\"\" data-image-caption=\"\" data-medium-file=\"https:\/\/www.jensd.de\/wordpress\/wp-content\/uploads\/2013\/03\/picmodo_suche-170x300.png\" data-large-file=\"https:\/\/www.jensd.de\/wordpress\/wp-content\/uploads\/2013\/03\/picmodo_suche.png\" tabindex=\"0\" role=\"button\" src=\"http:\/\/www.jensd.de\/wordpress\/wp-content\/uploads\/2013\/03\/picmodo_suche.png\" alt=\"picmodo search panel\" width=\"279\" height=\"490\" class=\"aligncenter size-full wp-image-290\" srcset=\"https:\/\/www.jensd.de\/wordpress\/wp-content\/uploads\/2013\/03\/picmodo_suche.png 279w, https:\/\/www.jensd.de\/wordpress\/wp-content\/uploads\/2013\/03\/picmodo_suche-170x300.png 170w\" sizes=\"(max-width: 279px) 100vw, 279px\" \/><\/a><\/p>\n<p>The <code>Checkbox<\/code>&#8216;s <code>selectedProperty<\/code> is bound to the <code>expandedProperty<\/code> of <code>TitledPane<\/code> to toggle the expand state and to get an indicator to enable \/ disable the criteria:<\/p>\n<p>[java]<br \/>\npublic class SelectableTitledPane extends TitledPane {<\/p>\n<p>  private CheckBox checkBox;<\/p>\n<p>  public SelectableTitledPane(String title, Node content) {<br \/>\n    super(title, content);<br \/>\n    checkBox = new CheckBox(title);<br \/>\n    checkBox.selectedProperty().<br \/>\n            bindBidirectional(this.expandedProperty());<br \/>\n    setExpanded(false);<br \/>\n    setContentDisplay(ContentDisplay.GRAPHIC_ONLY);<br \/>\n    setGraphic(checkBox);<br \/>\n    setSkin(new TitledPaneSkin(this));<br \/>\n    lookup(&#8220;.arrow&#8221;).<br \/>\n            setVisible(false);<br \/>\n    lookup(&#8220;.title&#8221;).<br \/>\n            setStyle(&#8220;-fx-padding: 0 0 4 -10;&#8221;<br \/>\n            + &#8220;-fx-background-color: null;&#8221;);<br \/>\n    lookup(&#8220;.content&#8221;).<br \/>\n            setStyle(&#8220;-fx-background-color: null; -fx-padding:  0.2em 0.2em 0.2em 1.316667em;&#8221;);<br \/>\n  }<\/p>\n<p>  public BooleanProperty getSelectedProperty() {<br \/>\n    return checkBox.selectedProperty();<br \/>\n  }<\/p>\n<p>  public boolean isSelected() {<br \/>\n    return checkBox.isSelected();<br \/>\n  }<\/p>\n<p>  public void setSelected(boolean selected) {<br \/>\n    checkBox.setSelected(selected);<br \/>\n  }<br \/>\n}<br \/>\n[\/java]<\/p>\n<p>Basically the <strong><code>SelectableTitledPane<\/code><\/strong> can then be used as a TitledPane, e.g.:<\/p>\n<p>[java]<br \/>\nComboBox ownerBox = ComboBoxBuilder.<AppUser>create().<br \/>\n            prefWidth(150).<br \/>\n            promptText(resourceBundle<br \/>\n            .getString(&#8220;search.prompt.owner&#8221;)).<br \/>\n            build();<\/p>\n<p>SelectableTitledPaneownerParams = new SelectableTitledPane(resourceBundle<br \/>\n            .getString(&#8220;search.checkbox.owner&#8221;), ownerBox);<br \/>\n[\/java]<\/p>\n<p><iframe loading=\"lazy\" title=\"picmodo - Bildersuche\" width=\"900\" height=\"675\" src=\"https:\/\/www.youtube.com\/embed\/1uPkzIO0aHw?feature=oembed\" frameborder=\"0\" allow=\"accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture; web-share\" allowfullscreen><\/iframe><\/p>\n","protected":false},"excerpt":{"rendered":"<p>I&#8217;m working on a form to provide search criteria to find pictures in picmodo. My goal is to provide a very easy to use interface. Each search criteria is represented by a SelectableTitledPane which contains the parameter settings. Basically I have set a CheckBox as graphic component of a TitlePane and modified the CSS of&hellip; <span class=\"clear\"><\/span><a href=\"https:\/\/www.jensd.de\/wordpress\/?p=274\" class=\"more-link read-more\" rel=\"bookmark\">Continue Reading <span class=\"screen-reader-text\">Custom Component: SelectableTitledPane<\/span><i class=\"fa fa-arrow-right\"><\/i><\/a><\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"jetpack_post_was_ever_published":false,"_jetpack_newsletter_access":"","_jetpack_dont_email_post_to_subs":false,"_jetpack_newsletter_tier_id":0,"_jetpack_memberships_contains_paywalled_content":false,"footnotes":"","_jetpack_memberships_contains_paid_content":false,"jetpack_publicize_message":"","jetpack_publicize_feature_enabled":true,"jetpack_social_post_already_shared":true,"jetpack_social_options":{"image_generator_settings":{"template":"highway","enabled":false},"version":2}},"categories":[12,20,4,19],"tags":[],"jetpack_publicize_connections":[],"aioseo_notices":[],"jetpack_featured_media_url":"","jetpack_shortlink":"https:\/\/wp.me\/p38FCL-4q","jetpack_sharing_enabled":true,"_links":{"self":[{"href":"https:\/\/www.jensd.de\/wordpress\/index.php?rest_route=\/wp\/v2\/posts\/274"}],"collection":[{"href":"https:\/\/www.jensd.de\/wordpress\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.jensd.de\/wordpress\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.jensd.de\/wordpress\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/www.jensd.de\/wordpress\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=274"}],"version-history":[{"count":17,"href":"https:\/\/www.jensd.de\/wordpress\/index.php?rest_route=\/wp\/v2\/posts\/274\/revisions"}],"predecessor-version":[{"id":293,"href":"https:\/\/www.jensd.de\/wordpress\/index.php?rest_route=\/wp\/v2\/posts\/274\/revisions\/293"}],"wp:attachment":[{"href":"https:\/\/www.jensd.de\/wordpress\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=274"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.jensd.de\/wordpress\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=274"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.jensd.de\/wordpress\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=274"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}