visidor/src/main/java/cz/xelfi/quoridor/visidor/BoardPane.java
author Jaroslav Tulach <jaroslav.tulach@apidesign.org>
Sun, 05 Sep 2010 22:34:43 +0200
changeset 255 9ecd02d694cd
child 266 15fcdfc4cd4a
permissions -rw-r--r--
Official API for BoardPane with listener to react to user gestures.
jaroslav@255
     1
/*
jaroslav@255
     2
 * To change this template, choose Tools | Templates
jaroslav@255
     3
 * and open the template in the editor.
jaroslav@255
     4
 */
jaroslav@255
     5
jaroslav@255
     6
package cz.xelfi.quoridor.visidor;
jaroslav@255
     7
jaroslav@255
     8
import cz.xelfi.quoridor.Board;
jaroslav@255
     9
import cz.xelfi.quoridor.Move;
jaroslav@255
    10
import java.awt.GridLayout;
jaroslav@255
    11
import java.util.List;
jaroslav@255
    12
import java.util.concurrent.CopyOnWriteArrayList;
jaroslav@255
    13
import javax.swing.JPanel;
jaroslav@255
    14
jaroslav@255
    15
/** JavaBean class that displays and can manipulate with Quoridor {@link Board}.
jaroslav@255
    16
 *
jaroslav@255
    17
 * @author Jaroslav Tulach <jtulach@netbeans.org>
jaroslav@255
    18
 */
jaroslav@255
    19
public final class BoardPane extends JPanel {
jaroslav@255
    20
    private final Viewer viewer;
jaroslav@255
    21
    private final List<BoardListener> listeners = new CopyOnWriteArrayList<BoardListener>();
jaroslav@255
    22
    
jaroslav@255
    23
    public BoardPane() {
jaroslav@255
    24
        setLayout(new GridLayout(1,1));
jaroslav@255
    25
        viewer = new Viewer();
jaroslav@255
    26
        viewer.moveListener(this);
jaroslav@255
    27
        add(viewer);
jaroslav@255
    28
    }
jaroslav@255
    29
    
jaroslav@255
    30
    public final void setBoard(Board b) {
jaroslav@255
    31
        viewer.setBoard(b);
jaroslav@255
    32
    }
jaroslav@255
    33
    
jaroslav@255
    34
    public final Board getBoard() {
jaroslav@255
    35
        return viewer.getBoard();
jaroslav@255
    36
    }
jaroslav@255
    37
jaroslav@255
    38
    /** The board can either be in <q>view only</q> mode when showing state 
jaroslav@255
    39
     * of the {@link Board} during opponent's move, or it can be editable.
jaroslav@255
    40
     * In editable mode, one shall listen on changes delivered to 
jaroslav@255
    41
     * BoardListener.
jaroslav@255
    42
     * 
jaroslav@255
    43
     * @param editable read only or editable mode?
jaroslav@255
    44
     */
jaroslav@255
    45
    public final void setEditable(boolean editable) {
jaroslav@255
    46
        viewer.enableListeners(editable);
jaroslav@255
    47
    }
jaroslav@255
    48
    
jaroslav@255
    49
    public final void addBoardListener(BoardListener l) {
jaroslav@255
    50
        listeners.add(l);
jaroslav@255
    51
    }
jaroslav@255
    52
    public final void removeBoardListener(BoardListener l) {
jaroslav@255
    53
        listeners.remove(l);
jaroslav@255
    54
    }
jaroslav@255
    55
    
jaroslav@255
    56
    final void moveHappened(Move m) {
jaroslav@255
    57
        BoardEvent ev = null;
jaroslav@255
    58
        for (BoardListener bl : listeners) {
jaroslav@255
    59
            if (ev == null) {
jaroslav@255
    60
                ev = new BoardEvent(this, m);
jaroslav@255
    61
            }
jaroslav@255
    62
            bl.boardChanged(ev);
jaroslav@255
    63
        }
jaroslav@255
    64
    }
jaroslav@255
    65
}