maskformatter.java

来自「linux下建立JAVA虚拟机的源码KAFFE」· Java 代码 · 共 584 行 · 第 1/2 页

JAVA
584
字号
/* MaskFormatter.java --    Copyright (C) 2005 Free Software Foundation, Inc.This file is part of GNU Classpath.GNU Classpath is free software; you can redistribute it and/or modifyit under the terms of the GNU General Public License as published bythe Free Software Foundation; either version 2, or (at your option)any later version.GNU Classpath is distributed in the hope that it will be useful, butWITHOUT ANY WARRANTY; without even the implied warranty ofMERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNUGeneral Public License for more details.You should have received a copy of the GNU General Public Licensealong with GNU Classpath; see the file COPYING.  If not, write to theFree Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA02110-1301 USA.Linking this library statically or dynamically with other modules ismaking a combined work based on this library.  Thus, the terms andconditions of the GNU General Public License cover the wholecombination.As a special exception, the copyright holders of this library give youpermission to link this library with independent modules to produce anexecutable, regardless of the license terms of these independentmodules, and to copy and distribute the resulting executable underterms of your choice, provided that you also meet, for each linkedindependent module, the terms and conditions of the license of thatmodule.  An independent module is a module which is not derived fromor based on this library.  If you modify this library, you may extendthis exception to your version of the library, but you are notobligated to do so.  If you do not wish to do so, delete thisexception statement from your version. */package javax.swing.text;import java.text.ParseException;import javax.swing.JFormattedTextField;/** * @author Anthony Balkissoon abalkiss at redhat dot com * */public class MaskFormatter extends DefaultFormatter{  // The declaration of the valid mask characters  private static final char NUM_CHAR = '#';  private static final char ESCAPE_CHAR = '\'';  private static final char UPPERCASE_CHAR = 'U';  private static final char LOWERCASE_CHAR = 'L';  private static final char ALPHANUM_CHAR = 'A';  private static final char LETTER_CHAR = '?';  private static final char ANYTHING_CHAR = '*';  private static final char HEX_CHAR = 'H';    /** The mask for this MaskFormatter **/  private String mask;    /**    * A String made up of the characters that are not valid for input for    * this MaskFormatter.    */  private String invalidChars;    /**    * A String made up of the characters that are valid for input for    * this MaskFormatter.    */  private String validChars;    /** A String used in place of missing chracters if the value does not    * completely fill in the spaces in the mask.   */  private String placeHolder;    /** A character used in place of missing characters if the value does    * not completely fill in the spaces in the mask.   */  private char placeHolderChar = ' ';    /**   * Whether or not stringToValue should return literal characters in the mask.   */  private boolean valueContainsLiteralCharacters = true;    /** A String used for easy access to valid HEX characters **/  private static String hexString = "0123456789abcdefABCDEF";    /** An int to hold the length of the mask, accounting for escaped characters **/  int maskLength = 0;    public MaskFormatter ()  {    // Override super's default behaviour, in MaskFormatter the default    // is not to allow invalid values    setAllowsInvalid(false);  }    /**   * Creates a MaskFormatter with the specified mask.   * @specnote doesn't actually throw a ParseException although it    * is declared to do so   * @param mask   * @throws java.text.ParseException   */  public MaskFormatter (String mask) throws java.text.ParseException  {    // Override super's default behaviour, in MaskFormatter the default    // is not to allow invalid values    setAllowsInvalid(false);    setMask (mask);  }    /**   * Returns the mask used in this MaskFormatter.   * @return the mask used in this MaskFormatter.   */  public String getMask()  {    return mask;  }    /**   * Returns a String containing the characters that are not valid for input   * for this MaskFormatter.   * @return a String containing the invalid characters.   */  public String getInvalidCharacters()  {    return invalidChars;  }    /**   * Sets characters that are not valid for input. If   * <code>invalidCharacters</code> is non-null then no characters contained   * in it will be allowed to be input.   *    * @param invalidCharacters the String specifying invalid characters.   */  public void setInvalidCharacters (String invalidCharacters)  {    this.invalidChars = invalidCharacters;  }    /**   * Returns a String containing the characters that are valid for input   * for this MaskFormatter.   * @return a String containing the valid characters.   */  public String getValidCharacters()  {    return validChars;  }    /**   * Sets characters that are valid for input. If   * <code>validCharacters</code> is non-null then no characters that are   * not contained in it will be allowed to be input.   *    * @param validCharacters the String specifying valid characters.   */  public void setValidCharacters (String validCharacters)  {    this.validChars = validCharacters;  }  /**   * Returns the place holder String that is used in place of missing    * characters when the value doesn't completely fill in the spaces   * in the mask.   * @return the place holder String.   */  public String getPlaceholder()  {    return placeHolder;  }    /**   * Sets the string to use if the value does not completely fill in the mask.   * If this is null, the place holder character will be used instead.   * @param placeholder the String to use if the value doesn't completely    * fill in the mask.   */  public void setPlaceholder (String placeholder)  {    this.placeHolder = placeholder;  }    /**   * Returns the character used in place of missing characters when the   * value doesn't completely fill the mask.   * @return the place holder character   */  public char getPlaceholderCharacter()  {    return placeHolderChar;  }    /**   * Sets the char  to use if the value does not completely fill in the mask.   * This is only used if the place holder String has not been set or does    * not completely fill in the mask.   * @param placeholder the char to use if the value doesn't completely    * fill in the mask.   */  public void setPlaceholderCharacter (char placeholder)  {    this.placeHolderChar = placeholder;  }    /**   * Returns true if stringToValue should return the literal    * characters in the mask.   * @return true if stringToValue should return the literal    * characters in the mask   */  public boolean getValueContainsLiteralCharacters()  {    return valueContainsLiteralCharacters;  }    /**   * Determines whether stringToValue will return literal characters or not.   * @param containsLiteralChars if true, stringToValue will return the    * literal characters in the mask, otherwise it will not.   */  public void setValueContainsLiteralCharacters (boolean containsLiteralChars)  {    this.valueContainsLiteralCharacters = containsLiteralChars;  }    /**   * Sets the mask for this MaskFormatter.     * @specnote doesn't actually throw a ParseException even though it is   * declared to do so   * @param mask the new mask for this MaskFormatter   * @throws ParseException if <code>mask</code> is not valid.   */  public void setMask (String mask) throws ParseException  {    this.mask = mask;    // Update the cached maskLength.    int end = mask.length() - 1;    maskLength = 0;        for (int i = 0; i <= end; i++)      {        // Handle escape characters properly - they don't add to the maskLength        // but 2 escape characters in a row is really one escape character and        // one literal single quote, so that does add 1 to the maskLength.        if (mask.charAt(i) == '\'')          {                        // Escape characters at the end of the mask don't do anything.            if (i != end)              maskLength++;            i++;          }        else          maskLength++;      }  }    /**   * Installs this MaskFormatter on the JFormattedTextField.   * Invokes valueToString to convert the current value from the    * JFormattedTextField to a String, then installs the Actions from   * getActions, the DocumentFilter from getDocumentFilter, and the    * NavigationFilter from getNavigationFilter.   *    * If valueToString throws a ParseException, this method sets the text   * to an empty String and marks the JFormattedTextField as invalid.   */  public void install (JFormattedTextField ftf)  {    super.install(ftf);    if (ftf != null)      {        try        {          valueToString(ftf.getValue());        }        catch (ParseException pe)        {          // Set the text to an empty String and mark the JFormattedTextField          // as invalid.          ftf.setText("");          setEditValid(false);

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?