Java Swing 皮肤定制 之 Synth DTD 用法

 

本文参考自:Java Synth用法

synth DTD下载:synth.dtd

1.   Synth概述

Synth是Sun提供的一种新的Look And Feel,与以往的Look And Feel不同,这是个通过配置文件进行定义的,插入式的Look And Feel。在不修改代码的情况下,用户可以仅通过修改配置文件,即可对控件的字体,颜色等属性进行修改。
2.   Synth配置文件
a)        说明:Synth配置文件是一个XML文件,她是整个Synth配置的关键,而要掌握Synth,最主要的就是要熟悉该文件的DTD,因为他规定了什么可以配置,而什么是不可配置的。
3.   Synth元素
a)        说明:synth元素是整个Synth配置文件的根元素,可以在该元素下通过font,color,imagePainter等标签,直接定义全局可用的风格,然后在某个style或者state内部,通过他们的子font,color标记上的idref属性,即可引用这些全局定义好的属性。。

b)        DTD:
<!ELEMENT synth ((%beansPersistance;) | style | bind | font | color | imagePainter | imageIcon)*>

4.   Style元素

a)        说明:style标签的用途就是把font,color等标签归到一起,作为一个完整的风格,她需要通过后续的bind标签,来绑定到具体的控件上。另外clone属性提供了一种继承机制,通过该属性你可以从某个已定义的style当中把内容继承过来,然后修改某个需要改变的部分即可。

b)        DTD:
<!ELEMENT style (property | defaultsProperty | state | font | painter | imagePainter | backgroundImage | opaque | (%beansPersistance;) | imageIcon)*>

c)        例子:
<style id="button">

  <opaque value="true"/>
  <insets top="4" left="4" right="4" bottom="4"/>
  <font name="Dialog" size="12"/>

</style>


 5.   State元素
a)        说明:State标签用于指定控件在某个特定状态时的风格。state标签中的value值在SynthConstants类中定义。
b)        DTD:
<!ELEMENT state (color | font | painter | imagePainter | (%beansPersistance;))*>
c)        例子:
<state value="SELECTED and PRESSED" id="one">
    <color value="RED" type="BACKGROUND"/>
</state>

6.   Font元素

a)        说明:定义某种字体风格。
b)        例子:<font name="DIALOG" size="12" style="ITALIC"/>

7.   Color元素:

a)        说明:定义某种颜色。
b)        例子:<color value="RED" type="BACKGROUND"/>

8.   Property元素:

a)        说明:通过键值对的方式定义某些控件特定的属性,属性值将存入类SynthStyle类中,这样做的一个好处就是不用为每个特定属性都定义一个标签,而且以后要扩展也比较方便。可以设置的控件属性,参考最后的表格。
b)        DTD:<!ELEMENT property EMPTY>
c)        例子:
<property key="ScrollBar.allowsAbsolutePositioning" type="boolean" value="false"/>

9.   DefaultsProperty元素

a)        说明:将特定于控件的属性值存入类UIDefaults当中,然后由SynthLookAndFeel传入UIManager当中。通过UIManager.get()方法可以获取到该值。
b)        DTD:<!ELEMENT defaultsProperty EMPTY>
c)        例子:

<object class="javax.swing.plaf.ColorUIResource" id="color">
    <int>255</int>
    <int>0</int>
    <int>0</int>
</object>
<defaultsProperty key="Table.focusCellForeground" type="idref" value="color"/>

10.GraphicsUtils元素

a)        说明:用于定义当前Style所使用的SynthGraphicsUtils实例。
b)        DTD:<!ELEMENT graphicsUtils EMPTY>
c)        例子:
<object class="CustomGraphicsUtils" id="graphics"/>
<graphicsUtils idref="graphics"/>

11.Insets元素:

a)        说明:定义某种间距。
b)        例子:<insets top="1" bottom="2" left="3"/>

12.Bind元素

a)        说明:将属性与一类或者某一特定的控件进行绑定。当type的值为region时,她处理的是一系列的控件。当需要处理某个特定的组件时,需要把type设定为name,然后在组件上调用setName()方法设定名字,这样在程序执行时Synth,将会根据组件的getName()的返回值进行匹配。Key部分是使用正则表达式的方式进行匹配。当一个控件有多个style可匹配,那么这些style将被合并,如果style之间有同名部分,则后定义的style将覆盖之前定义的style。
b)        DTD:<!ELEMENT bind EMPTY>
c)        例子:
<style id="b">
  <font name="DIALOG" size="12" style="BOLD"/>
</style>
<bind style="b" type="region" key="button"/>

13.Painter元素

a)        说明:为当前的Style或者State定义一个用于绘画文本的SynthPainter实例。
b)        DTD:<!ELEMENT painter EMPTY>
c)        例子:
<object class="MyPainter" id="MyPainter"/>
<painter idref="MyPainter"/>

14.ImagePainter元素

a)        说明:为当前的Style或者State定义一个用于绘画图形的SynthPainter实例。可以用该属性来绘制控件的背景。
b)        DTD:<!ELEMENT imagePainter EMPTY>
c)        例子:
<imagePainter path="bg.jpg" method="panelBackground" sourceInsets="2 2 2 2"
paintCenter="true"/>

15.ImageIcon元素

a)        说明:为支持Icon属性的控件绑定一个图标。
b)        例子:
<imageIcon id="icon" path="resources/myImage.png"/>
<property key="RadioButton.icon" value="icon"/>

16.Opaque元素

a)        说明:用于设置一个控件的Opaque属性。
b)        例子:<opaque value="FALSE">

17.BeansPersistence属性

a)        说明:该属性可以为其他标签(imagePainter等)引入一些自定义的类。

18.完整的例子:

a)        配置文件:

<synth>
   <style id="emulator">
      <imagePainter path="images/phone.png" method="panelBackground"   sourceInsets="2 2 2 2" paintCenter="true"/>
   </style>
   <bind style="emulator" type="name" key="Emulator.*"/>
</synth>

b)        Java代码:

public class Emulator extends JPanel {
     public static void main(String[] args) throws Exception {
         Runnable runner = new Runnable() {
              public void run() {
                   try {
                       SynthLookAndFeel synth = new SynthLookAndFeel();
                       Class aClass = Emulator.class;
                       InputStream is = aClass.getResourceAsStream("demo.xml");
                       synth.load(is, aClass);
                       UIManager.addAuxiliaryLookAndFeel(synth);
                       JFrame frame = new JFrame("SIP Client");
                       frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
                       frame.setLayout(new BorderLayout());
                       Emulator emulator = new Emulator();
                       emulator.setName("Emulator");
                       frame.add(emulator, BorderLayout.CENTER);
                       frame.setSize(360, 674);
                       frame.setResizable(false);
                       frame.setVisible(true);
                   } catch (Exception e) {
                       e.printStackTrace();
                   }
              }
         };
         EventQueue.invokeLater(runner);
     }
     public Emulator() {}
}

 

c)        说明:文件的路径,及下文当中路径相关的操作,都是相对于load()方法中的class参数的位置。当使用SynthLookAndFeel时,需要为每个控件都指定风格,这显然是很累的,一个解决办法就是,不调用UIManager.setLookAndFeel(laf),而是使用UIManager.addAuxiliaryLookAndFeel(laf),即将Synth作为扩展的LookAndFell,这就能继续使用默认的LookAndFeel和定制的SynthLookAndFeel。

 
 
posted @ 2012-05-09 14:44  雨之殇  阅读(768)  评论(0编辑  收藏  举报