需要有关JComboBox上的itemStateChanged的帮助

时间:2012-12-22 19:48:04

标签: java swing jcombobox

我有三个JComboBox,一个用于大陆,一个用于国家,另一个用于城市。所有数据都从数据库加载。

第一个JComboBox遍布各大洲。当我选择其中一个时,第二个JComboBox将加载相应的国家/地区。到现在为止,因为我添加了“itemStateChanged”。

但是,当我选择国家/地区时,会再次调用事件“itemStateChanged”。 是什么让我的第二个组合框保留选定的第一个项目,或者(如果我执行“RemoveAllItems”)重复其内容?

没有办法为每个JComboBox创建“itemStateChanged”?在.NET中,可以为每个组合框创建一个“SelectedIndexChanged”吗?

我的代码的某些部分:

public class MainFrame extends JFrame implements ItemListener 
{
…
private String iddistrito="VAZIO!!!";
private String idmunicipio="VAZIO!!!"; 
private boolean limpa=false;
private boolean populardistritos=false;
private boolean popularmunicipios=false;
private JComboBox cbFreguesiacliente = new JComboBox();
private JComboBox cbmunicipiocliente = new JComboBox();
private JComboBox cbdistritocliente = new JComboBox();
…
private void jbInit() throws Exception {
…
cbmunicipiocliente.addItemListener(this);
cbdistritocliente.addItemListener(this);     
…
}

这部分代码是当我点击按钮,启用我的组件时的内容:

private void btnNovocliente_actionPerformed(ActionEvent e) {
    populardistritos = true;
    cbdistritocliente.removeAllItems();
    preenchecbdistritos();
    populardistritos = false;
}

这段代码填充了第一个JComboBox的内容:

private void preenchecbdistritos(){
        query = "select Distrito from distritos;";
        try{
            Class.forName(JDBC_DRIVER);
            connection = DriverManager.getConnection(DATABASE_URL);
            statement = connection.createStatement();
            ResultSet resultset = statement.executeQuery(query);
            StringBuffer results = new StringBuffer();
            ResultSetMetaData metaData = resultset.getMetaData();
            int numberOfColumns = metaData.getColumnCount();
            cbdistritocliente.addItem("");
            while (resultset.next()) {
                for (int i =1; i<= numberOfColumns; i++) {
                    if (metaData.getColumnName(i).equals("Distrito")) {
                        cbdistritocliente.addItem(resultset.getObject(i).toString());
                    }
                }
            }
        } catch (ClassNotFoundException e) {
            JOptionPane.showMessageDialog(this,"rebentou no 1º catch " + e.toString(),"Inane error", JOptionPane.ERROR_MESSAGE);
        } catch (SQLException e) {
            JOptionPane.showMessageDialog(this,"rebentou no 2º catch " + e.toString(),"Inane error", JOptionPane.ERROR_MESSAGE);
        }
}

这是着名的活动,想要为每个JComboBox单独获取:

public void itemStateChanged(ItemEvent e) {
    if (populardistritos == false) {
        if (limpa == false) {
            if ((!cbdistritocliente.getSelectedItem().toString().equals("")) && (idmunicipio.equals("VAZIO!!!")))
            {
                query = "select id_distrito from distritos where distrito = '" + cbdistritocliente.getSelectedItem().toString() + "';";
                try{
                    Class.forName(JDBC_DRIVER);
                    connection = DriverManager.getConnection(DATABASE_URL);
                    statement = connection.createStatement();
                    ResultSet resultset = statement.executeQuery(query);
                    StringBuffer results = new StringBuffer();
                    ResultSetMetaData metaData = resultset.getMetaData();
                    int numberOfColumns = metaData.getColumnCount();
                    while (resultset.next()) {
                        for (int i =1; i<= numberOfColumns; i++) {
                            if (metaData.getColumnName(i).equals("id_distrito")) {
                                iddistrito = resultset.getObject(i).toString();
                            }
                        }
                    }
                        preenchecbmunicipios();    
                } catch (ClassNotFoundException e2) {
                } catch (SQLException e2) {
                }
            }
        }


        if (!cbmunicipiocliente.getSelectedItem().toString().equals(""))
        {
            query = "select id_municipio from municipios where municipio = '" + cbmunicipiocliente.getSelectedItem().toString() + "';";
            try{
                Class.forName(JDBC_DRIVER);
                connection = DriverManager.getConnection(DATABASE_URL);
                statement = connection.createStatement();
                ResultSet resultset = statement.executeQuery(query);
                StringBuffer results = new StringBuffer();
                ResultSetMetaData metaData = resultset.getMetaData();
                int numberOfColumns = metaData.getColumnCount();
                while (resultset.next()) {
                    for (int i =1; i<= numberOfColumns; i++) {
                        if (metaData.getColumnName(i).equals("id_municipio")) {
                            idmunicipio = resultset.getObject(i).toString();
                        }
                    }
                }
            } catch (ClassNotFoundException e2) {
            } catch (SQLException e2) {
            }
        }            
    }
}

这段代码填充了第二个JComboBox的内容:

private void preenchecbmunicipios(){
    if (!iddistrito.equals("VAZIO!!!")) {
        query = "select municipio from municipios where municipios.id_distrito = " + iddistrito + ";";
        populardistritos=true;
        //cbmunicipiocliente.removeAllItems();
        try{
            Class.forName(JDBC_DRIVER);
            connection = DriverManager.getConnection(DATABASE_URL);
            statement = connection.createStatement();
            ResultSet resultset = statement.executeQuery(query);
            StringBuffer results = new StringBuffer();
            ResultSetMetaData metaData = resultset.getMetaData();
            int numberOfColumns = metaData.getColumnCount();
            cbmunicipiocliente.addItem("");
            while (resultset.next()) {
                for (int i =1; i<= numberOfColumns; i++) {
                    if (metaData.getColumnName(i).equals("municipio")) {
                        cbmunicipiocliente.addItem(resultset.getObject(i).toString());
                    }
                }
            }
            populardistritos=false;
        } catch (ClassNotFoundException e) {
            JOptionPane.showMessageDialog(this,"rebentou no 1º catch do cbmunicipio com " + e.toString(),"Inane error", JOptionPane.ERROR_MESSAGE);
        } catch (SQLException e) {
            JOptionPane.showMessageDialog(this,"rebentou no 2º catch do cbmunicipio com " + e.toString(),"Inane error", JOptionPane.ERROR_MESSAGE);
        }            
    }
}

2 个答案:

答案 0 :(得分:2)

the docs告诉您该事件包含有关发起人的信息。所以只需检查e.getItemSelectable()。equals(firstSelectBox)等。

希望有所帮助。

答案 1 :(得分:2)

您可以利用here所示的方法,其中第一个组合中的选择将替换第二个组合中的模型。在该示例中,combo1将占据大陆,combo2模型将设置为包含所选大洲的国家/地区的模型。该示例使用数组,但List<ComboBoxModel<String>>可能是更灵活的选择。