TableCellRenderer用法實踐(一)


轉載:http://blog.csdn.net/chosen0ne/article/details/4453267

 

Swing組件根據其所操作的數據類型分為兩種,一種是標量數據類型的組件,一類是復合數據類型的組件。標量數據類型的組件操作的是基本類型的數據,如字符串、布爾、數字等,此類型組件包括JTextField、JCheckBox、JLabel、JButton等。復合數據類型的組件操作的是諸如向量、矩陣和非線形等類型的數據。向量數據類型的組件有JComboBox、JList,矩陣數據類型的組件有JTable,非線形數據類型的組件如 JTree。 
     為更形象地展現各種類型的數據,復合數據類型的組件往往采用標量數據類型組件來表現每種數據元素。比如JTable的某一列數據是字符串類型,那么該列的單元格往往用JLabel方式展現每個字符串;如果一列數據是布爾類型,那么該列的單元格往往用JCheckBox方式展現每個布爾值。 
     如何實現復合數據類型的組件的渲染呢?最直接的是在paint方法中一個一個地根據數據類型畫出每一個組件,但這種方法很顯然代碼復用率很低,大量重復了相應標量型組件的代碼,代碼的維護和同步會非常困難,也不容易實現皮膚切換。 
     為解決此問題,Swing體系中提出了所謂渲染器(Renderer)的概念,其核心思想是使用接口,封裝和復用已有標量型組件的渲染代碼,降低代碼重復率,提高組件的可擴展性。

     JTable負責管理表格的可視外觀,在繪制每個單元格時,調用getCellRenderer(int row,int col)獲得當前單元格的渲染器,即得到一個Component,然后將其繪制展現。TableCellRenderer是一個接口,只有一個方法:

 

Component getTableCellRendererComponent(JTable table,
                                        Object value,
                                        boolean isSelected,
                                        boolean hasFocus,
                                        int row,
                                        int column)

     

      其中,row和column標識一個單元格。也就是說,可以根據row和column的不同(單元格也就不同),獲得不同的填充組件,這樣只需要在該方法內進行相應的邏輯判斷。例如,可以實現同一列的不同行渲染效果不同,可以是單元格的背景色不同,或者是單元格內的字體不同諸如此類。下面的列子是,實現偶數行被划一道行線的效果:

 

                           

 

 

[java] view plain copy
 
 print?
  1. import java.awt.*;  
  2.   
  3. import javax.swing.*;  
  4. import javax.swing.table.*;  
  5.   
  6. public class RoundColorTable extends JFrame {  
  7.      private String[] colname = {"第1列","第2列","第3列","第4列","第5列"}; //表頭信息  
  8.      private String[][] data = new String[10][5]; //表內容   
  9.      private JTable table;  
  10.      public RoundColorTable() {  
  11.          //表內容賦值  
  12.          for(int i = 0; i < 10; i++) {  
  13.              for(int j = 0; j < 5; j++) {  
  14.                  data[i][j] = "( " + (j+1) + ", " + (i+1) + " )";  
  15.              }  
  16.          }  
  17.          table = new JTable(new DefaultTableModel(data,colname));  
  18.          TableCellRenderer tcr = new ColorTableCellRenderer();  
  19.          table.setDefaultRenderer(Object.class,tcr);//為JTable增加渲染器,因為是針對於表格中的所有單元格,所有用Object.class  
  20.          add(new JScrollPane(table),BorderLayout.CENTER);  
  21.          setVisible(true);  
  22.          setSize(500,300);  
  23.          setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);  
  24.      }  
  25.      public static void main(String args[]) {  
  26.          new RoundColorTable();  
  27.      }  
  28. }  
  29.   
  30. class ColorTableCellRenderer extends DefaultTableCellRenderer  
  31. {  
  32.     DefaultTableCellRenderer renderer=new DefaultTableCellRenderer();  
  33.     public Component getTableCellRendererComponent(JTable table, Object value,  
  34.         boolean isSelected, boolean hasFocus, int row, int column) {  
  35.         if(row%2 == 0){  
  36.             //調用基類方法  
  37.             return super.getTableCellRendererComponent(table, value, isSelected,hasFocus, row, column);  
  38.         }  
  39.         else{  
  40.             return renderer.getTableCellRendererComponent(table, value, isSelected,hasFocus, row, column);  
  41.         }  
  42.     }  
  43.     //該類繼承與JLabel,Graphics用於繪制單元格,繪制紅線  
  44.     public void paintComponent(Graphics g){  
  45.         super.paintComponent(g);  
  46.         Graphics2D g2=(Graphics2D)g;  
  47.         final BasicStroke stroke=new BasicStroke(2.0f);  
  48.         g2.setColor(Color.RED);  
  49.         g2.setStroke(stroke);  
  50.         g2.drawLine(0,getHeight()/2,getWidth(),getHeight()/2);  
  51.     }  
  52. }  

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM