<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    TWaver - 專注UI技術

    http://twaver.servasoft.com/
    posts - 171, comments - 191, trackbacks - 0, articles - 2
      BlogJava :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理
    TWaver Java不但提供了TTable、TElementTable這些表格組件,而且還提供了表格翻頁器TPageNavigator。讓表格和翻頁器結合工作,可以立刻做出一個非常標準的可翻頁
    的表格界面,如下圖。

    要讓這兩個組件一起工作,直接這樣new一個實例,并放在界面上就可以了:

    1 TElementTable table = new TElementTable();
    2 int[] pageSizes = { 100, 500, 1000 };
    3 TPageNavigator nav=new TPageNavigator(table.getTablePaging(), pageSizes)

    其中nav就是一個普通的JPanel,可以放在界面的任何位置。而table可以和nav在界面上完全脫離顯示,如何布局都可以。

    不過,這個可以翻頁的表格,只能翻頁本地數(shù)據(jù)。也就是說,它只能翻已經(jīng)放入TDataBox中的數(shù)據(jù)。例如我們一次性在TDataBox中加入了10000條數(shù)據(jù),可以通過這個
    翻頁器進行“每頁100條、共有100頁”這樣的翻頁操作。但是大多時候,我們需要的并不是“本地翻頁”,而是“遠程翻頁”。所謂的遠程翻頁,也就是在每次翻頁時候,
    TDataBox的數(shù)據(jù)需要被清空,并從遠程服務器動態(tài)重新獲取“下一頁”的數(shù)據(jù)進行TDataBox加載并且顯示。

    如何做到這一點呢?只要用了TWaver Java這一“神器”,做到這一點就不難了。本文就通過一個例子,來說明如何定制一個翻頁器,來攔截翻頁動作,并從服務器獲取
    翻頁數(shù)據(jù),進行動態(tài)顯示。

    TElementTable的翻頁,實際上是靠一個TablePaging的接口來完成的。TWaver Java靠一個默認的TablePaging實現(xiàn)來完成了本地翻頁。
    而我們要做的,就是創(chuàng)建一個遠程翻頁的TablePaging,來代替這個默認實現(xiàn)即可。

    TablePaging接口定義了下面這些函數(shù)。大多數(shù)的函數(shù),都是在問你一些簡單的遠端數(shù)據(jù)方面的問題:一共有多少記錄?一頁有多少條記錄?一共有多少頁?當前是第幾頁?
    并且在第一頁、最后一頁、上一頁、下一頁等操作發(fā)生時,回調(diào)這個接口。所以,我們只要有了后臺數(shù)據(jù),就不難回答這些問題。

     1 public interface TablePaging {
     2     public int getCurrentPageIndex();
     3     public void setCurrentPageIndex(int currentPageIndex);
     4     public int getPageRowSize();
     5     public void setPageRowSize(int pageRowSize);
     6     public int getPageTotalCount();
     7     public int getTotalRowCount();
     8     public void firstPage();
     9     public void previousPage();
    10     public void nextPage();
    11     public void lastPage();
    12     public void update();
    13     public void addPageListener(PageListener pageListener);
    14     public void removePageListener(PageListener pageListener);
    15 }

     以上函數(shù)基本上都可以顧名思義地理解,就不多作介紹了。我們現(xiàn)在假設后臺有一個數(shù)據(jù)庫,里面有一個客戶地址的table。通過一個SQL查詢服務,我們可以獲得這些翻頁數(shù)據(jù)。根據(jù)
    這個假設,我們可以做下面的實現(xiàn):

      1 public class AddressTablePaging implements TablePaging {
      2     private SearchPane parent = null;
      3     private List pageListeners = new ArrayList();
      4     private TElementTable table = null;
      5     private int pageIndex = 1;
      6     private int pageSize = 100;
      7 
      8     public AddressTablePaging(TElementTable table, SearchPane parent) {
      9         this.table = table;
     10         this.parent = parent;
     11     }
     12 
     13     private void loadPage() {
     14         table.getDataBox().clear();
     15         try {
     16             int start = (pageIndex - 1) * pageSize;
     17             Collection<AddressVO> data = Server.searchAddress(..);
     18             for (AddressVO vo : data) {
     19                 Node node = new Node();
     20                 node.setBusinessObject(vo);
     21                 table.getDataBox().addElement(node);
     22             }
     23         } catch (Exception ex) {
     24             ex.printStackTrace();
     25             JOptionPane.showMessageDialog(table, ex.getMessage());
     26         }
     27         firePageChanged();
     28     }
     29 
     30     @Override
     31     public void firstPage() {
     32         pageIndex = 1;
     33         loadPage();
     34     }
     35 
     36     @Override
     37     public int getCurrentPageIndex() {
     38         return this.pageIndex;
     39     }
     40 
     41     @Override
     42     public int getPageRowSize() {
     43         return this.pageSize;
     44     }
     45 
     46     @Override
     47     public int getPageTotalCount() {
     48         try {
     49             int totalCount = getTotalRowCount();
     50             int pageCount = totalCount / getPageRowSize();
     51             if (totalCount % getPageRowSize() > 0) {
     52                 pageCount++;
     53             }
     54             return pageCount;
     55         } catch (Exception ex) {
     56             ex.printStackTrace();
     57         }
     58         return 0;
     59     }
     60 
     61     @Override
     62     public int getTotalRowCount() {
     63         try {
     64             return Server.getAddressTotalCount(.);
     65         } catch (Exception ex) {
     66             ex.printStackTrace();
     67         }
     68         return 0;
     69     }
     70 
     71     @Override
     72     public void lastPage() {
     73         this.pageIndex = getPageTotalCount();
     74         this.loadPage();
     75     }
     76 
     77     @Override
     78     public void nextPage() {
     79         this.pageIndex++;
     80         this.loadPage();
     81     }
     82 
     83     @Override
     84     public void previousPage() {
     85         if (this.pageIndex > 1) {
     86             pageIndex--;
     87         }
     88         this.loadPage();
     89     }
     90 
     91     @Override
     92     public void setCurrentPageIndex(int pageIndex) {
     93         this.pageIndex = pageIndex;
     94     }
     95 
     96     @Override
     97     public void setPageRowSize(int pageSize) {
     98         this.pageSize = pageSize;
     99     }
    100 
    101     @Override
    102     public void addPageListener(PageListener pageListener) {
    103         this.pageListeners.add(pageListener);
    104     }
    105 
    106     @Override
    107     public void removePageListener(PageListener pageListener) {
    108         this.pageListeners.remove(pageListener);
    109     }
    110 
    111     public void firePageChanged() {
    112         for (int i = 0; i < this.pageListeners.size(); i++) {
    113             PageListener pageListener = (PageListener) this.pageListeners.get(i);
    114             pageListener.pageChanged();
    115         }
    116     }
    117 
    118     @Override
    119     public void update() {
    120     }
    121 }

     在上面代碼中,所有的翻頁函數(shù),都會集中調(diào)用loadPage()這個函數(shù),從后臺真正獲取數(shù)據(jù)。而函數(shù)getTotalRowCount則負責
    從后臺獲得“一共有多少條記錄”。其他函數(shù),基本進行轉(zhuǎn)發(fā)即可。

    另外一個需要注意的就是removePageListener/addPageListener等函數(shù)。主要用于對監(jiān)聽器進行管理,包括注冊、刪除、觸發(fā)通知等等。
    這些也是必須要實現(xiàn)的,不過很簡單,用一個ArrayList維護就行了,觸發(fā)時間時候,直接遍歷、回調(diào)即可。

    具體通過SQL從后臺調(diào)用數(shù)據(jù)的實現(xiàn),這里就不介紹了。相信每一個實際項目都有不同的數(shù)據(jù)庫、接口、調(diào)用方法方面的差別。這里只是點到為止。

    有了這個翻頁器,我們就可以直接用在表格中了。下面繼承一個表格,并用這個翻頁器。

    1 public class AddressTable extends TElementTable {
    2     
    3     public AddressTablePaging getTablePaging() {
    4         return tablePaging;
    5     }
    6     
    7 }
    8 

    這樣,默認翻頁器被替換,新的后臺翻頁器被置入表格中。最后,再通過本文最開始提供的兩行代碼把表格放入界面中,程序就基本完成了。

    1 int[] pageSizes = { 100, 500, 1000 };
    2 this.add(new TPageNavigator(table.getTablePaging(), pageSizes), BorderLayout.CENTER);

    其中pageSizes數(shù)組是定義了界面上每頁條數(shù)的下拉列表選項,我們可以根據(jù)實際應用自己設置,如下圖:

    這樣,一個完整的后臺翻頁程序就完成了。給表格設置好列、在后臺添加一些數(shù)據(jù),跑起來會是這樣:



    如果再增加一些查詢字段等,就更帥了:

    對了,最后,再順便給大家介紹一下表格中的可點擊連接是如何做的:


    要做這種可點擊鏈接,首先要做3件事:1是顯示link,2是顯示手形狀的光標,3是響應鼠標點擊動作。對于1,可以來個“釜底抽薪”:在表格上從根兒上攔截prepareRenderer
    然后對文字動態(tài)修改為html的a標簽的連接方式進行處理:

     1 @Override
     2 public Component prepareRenderer(TableCellRenderer renderer, int row, int column) {
     3     Element element = this.getElementByRowIndex(row);
     4     AddressVO vo = (AddressVO) element.getBusinessObject();
     5     Component com = super.prepareRenderer(renderer, row, column);
     6     if (!vo.isValid()) {
     7         com.setForeground(Color.red);
     8     } else {
     9         com.setForeground(Color.black);
    10     }
    11 
    12     if (column == 2 || column == 3) {
    13         String text = ((JLabel) com).getText();
    14         text = "<html><a href=\"#\">" + text + "</a></html>";
    15         ((JLabel) com).setText(text);
    16     }
    17     return com;
    18 }
    19 

     對于手形光標,可以通過監(jiān)聽鼠標移動,是否位于鏈接文字上方來動態(tài)修改光標:
     1 this.addMouseMotionListener(new MouseMotionAdapter() {
     2     @Override
     3     public void mouseMoved(MouseEvent e) {
     4         int row = rowAtPoint(e.getPoint());
     5         int column = columnAtPoint(e.getPoint());
     6         setCursor(Cursor.getDefaultCursor());
     7         if (row >= 0 && column >= 0) {
     8             if (column == 2 || column == 3) {
     9                 setCursor(Cursor.getPredefinedCursor(Cursor.HAND_CURSOR));
    10             }
    11         }
    12     }
    13 });

    最后,對于點擊動作,可以通過給table添加鼠標監(jiān)聽器完成:
     1 this.addMouseListener(new MouseAdapter() {
     2     @Override
     3     public void mouseClicked(MouseEvent e) {
     4         int row = rowAtPoint(e.getPoint());
     5         int column = columnAtPoint(e.getPoint());
     6         setCursor(Cursor.getDefaultCursor());
     7         if (row >= 0 && column >= 0) {
     8             if (column == 2 || column == 3) {
     9                 Object value = getValueAt(row, column);
    10                 //do your action here.
    11             }
    12         }
    13     }
    14 });
    15 

    至此,一個完整的可后臺翻頁、可鼠標點擊超鏈接的綜合型table就完成了。在實際使用中,還可以增加更復雜的翻頁和
    顯示效果。例如在TWaver的兄弟產(chǎn)品2BizBox免費ERP軟件中,就有大量這樣的應用,感興趣的朋友可以到2BizBox.cn
    去下載安裝一個玩一玩。


    只有注冊用戶登錄后才能發(fā)表評論。


    網(wǎng)站導航:
     
    主站蜘蛛池模板: 国产美女在线精品免费观看| 国产亚洲人成A在线V网站| 国产av无码专区亚洲av毛片搜| 亚洲一级片内射网站在线观看| 十八禁无码免费网站| 国产成人精品亚洲一区| 亚洲激情在线视频| 免费理论片51人人看电影| 一个人看的www免费视频在线观看 一个人免费视频观看在线www | 亚洲啪啪综合AV一区| 青青青免费国产在线视频小草| 精品国产_亚洲人成在线| 亚洲精品自产拍在线观看动漫| 日韩激情无码免费毛片| 久久亚洲免费视频| 婷婷亚洲综合五月天小说在线| 久久久久亚洲AV无码专区首JN| 免费在线观看视频a| 四虎永久在线观看免费网站网址| 三年片免费观看大全国语| 亚洲欧美不卡高清在线| 亚洲av无码一区二区乱子伦as | 国产精品亚洲精品观看不卡| 中文字幕在亚洲第一在线| 香蕉视频在线观看免费国产婷婷| 日本免费高清视频| 免费很黄无遮挡的视频毛片| 亚洲91精品麻豆国产系列在线| 久久精品国产69国产精品亚洲| 国产免费观看网站| 成年女人18级毛片毛片免费| 99热精品在线免费观看| 九九99热免费最新版| 免费看黄福利app导航看一下黄色录像| 亚洲伊人久久大香线蕉| 亚洲自偷自偷精品| 久久久久亚洲AV无码专区首| 亚洲真人日本在线| 亚洲Av无码乱码在线观看性色| 国内自产拍自a免费毛片| 久草视频在线免费|