思路分析:
因?yàn)槭谴绑w應(yīng)用,首先看視圖層。需要一個(gè)按鈕控件JButton用來(lái)選擇文件夾;需要一個(gè)標(biāo)簽控件JLabel用來(lái)顯示選擇的路徑;需要一個(gè)標(biāo)簽控件JLabel提示用戶(hù)輸入什么;需要一個(gè)文本框控件JTextField供用戶(hù)輸入文件類(lèi)型;需要一個(gè)表格控件JTable顯示選中目錄下指定類(lèi)型的文件。
對(duì)于按鈕控件,為其綁定事件處理方法,在該方法中首先創(chuàng)建JFileChooser文件選擇器對(duì)象,為該對(duì)象設(shè)置選擇器的過(guò)濾器,即通過(guò)JFileChoose類(lèi)的setFileSelectionMode()方法設(shè)定只能選擇路徑,然后執(zhí)行showDialog()方法,再使用JFileChooser類(lèi)的getSelectedFile()方法獲取選中路徑,賦值給一個(gè)File型變量,使用toString()方法將該路徑顯示在標(biāo)簽中,最后獲取過(guò)濾后的符合條件的文件數(shù)組。
對(duì)于文本框控件,一旦里面的文字發(fā)生變化,就要重新對(duì)選中路徑中的文件進(jìn)行過(guò)濾,所以通過(guò)JTextField類(lèi)的addCaretListener()方法為其綁定事件處理方法,在該方法中獲取過(guò)濾后的符合條件的文件數(shù)組。
因?yàn)榘粹o控件和文本框控件都要實(shí)現(xiàn)過(guò)濾及顯示,故可以將過(guò)濾及顯示單獨(dú)作為一個(gè)方法,在該方法中首先判斷當(dāng)前路徑是否為空,若不為空則使用File類(lèi)的listFiles()方法獲取符合條件的文件數(shù)組,賦值給一個(gè)File型數(shù)組,然后使用JTable類(lèi)的getModel()方法獲取表格的數(shù)據(jù)模型,使用DefaultTableModel類(lèi)的setRowCount()方法先將表格清空,然后使用foreach()循環(huán)遍歷文件數(shù)組,在循環(huán)中使用Object[]數(shù)組創(chuàng)建表格行數(shù)據(jù),調(diào)用File類(lèi)的getName()方法獲取文件名,length()方法獲取文件大小,lastModified()方法獲取修改日期,最后使用DefaultTableModel類(lèi)的addRow()方法添加行數(shù)據(jù)到表格模型。
代碼如下:
import java.awt.BorderLayout;
import java.awt.EventQueue;
import java.awt.GridBagConstraints;
import java.awt.GridBagLayout;
import java.awt.Insets;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.io.File;
import java.sql.Date;
import javax.swing.JButton;
import javax.swing.JFileChooser;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JPanel;
import javax.swing.JScrollPane;
import javax.swing.JTable;
import javax.swing.JTextField;
import javax.swing.border.EmptyBorder;
import javax.swing.event.CaretEvent;
import javax.swing.event.CaretListener;
import javax.swing.table.DefaultTableModel;
public class ListCustomTypeFile extends JFrame {
/**
*
*/
private static final long serialVersionUID = -6263975104443132420L;
/**
* 自定義擴(kuò)展名過(guò)濾器
*
* @author 李鐘尉
*/
private final class CustomFilter implements java.io.FileFilter {
@Override
public boolean accept(File pathname) {
// 獲取用戶(hù)設(shè)置的指定擴(kuò)展名
String extName = extNameField.getText();
if (extName == null || extName.isEmpty())
return false;
if (!extName.startsWith("."))// 判斷擴(kuò)展名前綴
extName = "." + extName;// 完事擴(kuò)展名前綴
extName = extName.toLowerCase();
// 判斷擴(kuò)展名與過(guò)濾文件名是否符合要求
if (pathname.getName().toLowerCase().endsWith(extName))
return true;
return false;
}
}
private JPanel contentPane;
private JTextField extNameField;
private JTable table;
private File dir;
private JLabel label;
/**
* Launch the application.
*/
public static void main(String[] args) {
EventQueue.invokeLater(new Runnable() {
public void run() {
try {
ListCustomTypeFile frame = new ListCustomTypeFile();
frame.setVisible(true);
} catch (Exception e) {
e.printStackTrace();
}
}
});
}
/**
* Create the frame.
*/
public ListCustomTypeFile() {
setTitle("顯示指定類(lèi)型的文件");
setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
setBounds(100, 100, 450, 300);
contentPane = new JPanel();
contentPane.setBorder(new EmptyBorder(5, 5, 5, 5));
contentPane.setLayout(new BorderLayout(0, 0));
setContentPane(contentPane);
JPanel panel = new JPanel();
contentPane.add(panel, BorderLayout.NORTH);
GridBagLayout gbl_panel = new GridBagLayout();
gbl_panel.columnWidths = new int[] { 93, 54, 0 };
gbl_panel.rowHeights = new int[] { 23, 0, 0 };
gbl_panel.columnWeights = new double[] { 0.0, 1.0, Double.MIN_VALUE };
gbl_panel.rowWeights = new double[] { 0.0, 0.0, Double.MIN_VALUE };
panel.setLayout(gbl_panel);
JButton button = new JButton("選擇文件夾");
button.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent e) {
do_button_actionPerformed(e);
}
});
GridBagConstraints gbc_button = new GridBagConstraints();
gbc_button.anchor = GridBagConstraints.NORTH;
gbc_button.gridx = 0;
gbc_button.gridy = 0;
panel.add(button, gbc_button);
label = new JLabel("文件夾");
GridBagConstraints gbc_label = new GridBagConstraints();
gbc_label.fill = GridBagConstraints.HORIZONTAL;
gbc_label.gridx = 1;
gbc_label.gridy = 0;
panel.add(label, gbc_label);
JLabel label_1 = new JLabel("輸入指定文件擴(kuò)展名稱(chēng):");
GridBagConstraints gbc_label_1 = new GridBagConstraints();
gbc_label_1.anchor = GridBagConstraints.EAST;
gbc_label_1.insets = new Insets(0, 0, 0, 5);
gbc_label_1.gridx = 0;
gbc_label_1.gridy = 1;
panel.add(label_1, gbc_label_1);
extNameField = new JTextField();
extNameField.addCaretListener(new CaretListener() {
public void caretUpdate(CaretEvent e) {
do_extNameField_caretUpdate(e);
}
});
extNameField.setText(".gif");
GridBagConstraints gbc_extNameField = new GridBagConstraints();
gbc_extNameField.insets = new Insets(0, 0, 5, 0);
gbc_extNameField.fill = GridBagConstraints.HORIZONTAL;
gbc_extNameField.gridx = 1;
gbc_extNameField.gridy = 1;
panel.add(extNameField, gbc_extNameField);
extNameField.setColumns(10);
JScrollPane scrollPane = new JScrollPane();
contentPane.add(scrollPane, BorderLayout.CENTER);
table = new JTable();
table.setAutoResizeMode(JTable.AUTO_RESIZE_OFF);
table.setModel(new DefaultTableModel(new Object[][] {}, new String[] {"文件名稱(chēng)", "文件大小","修改日期" }) {
/**
*
*/
private static final long serialVersionUID = 5274214559103654856L;
boolean[] columnEditables = new boolean[] { false, false, false };
public boolean isCellEditable(int row, int column) {
return columnEditables[column];
}
});
table.getColumnModel().getColumn(0).setPreferredWidth(220);
table.getColumnModel().getColumn(1).setPreferredWidth(85);
table.getColumnModel().getColumn(2).setPreferredWidth(110);
scrollPane.setViewportView(table);
}
/**
* 選擇文件夾按鈕的事件處理方法
*
* @param e
*/
protected void do_button_actionPerformed(ActionEvent e) {
JFileChooser chooser = new JFileChooser();// 創(chuàng)建文件選擇器
// 設(shè)置選擇器的過(guò)濾器
chooser.setFileSelectionMode(JFileChooser.DIRECTORIES_ONLY);
chooser.showDialog(this, null);
dir = chooser.getSelectedFile();
getLabel().setText(dir.toString());
// 獲取過(guò)濾后的符合條件的文件數(shù)組
listFiles();
}
/**
* 顯示文件夾中的文件
*/
private void listFiles() {
if (dir == null)
return;
// 獲取符合條件的文件數(shù)組
File[] files = dir.listFiles(new CustomFilter());
// 獲取表格的數(shù)據(jù)模型
DefaultTableModel model = (DefaultTableModel) table.getModel();
model.setRowCount(0);
for (File file : files) {// 遍歷文件數(shù)組
// 創(chuàng)建表格行數(shù)據(jù)
Object[] row = { file.getName(), file.length(),
new Date(file.lastModified()) };
model.addRow(row);// 添加行數(shù)據(jù)到表格模型
}
}
protected void do_extNameField_caretUpdate(CaretEvent e) {
listFiles();
}
protected JLabel getLabel() {
return label;
}
}
效果如圖: