1

Ok。2 つのコンテナーを含むメインフレームがあります。1 つは私のウィザードに似たボタンを含み、もう 1 つは contentPane を含みます。Window1、Window2 などのいくつかのクラスをメインフレーム クラスでインスタンス化してから、contentPane に表示する Window クラスを決定する cardLayout を介してトグリングします。

これらの各 Window クラスには、データベースへの接続が必要です。現在、ウィンドウ クラスでデータベース接続を個別にインスタンス化していますが、Window1 クラス (ログイン クラスとも呼ばれます) を渡した瞬間からアプリケーションを閉じるまで、何らかの形で接続されているグローバル セッションが必要です。他の Window クラスに到達すると、このセッションを使用してデータベースの読み取りと書き込みを行うことができます。

私のメインフレームクラス:

public class MainFrame {
private static void createAndShowGUI() {
    JFrame frame = new JFrame("Stackoverflowquestion");
    frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
    frame.setLocationRelativeTo(null);

    final JPanel contentPane = new JPanel();
    contentPane.setLayout(new CardLayout(5, 5));

    Database db = new Database();
    //Trying to make some kind of global database instance but fails

    Window1 win1 = new Window1();
    contentPane.add(win1);
    Window2 win2 = new Window2();
    contentPane.add(win2);
    Window3 win3 = new Window3();
    contentPane.add(win3);
    Window4 win4 = new Window4();
    contentPane.add(win4);
    Window5 win5 = new Window5();
    contentPane.add(win5);
    Window6 win6 = new Window6();
    contentPane.add(win6);

    JPanel buttonPanel = new JPanel(); 
    final JButton previousButton = new JButton("< PREVIOUS");
    previousButton.setEnabled(false);
    final JButton nextButton = new JButton("NEXT >");
    final JButton cancelButton = new JButton("CANCEL");
    buttonPanel.add(cancelButton);
    buttonPanel.add(previousButton);
    buttonPanel.add(nextButton);            

    nextButton.addActionListener(new ActionListener() {
        public void actionPerformed(ActionEvent ae) {
            nextButton.setCursor(Cursor.getPredefinedCursor(Cursor.WAIT_CURSOR));
            Verifiable verifiable = null;
            Component[] contents = contentPane.getComponents();
            for(Component component : contents) {
                if(component.isVisible() && component instanceof Verifiable) {
                    verifiable = (Verifiable)component;
                }
            }
            if(verifiable != null && verifiable.isDataValid()) {
                CardLayout cardLayout = (CardLayout) contentPane.getLayout();
                cardLayout.next(contentPane); 
                previousButton.setEnabled(true);
                nextButton.setCursor(Cursor.getDefaultCursor()); 

            }
        }
    });

    cancelButton.addActionListener(new ActionListener() {
        public void actionPerformed(ActionEvent ae) {
            System.exit(0);
              //Should close the database session
        }

    });

    frame.add(contentPane);
    frame.add(buttonPanel, BorderLayout.PAGE_END);
    frame.setSize(400, 400);
    frame.setVisible(true);
}
    public static void main(String[] args) {

        SwingUtilities.invokeLater(new Runnable() {
            public void run() {
                createAndShowGUI();
            }
        });
    }
} 

Window クラスの例:

public class Window1 extends JPanel implements Verifiable {

public static final String IDENTIFIER = "FIRST";

JTextField txtUsername = new JTextField();
JPasswordField txtPassword = new JPasswordField();

Database db = new Database();
     //As I said, I currently intantiate a database connection separetely which
     //I want to get rid of 
public Window1() {
    init();
}

private void init() {
    JLabel lblUsername = new JLabel("Username:", JLabel.CENTER);
    lblUsername.setBounds(10, 91, 135, 77);
    txtUsername = new JTextField();
    txtUsername.setBounds(155, 116, 188, 27);

    JLabel lblPassword = new JLabel("Password:", JLabel.CENTER);
    lblPassword.setBounds(0, 163, 149, 77);
    txtPassword = new JPasswordField();
    txtPassword.setBounds(155, 188, 188, 27);
    setLayout(null);

    add(lblUsername);
    add(txtUsername);
    add(lblPassword);
    add(txtPassword);
    String title = "Log in";
    setBorder(BorderFactory.createTitledBorder(title));
}

@Override
public boolean isDataValid() {
    String username = new String(txtUsername.getText());
    String password = new String(txtPassword.getPassword());

    try {
        DatabaseConnection conn = db.getDatabaseConnection(username, password, "test", "test", "test");
        db.getTest(conn);
        return true;
        } catch (LoginFailedException e) {
            JOptionPane.showMessageDialog(this, "Something went wrong", 
                    "Error", JOptionPane.ERROR_MESSAGE);
            return false;
    }
}

@Override
public String getIdentifier() {
    return IDENTIFIER;
}

}

4

1 に答える 1

2

シングルトンパターンを使用します。基本的に、オブジェクトのインスタンスを1つ持つことができ、どこからでも取得できます。詳細はこちら: http: //en.wikipedia.org/wiki/Singleton_pattern

以下の私の例では、必要なデータベースへの呼び出しを作成するために使用するデータベース接続を持つことができます。私は現在取り組んでいるプロジェクトでこれとまったく同じことをしています。それは素晴らしい働きをします:)

次に例を示します。

public class DatabaseConnection {

  private static DatabaseConnection instance; //note this is static

  private DatabaseConnection() { //note this is private
  }

  public static DatabaseConnection getInstance() { //note this is static
    if (instance == null) {
      instance = new DatabaseConnection();
    }
    return instance;
  }

ウィキペディアが従来の方法と呼んでいる方法を試すこともできます(これを見た後、これがこれからのやり方だと思います)。

public class DatabaseConnection {
  private static final DatabaseConnection instance = new DatabaseConnection();

  // Private constructor prevents instantiation from other classes
  private DatabaseConnection() { }

  public static DatabaseConnection getInstance() {
    return instance;
  }
}
于 2012-03-22T12:20:28.090 に答える