All Downloads are FREE. Search and download functionalities are using the official Maven repository.

jxl.format.UnderlineStyle Maven / Gradle / Ivy

Go to download

JExcelApi is a java library which provides the ability to read, write, and modify Microsoft Excel spreadsheets.

The newest version!
/*********************************************************************
*
*      Copyright (C) 2002 Andrew Khan
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
***************************************************************************/

package jxl.format;

/**
 * Enumeration class which contains the various underline styles available 
 * within the standard Excel UnderlineStyle palette
 * 
 */
public final class UnderlineStyle
{
  /**
   * The internal numerical representation of the UnderlineStyle
   */
  private int value;

  /**
   * The display string for the underline style.  Used when presenting the 
   * format information
   */
  private String string;

  /**
   * The list of UnderlineStyles
   */
  private static UnderlineStyle[] styles  = new UnderlineStyle[0];

  /**
   * Private constructor
   * 
   * @param val 
   * @param s the display string
   */
  protected UnderlineStyle(int val, String s)
  {
    value = val;
    string = s;

    UnderlineStyle[] oldstyles = styles;
    styles = new UnderlineStyle[oldstyles.length + 1];
    System.arraycopy(oldstyles, 0, styles, 0, oldstyles.length);
    styles[oldstyles.length] = this;
  }

  /**
   * Gets the value of this style.  This is the value that is written to 
   * the generated Excel file
   * 
   * @return the binary value
   */
  public int getValue()
  {
    return value;
  }

  /**
   * Gets the string description for display purposes
   * 
   * @return the string description
   */
  public String getDescription()
  {
    return string;
  }

  /**
   * Gets the UnderlineStyle from the value
   *
   * @param val 
   * @return the UnderlineStyle with that value
   */
  public static UnderlineStyle getStyle(int val)
  {
    for (int i = 0 ; i < styles.length ; i++)
    {
      if (styles[i].getValue() == val)
      {
        return styles[i];
      }
    }

    return NO_UNDERLINE;
  }

  // The underline styles
  public static final UnderlineStyle NO_UNDERLINE  = 
    new UnderlineStyle(0, "none");

  public static final UnderlineStyle SINGLE        = 
    new UnderlineStyle(1, "single");

  public static final UnderlineStyle DOUBLE        = 
    new UnderlineStyle(2, "double");

  public static final UnderlineStyle SINGLE_ACCOUNTING = 
    new UnderlineStyle(0x21, "single accounting");

  public static final UnderlineStyle DOUBLE_ACCOUNTING = 
    new UnderlineStyle(0x22, "double accounting");
}















© 2015 - 2024 Weber Informatics LLC | Privacy Policy