/* The contents of this file are subject to the THDL Open Community License Version 1.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License on the THDL web site (http://www.thdl.org/). Software distributed under the License is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License for the specific terms governing rights and limitations under the License. The Initial Developer of this software is the Tibetan and Himalayan Digital Library (THDL). Portions created by the THDL are Copyright 2001-2003 THDL. All Rights Reserved. Contributor(s): ______________________________________. */ package org.thdl.tib.bibl; import java.awt.Color; import java.awt.Container; import java.awt.Dimension; import java.awt.GridLayout; import java.awt.event.MouseAdapter; import java.awt.event.MouseEvent; //import java.awt.event.WindowAdapter; //import java.awt.event.WindowEvent; import java.io.File; import java.io.FileReader; import java.io.BufferedReader; import java.io.IOException; import javax.swing.SwingConstants; import javax.swing.JLabel; import javax.swing.JPanel; import javax.swing.JFrame; import javax.swing.JScrollPane; import javax.swing.ScrollPaneConstants; import javax.swing.BorderFactory; import javax.swing.border.CompoundBorder; import javax.swing.border.EmptyBorder; import javax.swing.border.LineBorder; import javax.swing.text.*; /** *<p> * This class creates a panel that displays all the relevant diacritic characters used in Asian Studies. * In the context of TibEdit, it's constructor takes a TibFrame which is its parent. When the mouse is clicked * on any diacritic character displayed in DiacriticPanel, it inserts that character at the cursor of the * TibFrame's {@link TextPane}. All characters are, of course, in Unicode. The file that is the list of diacrtics * is dia.dat in the /bin/ directory. It is a flat file list of the hexadecimal codes for the Unicode diacritics. * These are read and converted into characters by DiacriticPanel and they are displayed in the order they are read. * Thus, to reorder, modify, or add diacritics, one needs only to make the appropriate changes to the dia.dat file. * </p> * * @author Than Garson, Tibetan and Himalayan Digital Library */ public class DiacriticPanel extends JPanel implements TibConstants { // Attributes protected TibFrame frame; protected JTextComponent jtc; private TiblEdit controller; //private StringTokenizer dataSplitter; private char chosenChar; private boolean hasPicked; private boolean isGeneral; /** * Sets the panel's layout, size, and background, and reads in the diacritic data. */ private void init() { // Creating content panel to use for frame's content & initialize //JPanel charPanel = new JPanel(new BorderLayout()); setLayout(new GridLayout(0,3)); setSize(new Dimension(100,450)); setBackground(Color.white); // Split the data, create individual line labels try { BufferedReader br = new BufferedReader(new FileReader(new File(DEFAULT_DIRECTORY + DIA_DATA))); String line = br.readLine(); while(line != null) { char diaChar = (char)Long.parseLong(line.trim(),16); String diaStr = Character.toString(diaChar); JLabel diaLab = getDiaLabel(diaStr); this.add(diaLab); line = br.readLine(); } br.close(); } catch (IOException ioe) { System.out.println("An IOE caught: " + ioe.getMessage()); ioe.printStackTrace(); } } // Accessors /** * This method takes a character, which is actually a String variable and creates a label * with a border and a margin with the supplied character string as the * centered text. Adds a MouseListener that is a {@link DiacriticPanel.TiblEditMouseAdapter}. It is called by the {@link #init} method. * * @param ch - A string variable that is the character associated with this label/button. * * @return JLabel - the label created. */ public JLabel getDiaLabel(String ch) { JLabel lab = new JLabel(ch); lab.setFont(DEFAULT_FONT); lab.setHorizontalAlignment(SwingConstants.CENTER); lab.setBorder(new CompoundBorder(new LineBorder(Color.black),BorderFactory.createEmptyBorder(2,2,2,2))); if(isGeneral) { lab.addMouseListener(new GenMouseAdapter()); } else { lab.addMouseListener(new TiblEditMouseAdapter()); } return lab; } public void setChosenChar(char aChar) { chosenChar = aChar; hasPicked = true; } public char getChosenChar() { char rValue = chosenChar; chosenChar = ' '; hasPicked = false; return rValue; } public void setController(TiblEdit te) { controller = te; } public TiblEdit getController() { return controller; } public void setFrame(TibFrame tf) { frame = tf; } public JFrame getFrame() { return frame; } public void setJTC(JTextComponent jtextc) { jtc = jtextc; } public JTextComponent getJTC() { return jtc; } // Constructors public DiacriticPanel(boolean isGen, Container cont) { super(); isGeneral = isGen; if(cont instanceof TibFrame) { setFrame((TibFrame)cont); } else if(cont instanceof JTextComponent) { setJTC((JTextComponent)cont); } init(); hasPicked = false; } public DiacriticPanel(TibFrame tf) { this(false,tf); setFrame(tf); setController(tf.getController()); } public DiacriticPanel(JTextComponent jtc) { this(true,jtc); } // Inner Classes // The Mouse Adapter /** * <p> * This inner class is a MouseAdapter that implements "mousePressed". It is added to a label with a diacritic * so that when that label is clicked, the corresponding Unicode diacritic character is inserted in the * open document, a {@link TextPane}, at the cursor. *</p> */ private class TiblEditMouseAdapter extends MouseAdapter { /** * <p> * This version of mousePressed. Takes the {@link TibFrame} supplied with the DiacriticPanel's constructor * and gets its {@link TextPane}. It then inserts the Unicode diacritic character from the source * label at the cursor of this text pane. * </p> */ public void mousePressed(MouseEvent me) { TextPane tp = frame.getTextPane(); if(tp.isEditable()) { JLabel source = (JLabel)me.getSource(); String dia = source.getText(); int pos = tp.getCaret().getDot(); try { tp.getDocument().insertString(pos,dia,tp.getCharacterAttributes()); } catch (BadLocationException ble) { System.out.println("Bad location exception while inserting diacritic (" +pos+")! \n"); } } } } private class GenMouseAdapter extends MouseAdapter { /** * <p> * This version of mousePressed. Takes the {@link TibFrame} supplied with the DiacriticPanel's constructor * and gets its {@link TextPane}. It then inserts the Unicode diacritic character from the source * label at the cursor of this text pane. * </p> */ public void mousePressed(MouseEvent me) { JLabel source = (JLabel)me.getSource(); String dia = source.getText(); jtc.replaceSelection(dia); } } // Main Method for testing public static void main(String[] args) {/* TibFrame tf = new TibFrame("Diacritic Test"); DiacriticPanel dp = new DiacriticPanel(); JScrollPane jsp = new JScrollPane(dp, ScrollPaneConstants.VERTICAL_SCROLLBAR_ALWAYS, ScrollPaneConstants.HORIZONTAL_SCROLLBAR_ALWAYS); tf.setContentPane(jsp); tf.pack(); tf.show();*/ } }