< prev index next >

src/java.desktop/share/classes/javax/swing/plaf/synth/package-info.java

Print this page

        

*** 1,178 **** ! <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 3.2 Final//EN"> ! <html> ! <head> ! <!-- ! Copyright (c) 2003, 2013, Oracle and/or its affiliates. All rights reserved. ! DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. ! ! This code is free software; you can redistribute it and/or modify it ! under the terms of the GNU General Public License version 2 only, as ! published by the Free Software Foundation. Oracle designates this ! particular file as subject to the "Classpath" exception as provided ! by Oracle in the LICENSE file that accompanied this code. ! ! This code is distributed in the hope that it will be useful, but WITHOUT ! ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or ! FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License ! version 2 for more details (a copy is included in the LICENSE file that ! accompanied this code). ! ! You should have received a copy of the GNU General Public License version ! 2 along with this work; if not, write to the Free Software Foundation, ! Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. ! ! Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA ! or visit www.oracle.com if you need additional information or have any ! questions. ! ! ! --> ! <title></title> ! </head> ! <body bgcolor="white"> ! <p> ! Synth is a skinnable look and feel in which all painting is ! delegated. Synth does not provide a default look. In ! order to use Synth you need to specify a ! <a href="doc-files/synthFileFormat.html">file</a>, or ! provide a {@link ! javax.swing.plaf.synth.SynthStyleFactory}. Both ! configuration options require an ! understanding of the synth architecture, which is described ! below, as well as an understanding of Swing's architecture. ! </p> ! <p> ! Unless otherwise specified null is not a legal value to any of ! the methods defined in the synth package and if passed in will ! result in a <code>NullPointerException</code>. ! ! ! <h2>Synth</h2> ! <p> ! Each {@link javax.swing.plaf.ComponentUI} implementation in Synth associates ! itself with one {@link ! javax.swing.plaf.synth.SynthStyle} per {@link ! javax.swing.plaf.synth.Region}, most ! <code>Components</code> only have one <code>Region</code> and ! therefor only one <code>SynthStyle</code>. ! <code>SynthStyle</code> ! is used to access all style related properties: fonts, colors ! and other <code>Component</code> properties. In addition ! <code>SynthStyle</code>s are used to obtain ! {@link javax.swing.plaf.synth.SynthPainter}s for painting the background, border, ! focus and other portions of a <code>Component</code>. The <code>ComponentUI</code>s obtain ! <code>SynthStyle</code>s from a ! {@link javax.swing.plaf.synth.SynthStyleFactory}. ! A <code>SynthStyleFactory</code> ! can be provided directly by way of ! {@link javax.swing.plaf.synth.SynthLookAndFeel#setStyleFactory(javax.swing.plaf.synth.SynthStyleFactory)}, ! or indirectly by way of ! {@link javax.swing.plaf.synth.SynthLookAndFeel#load}. The ! following example uses the <code>SynthLookAndFeel.load()</code> ! method to configure a <code>SynthLookAndFeel</code> and sets it ! as the current look and feel: ! </p> ! <div class="example"> ! <pre> ! SynthLookAndFeel laf = new SynthLookAndFeel(); ! laf.load(MyClass.class.getResourceAsStream("laf.xml"), MyClass.class); ! UIManager.setLookAndFeel(laf); ! </pre> ! </div> ! <p> ! Many <code>JComponent</code>s are broken down into smaller ! pieces and identified by the type safe enumeration in ! {@link javax.swing.plaf.synth.Region}. For example, a <code>JTabbedPane</code> ! consists of a <code>Region</code> for the ! <code>JTabbedPane</code> ({@link ! javax.swing.plaf.synth.Region#TABBED_PANE}), the content ! area ({@link ! javax.swing.plaf.synth.Region#TABBED_PANE_CONTENT}), the ! area behind the tabs ({@link ! javax.swing.plaf.synth.Region#TABBED_PANE_TAB_AREA}), and the ! tabs ({@link ! javax.swing.plaf.synth.Region#TABBED_PANE_TAB}). Each ! <code>Region</code> of each ! <code>JComponent</code> will have a ! <code>SynthStyle</code>. This allows ! you to customize individual pieces of each region of each ! <code>JComponent</code>. ! <p> ! Many of the Synth methods take a {@link javax.swing.plaf.synth.SynthContext}. This ! is used to provide information about the current ! <code>Component</code> and includes: the ! {@link javax.swing.plaf.synth.SynthStyle} associated with the current ! {@link javax.swing.plaf.synth.Region}, the state of the <code>Component</code> ! as a bitmask (refer to {@link ! javax.swing.plaf.synth.SynthConstants} for the valid ! states), and a {@link javax.swing.plaf.synth.Region} identifying the portion of ! the <code>Component</code> being painted. ! <p> ! All text rendering by non-<code>JTextComponent</code>s is ! delegated to a {@link ! javax.swing.plaf.synth.SynthGraphicsUtils}, which is ! obtained using the {@link javax.swing.plaf.synth.SynthStyle} method ! {@link javax.swing.plaf.synth.SynthStyle#getGraphicsUtils}. You can ! customize text rendering ! by supplying your own {@link javax.swing.plaf.synth.SynthGraphicsUtils}. ! ! </p> ! ! <h2>Notes on specific components</h2> ! ! <h3>JTree</h3> ! <p> ! Synth provides a region for the cells of a tree: ! <code>Region.TREE_CELL</code>. To specify the colors of the ! renderer you'll want to provide a style for the ! <code>TREE_CELL</code> region. The following illustrates this: ! <pre> ! &lt;style id="treeCellStyle"> ! &lt;opaque value="TRUE"/> ! &lt;state> ! &lt;color value="WHITE" type="TEXT_FOREGROUND"/> ! &lt;color value="RED" type="TEXT_BACKGROUND"/> ! &lt;/state> ! &lt;state value="SELECTED"> ! &lt;color value="RED" type="TEXT_FOREGROUND"/> ! &lt;color value="WHITE" type="BACKGROUND"/> ! &lt;/state> ! &lt;/style> ! &lt;bind style="treeCellStyle" type="region" key="TreeCell"/> ! </pre> ! <p> ! This specifies a color combination of red on white, when ! selected, and white on red when not selected. To see the ! background you need to specify that labels are not opaque. The ! following XML fragment does that: ! <pre> ! &lt;style id="labelStyle"> ! &lt;opaque value="FALSE"/> ! &lt;/style> ! &lt;bind style="labelStyle" type="region" key="Label"/> ! </pre> ! ! <h3>JList and JTable</h3> ! <p> ! The colors that the renderers for JList and JTable use are ! specified by way of the list and table Regions. The following ! XML fragment illustrates how to specify red on white, when ! selected, and white on red when not selected: ! <pre> ! &lt;style id="style"> ! &lt;opaque value="TRUE"/> ! &lt;state> ! &lt;color value="WHITE" type="TEXT_FOREGROUND"/> ! &lt;color value="RED" type="TEXT_BACKGROUND"/> ! &lt;color value="RED" type="BACKGROUND"/> ! &lt;/state> ! &lt;state value="SELECTED"> ! &lt;color value="RED" type="TEXT_FOREGROUND"/> ! &lt;color value="WHITE" type="TEXT_BACKGROUND"/> ! &lt;/state> ! &lt;/style> ! &lt;bind style="style" type="region" key="Table"/> ! &lt;bind style="style" type="region" key="List"/> ! </pre> ! </body> ! </html> --- 1,143 ---- ! /* ! * Copyright (c) 2003, 2017, Oracle and/or its affiliates. All rights reserved. ! * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. ! * ! * This code is free software; you can redistribute it and/or modify it ! * under the terms of the GNU General Public License version 2 only, as ! * published by the Free Software Foundation. Oracle designates this ! * particular file as subject to the "Classpath" exception as provided ! * by Oracle in the LICENSE file that accompanied this code. ! * ! * This code is distributed in the hope that it will be useful, but WITHOUT ! * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or ! * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License ! * version 2 for more details (a copy is included in the LICENSE file that ! * accompanied this code). ! * ! * You should have received a copy of the GNU General Public License version ! * 2 along with this work; if not, write to the Free Software Foundation, ! * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. ! * ! * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA ! * or visit www.oracle.com if you need additional information or have any ! * questions. ! */ ! ! /** ! * Synth is a skinnable look and feel in which all painting is delegated. Synth ! * does not provide a default look. In order to use Synth you need to specify a ! * <a href="doc-files/synthFileFormat.html">file</a>, or provide a ! * {@link javax.swing.plaf.synth.SynthStyleFactory}. Both configuration options ! * require an understanding of the synth architecture, which is described below, ! * as well as an understanding of Swing's architecture. ! * <p> ! * Unless otherwise specified null is not a legal value to any of the methods ! * defined in the synth package and if passed in will result in a ! * {@code NullPointerException}. ! * ! * <h2>Synth</h2> ! * Each {@link javax.swing.plaf.ComponentUI} implementation in Synth associates ! * itself with one {@link javax.swing.plaf.synth.SynthStyle} per ! * {@link javax.swing.plaf.synth.Region}, most {@code Components} only have one ! * {@code Region} and therefor only one {@code SynthStyle}. {@code SynthStyle} ! * is used to access all style related properties: fonts, colors ! * and other {@code Component} properties. In addition {@code SynthStyle}s are ! * used to obtain {@link javax.swing.plaf.synth.SynthPainter}s for painting the ! * background, border, focus and other portions of a {@code Component}. The ! * {@code ComponentUI}s obtain {@code SynthStyle}s from a ! * {@link javax.swing.plaf.synth.SynthStyleFactory}. A {@code SynthStyleFactory} ! * can be provided directly by way of ! * {@link javax.swing.plaf.synth.SynthLookAndFeel#setStyleFactory(javax.swing.plaf.synth.SynthStyleFactory)}, ! * or indirectly by way of {@link javax.swing.plaf.synth.SynthLookAndFeel#load}. ! * The following example uses the {@code SynthLookAndFeel.load()} method to ! * configure a {@code SynthLookAndFeel} and sets it as the current look and ! * feel: ! * <div class="example"> ! * <pre>{@code ! * SynthLookAndFeel laf = new SynthLookAndFeel(); ! * laf.load(MyClass.class.getResourceAsStream("laf.xml"), MyClass.class); ! * UIManager.setLookAndFeel(laf); ! * }</pre> ! * </div> ! * <p> ! * Many {@code JComponent}s are broken down into smaller pieces and identified ! * by the type safe enumeration in {@link javax.swing.plaf.synth.Region}. For ! * example, a {@code JTabbedPane} consists of a {@code Region} for the ! * {@code JTabbedPane}({@link javax.swing.plaf.synth.Region#TABBED_PANE}), the ! * content area ({@link javax.swing.plaf.synth.Region#TABBED_PANE_CONTENT}), the ! * area behind the tabs ! * ({@link javax.swing.plaf.synth.Region#TABBED_PANE_TAB_AREA}), and the tabs ! * ({@link javax.swing.plaf.synth.Region#TABBED_PANE_TAB}). Each ! * {@code Region} of each {@code JComponent} will have a {@code SynthStyle}. ! * This allows you to customize individual pieces of each region of each ! * {@code JComponent}. ! * <p> ! * Many of the Synth methods take a {@link javax.swing.plaf.synth.SynthContext}. ! * This is used to provide information about the current {@code Component} and ! * includes: the {@link javax.swing.plaf.synth.SynthStyle} associated with the ! * current {@link javax.swing.plaf.synth.Region}, the state of the ! * {@code Component} as a bitmask (refer to ! * {@link javax.swing.plaf.synth.SynthConstants} for the valid states), and a ! * {@link javax.swing.plaf.synth.Region} identifying the portion of the ! * {@code Component} being painted. ! * <p> ! * All text rendering by non-{@code JTextComponent}s is delegated to a ! * {@link javax.swing.plaf.synth.SynthGraphicsUtils}, which is obtained using ! * the {@link javax.swing.plaf.synth.SynthStyle} method ! * {@link javax.swing.plaf.synth.SynthStyle#getGraphicsUtils}. You can customize ! * text rendering by supplying your own ! * {@link javax.swing.plaf.synth.SynthGraphicsUtils}. ! * ! * <h2>Notes on specific components</h2> ! * <h3>JTree</h3> ! * Synth provides a region for the cells of a tree: ! * {@code Region.TREE_CELL}. To specify the colors of the ! * renderer you'll want to provide a style for the ! * {@code TREE_CELL} region. The following illustrates this: ! * <pre>{@code ! * <style id="treeCellStyle"> ! * <opaque value="TRUE"/> ! * <state> ! * <color value="WHITE" type="TEXT_FOREGROUND"/> ! * <color value="RED" type="TEXT_BACKGROUND"/> ! * </state> ! * <state value="SELECTED"> ! * <color value="RED" type="TEXT_FOREGROUND"/> ! * <color value="WHITE" type="BACKGROUND"/> ! * </state> ! * </style> ! * <bind style="treeCellStyle" type="region" key="TreeCell"/> ! * }</pre> ! * <p> ! * This specifies a color combination of red on white, when selected, and white ! * on red when not selected. To see the background you need to specify that ! * labels are not opaque. The following XML fragment does that: ! * <pre>{@code ! * <style id="labelStyle"> ! * <opaque value="FALSE"/> ! * </style> ! * <bind style="labelStyle" type="region" key="Label"/> ! * }</pre> ! * ! * <h3>JList and JTable</h3> ! * The colors that the renderers for JList and JTable use are specified by way ! * of the list and table Regions. The following XML fragment illustrates how to ! * specify red on white, when selected, and white on red when not selected: ! * <pre>{@code ! * <style id="style"> ! * <opaque value="TRUE"/> ! * <state> ! * <color value="WHITE" type="TEXT_FOREGROUND"/> ! * <color value="RED" type="TEXT_BACKGROUND"/> ! * <color value="RED" type="BACKGROUND"/> ! * </state> ! * <state value="SELECTED"> ! * <color value="RED" type="TEXT_FOREGROUND"/> ! * <color value="WHITE" type="TEXT_BACKGROUND"/> ! * </state> ! * </style> ! * <bind style="style" type="region" key="Table"/> ! * <bind style="style" type="region" key="List"/> ! * }</pre> ! */ ! package javax.swing.plaf.synth;
< prev index next >