简体   繁体   English

如何在SWT中按列对表格排序

[英]How can I sort a table by column in SWT

I'm making a program that gets data from a database in MySQL and puts it into a SWT Table and the way I was sorting the table was deleting all the TableItem's and loading all the sorted data again from the database but when there are a lot of rows in the database it takes a lot loading the data 我正在编写一个从MySQL中的数据库中获取数据并将其放入SWT表中的程序,而我对该表进行排序的方式是删除所有TableItem并从数据库中再次加载所有已排序的数据,但是当有很多情况时数据库中的行数需要大量的数据加载

I tried some codes that I found to sort a Table but they didn't work, I don't know if I was doing right or not but didn't work 我尝试了一些发现对表进行排序的代码,但是它们没有用,我不知道我做对了还是不正确,但是没有用

Is there any easy way to sort a SWT Table? 有没有简单的方法来排序SWT表?

Here you have an appropriate code example for sorting swt columns: 在这里,您有一个适当的代码示例,用于对swt列进行排序:

import org.eclipse.swt.*;  
 import org.eclipse.swt.widgets.*;  
 import org.eclipse.swt.layout.*;  
 import java.text.*;  
 import java.util.*;  

public class SortTable {  

  public static void main(String[] args) {  
     Display display = new Display ();  
     Shell shell = new Shell (display);  
     shell.setLayout(new FillLayout());  
     final Table table = new Table(shell, SWT.BORDER);  
     table.setHeaderVisible(true);  
     final TableColumn column1 = new TableColumn(table, SWT.NONE);  
     column1.setText("Column 1");  
     final TableColumn column2 = new TableColumn(table, SWT.NONE);  
     column2.setText("Column 2");  
     TableItem item = new TableItem(table, SWT.NONE);  
     item.setText(new String[] {"a", "3"});  
     item = new TableItem(table, SWT.NONE);  
     item.setText(new String[] {"b", "2"});  
     item = new TableItem(table, SWT.NONE);  
     item.setText(new String[] {"c", "1"});  
     column1.setWidth(100);  
     column2.setWidth(100);  
     Listener sortListener = new Listener() {  
         public void handleEvent(Event e) {  
             TableItem[] items = table.getItems();  
             Collator collator = Collator.getInstance(Locale.getDefault());  
             TableColumn column = (TableColumn)e.widget;  
             int index = column == column1 ? 0 : 1;  
             for (int i = 1; i < items.length; i++) {  
                 String value1 = items[i].getText(index);  
                 for (int j = 0; j < i; j++){  
                     String value2 = items[j].getText(index);  
                     if (collator.compare(value1, value2) < 0) {  
                         String[] values = {items[i].getText(0), items[i].getText(1)};  
                         items[i].dispose();  
                         TableItem item = new TableItem(table, SWT.NONE, j);  
                         item.setText(values);  
                         items = table.getItems();  
                         break;  
                     }  
                 }  
             }  
             table.setSortColumn(column);  
         }  
     };  
     column1.addListener(SWT.Selection, sortListener);  
     column2.addListener(SWT.Selection, sortListener);  
     table.setSortColumn(column1);  
     table.setSortDirection(SWT.UP);  
     shell.setSize(shell.computeSize(SWT.DEFAULT, SWT.DEFAULT).x, 300);  
     shell.open();  
     while (!shell.isDisposed ()) {  
         if (!display.readAndDispatch ()) display.sleep ();  
     }  
     display.dispose ();  
 }  

 } 

I do not think you need to delete the existing data in the tableItems . 我认为您不需要删除tableItems的现有数据。 Just call the table.getItems() that will overwrite the existing data. 只需调用table.getItems() ,它将覆盖现有数据。

If we use as input for Viewer a List we can use Collections.sort() method. 如果我们使用List作为Viewer的输入,则可以使用Collections.sort()方法。 We can create a generic sorter which takes a field as parameter and viewer (to obtain a data model) 我们可以创建一个通用的分类器,将字段作为参数并使用查看器(以获取数据模型)

void createColumn(String fieldName){
Field field = MyClass.getDeclaredField(fieldName);
coltName = new TableViewerColumn(viewer, swtModifier);
coltName.getColumn().addSelectionListener(createSorter(viewer, field));
}


SelectionListener createSorter(final TableViewer viewer, final Field field) {
    return new SelectionListener() {

@SuppressWarnings({ "unchecked", "rawtypes" })
@Override
public void widgetSelected(SelectionEvent e) {
Object data= viewer.getInput();
 viewer.getTable().setSortColumn((TableColumn) e.getSource());
 int oldSortDir = viewer.getTable().getSortDirection();
int newSortDir = SWT.UP;
switch(oldSortDir){
    case SWT.UP:
        newSortDir = SWT.DOWN;
        break;
    case SWT.DOWN:
        newSortDir = SWT.UP;
        break;
}
viewer.getTable().setSortDirection(newSortDir);
if(data instanceof List){
    Collections.sort((List) data, createComparator(field));
    viewer.refresh();
}           
}

@Override
public void widgetDefaultSelected(SelectionEvent e) {
    widgetSelected(e);
}
};
}

@SuppressWarnings("rawtypes")
Comparator createComparator(final Field field) {
    return new Comparator() {
        @Override
        public int compare(Object arg0, Object arg1) {
            try {
                Object value0 = field.get(arg0);
                Object value1 = field.get(arg1);

                if(value0 instanceof Integer){
                    return ((Integer) value0).compareTo((Integer) value1);
                }

                if(value0 instanceof String){
                    return ((String) value0).compareToIgnoreCase((String) value1);
                }

                if(value0 instanceof Date){
                    return ((Date) value0).compareTo((Date) value1);
                }

                if(value0 instanceof BigDecimal){
                    return ((BigDecimal) value0).compareTo((BigDecimal) value1);
                }

                if(value0 instanceof Long){
                    return ((Long) value0).compareTo((Long) value1);
                }

                if(value0 instanceof Double){
                    return ((Double) value0).compareTo((Double) value1);
                }

                if(value0 instanceof Boolean){
                    return ((Boolean) value0).compareTo((Boolean) value1);
                }
            }
            catch (IllegalArgumentException e) {
                e.printStackTrace();
            }
            catch (IllegalAccessException e) {
                e.printStackTrace();
            }

            return 0;
        }};
}

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM