码迷,mamicode.com
首页 > 其他好文 > 详细

自定义JTabbedPane 标签风格

时间:2018-08-17 23:32:01      阅读:198      评论:0      收藏:0      [点我收藏+]

标签:oid   ade   post   介绍   count   blog   static   data   follow   

自定义JTabbedPane 标签风格

下面简要说一下自定义这种Tab的关键点:
1.     每个JComponent几乎都有其UI 委托对象类,当然JTabbedPane也不例外。我们首先继承BasicTabbedPaneUI类,这其中有我们必须要重写的一个方法,具体形式如下:
       public static ComponentUI createUI(JComponent c) {
          return new XXXTabbedPaneUI();
       }
     其中XXXTabbedPaneUI就是自己实现的BasicTabbedPaneUI的子类的名字。
2.下面类出几个改变外观的重要的方法:
a. protectedvoid installDefaults() //可以改变一些BasicTabbedPaneUI中默认的属性。
b.protectedvoid paintTabArea(Graphics g, int tabPlacement, int selectedIndex)  //绘制整个选项卡区域
c. protectedvoid paintTabBackground(Graphics g, int tabPlacement,
           int tabIndex, int x, int y, int w, int h, boolean isSelected)
//绘制某个选项卡的背景色
d. protectedvoid paintContentBorder(Graphics g, int tabPlacement,
           int selectedIndex) //绘制TabbedPane容器的四周边框样式。
e. protectedvoid paintFocusIndicator(Graphics g, int tabPlacement,
           Rectangle[] rects, int tabIndex, Rectangle iconRect,
           Rectangle textRect, boolean isSelected)
//绘制选中某个Tab后,获得焦点的样式。
3.默认状态下每个选择项卡是连续摆放的,那么我们怎么使得他像新浪网页里那样的Tab中间有一定间隙呢,那么我们还定义一个内部类继承BasicTabbedPaneUI的内部类TabbedPaneLayou重写calculateTabRects方法,因为具体的选项卡标签位置是由变量rects所决定的。
根据上面的介绍是不是你也想自己动手实践一下呢??那还等什么,让我们共同努力让Swing更美丽!!
 
也许,看到这里你还是一头雾水,写了这个那到底怎么用它呢,其实很简单,在你要用的地方设置就行了,如下
        UserJTab = new JTabbedPane();
        UserJTab.setTabPlacement(JTabbedPane.TOP);
        UserJTab.setBorder(null);
        UserJTab.setUI(new SinaTabbedPaneUI());
这里就用到了,这样刚才的效果就实现了

自定义JTabbedPane 标签风格

标签:oid   ade   post   介绍   count   blog   static   data   follow   

原文地址:https://www.cnblogs.com/LiuYanYGZ/p/9495523.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!