swing 類似於文檔流的界面佈局器:改進版的FlowLayout

 

參考:JAVA Swing--JTree實時刷新控制(刷新數據)  http://fangguanhong.iteye.com/blog/1914115

JFrame界面問題添加超鏈接   http://www.vcsos.com/article/pageSource/120307/20120307110753.shtml

使用JFrame編寫類似QQ好友列表懸浮界面例子,JFrame初學   http://fangguanhong.iteye.com/blog/1838715



JTextArea自動換行以及設置滾動條   http://fangguanhong.iteye.com/blog/1920937


java swing 實現窗體靠邊自動伸縮隱藏   http://fangguanhong.iteye.com/blog/1913138


我在做一個swing程序的時候想做一個類似於文檔流的界面佈局:

 

在一個JPanel裏面動態放置一些面板(如jPanel),這些面板的尺寸大小都是相同的,考慮到不同尺寸屏幕的使用方便性來說,最好是當第一行滿時,會自動換行到第二行。如果超過了當前JPanle的高度,則會出現上下滾動條。

 

一開始我用JPanel+FlowLayout.LEFT佈局,倒是可以自動換行,但是發現當面板佔據空間的高度高於JPanel的高度時,沒有上下方向的滾動條出現,也就是說,下面的內容都被遮住了。

 

然後我在JPanel外面套了一個JScrollPane,卻發現內容會一直往右邊加,超出JPanel的寬度則出現橫向的滾動條,與預想的效果相差較大。

 

於是我把JScrollPane的horizontalScrollBarPolicy屬性設爲ScrollPaneConstants.HORIZONTAL_SCROLLBAR_NEVER,這回橫向滾動條沒了,但是圖片還是一直往右邊加,超出JPanle寬度部分被遮住了。

 

經過上網檢索資料,有一個方法可以實現,即繼承FLowLayout類,並重寫minimumLayoutSize方法和preferredLayoutSize方法,不過帖子上的代碼有點小問題,後來我仔細研究代碼和源碼,進行了修正,最後實現了想要的效果,下面把正確的代碼貼出來,供有此類需求的人使用

 

Java代碼  收藏代碼
  1. package com.xxxx.swing.layout;  
  2.   
  3. import java.awt.Component;  
  4. import java.awt.Container;  
  5. import java.awt.Dimension;  
  6. import java.awt.FlowLayout;  
  7. import java.awt.Insets;  
  8.   
  9. public class ModifiedFlowLayout extends FlowLayout {  
  10.   
  11.     public ModifiedFlowLayout() {    
  12.         super();    
  13.     }    
  14.     
  15.     public ModifiedFlowLayout(int align) {    
  16.         super(align);    
  17.     }    
  18.     
  19.     public ModifiedFlowLayout(int align, int hgap, int vgap) {    
  20.         super(align, hgap, vgap);    
  21.     }    
  22.     
  23.     public Dimension minimumLayoutSize(Container target) {    
  24.         return computeSize(target, true);    
  25.     }    
  26.     
  27.     public Dimension preferredLayoutSize(Container target) {    
  28.         return computeSize(target, false);    
  29.     }    
  30.     
  31.     private Dimension computeSize(Container target, boolean minimum) {    
  32.         synchronized (target.getTreeLock()) {    
  33.             int hgap = getHgap();    
  34.             int vgap = getVgap();    
  35.             int w = target.getWidth();    
  36.     
  37.             if (w == 0) {    
  38.                 w = Integer.MAX_VALUE;    
  39.             }    
  40.     
  41.             Insets insets = target.getInsets();    
  42.             if (insets == null) {    
  43.                 insets = new Insets(0000);    
  44.             }    
  45.             int reqdWidth = 0;    
  46.     
  47.             int maxwidth = w - (insets.left + insets.right + hgap * 2);    
  48.             int n = target.getComponentCount();    
  49.             int x = 0;    
  50.             int y = insets.top;    
  51.             int rowHeight = 0;    
  52.     
  53.             for (int i = 0; i < n; i++) {    
  54.                 Component c = target.getComponent(i);    
  55.                 if (c.isVisible()) {    
  56.                     Dimension d =    
  57.                             minimum ? c.getMinimumSize() : c.getPreferredSize();    
  58.                     if ((x == 0) || ((x + d.width) <= maxwidth)) {    
  59.                         if (x > 0) {    
  60.                             x += hgap;    
  61.                         }    
  62.                         x += d.width;    
  63.                         rowHeight = Math.max(rowHeight, d.height);    
  64.                     } else {    
  65.                         x = d.width;    
  66.                         y += vgap + rowHeight;    
  67.                         rowHeight = d.height;    
  68.                     }    
  69.                     reqdWidth = Math.max(reqdWidth, x);    
  70.                 }    
  71.             }    
  72.             y += rowHeight;  
  73.             return new Dimension(reqdWidth + insets.left + insets.right, y);    
  74.         }    
  75.     }    
  76. }  

 

最終的效果(不想截圖了,從網上找了個類似的效果圖片貼上來吧):

 



 

 

  • 大小: 97.6 KB
發佈了24 篇原創文章 · 獲贊 7 · 訪問量 6萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章