⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 wordbreakiterator.java

📁 swing编写的库存管理程序。毕业设计类
💻 JAVA
字号:
/**
 * ========================================
 * JFreeReport : a free Java report library
 * ========================================
 *
 * Project Info:  http://www.jfree.org/jfreereport/index.html
 * Project Lead:  Thomas Morgner;
 *
 * (C) Copyright 2000-2003, by Simba Management Limited and Contributors.
 *
 * 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.
 *
 * ----------------------
 * WordBreakIterator.java
 * ----------------------
 * (C)opyright 2003, by Thomas Morgner and Contributors.
 *
 * Original Author:  Thomas Morgner;
 * Contributor(s):   David Gilbert (for Simba Management Limited);
 *
 * $Id: WordBreakIterator.java,v 1.2 2003/08/24 15:13:23 taqua Exp $
 *
 * Changes
 * -------
 * 18-03-2003 : Initial version
 */
package org.jfree.report.util;

/**
 * Behaves similiar to BreakIterator.getWordInstance() but handles line break
 * delimeters as simple whitespaces.
 * <p>
 * This class is not synchronized.
 *
 * @author Thomas Morgner.
 */
public class WordBreakIterator
{
  /** A useful constant. */
  public static final int DONE = -1;

  /** The current position. */
  private int position;

  /** Storage for characters. */
  private char[] text;

  /**
   * Creates a new iterator.
   *
   * @param text  the text to break.
   */
  public WordBreakIterator(final String text)
  {
    setText(text);
  }

  /**
   * Returns the next word boundary.
   *
   * @return The index of the next word boundary.
   */
  public int next()
  {
    if (position == DONE)
    {
      return DONE;
    }
    if (text == null)
    {
      return DONE;
    }
    if (position == text.length)
    {
      return DONE;
    }

    //lastFound = position;

    if (Character.isWhitespace(text[position]))
    {
      // search the first non whitespace character ..., this is the beginning of the word
      while ((position < text.length) && (Character.isWhitespace(text[position])))
      {
        position++;
      }
      return position;
    }
    else
    {
      // now search the first whitespace character ..., this is the end of the word
      while ((position < text.length) && (Character.isWhitespace(text[position]) == false))
      {
        position++;
      }
      return position;
    }
  }

  /**
   * Same like next(), but returns the End-Of-Text as
   * if there was a linebreak added (Reader.readLine() compatible)
   *
   * @return  The next position.
   */
  public int nextWithEnd()
  {
    final int pos = position;
    if (pos == DONE || pos == text.length)
    {
      return DONE;
    }
    final int retval = next();
    if (retval == DONE)
    {
      return text.length;
    }
    return retval;
  }

  /**
   * Returns the position of the previous break.
   *
   * @return The index.
   */
  public int previous()
  {
    //return lastFound;

    if (position == 0)
    {
      return 0;
    }
    if (text == null)
    {
      return DONE;
    }
    if (position == DONE)
    {
      position = text.length;
      return position;
    }
    //lastFound = position;

    if (Character.isWhitespace(text[position - 1]))
    {
      // search the first non whitespace character ..., this is the beginning of the word
      while ((position > 0) && (Character.isWhitespace(text[position - 1])))
      {
        position--;
      }
      return position;
    }
    else
    {
      // now search the first whitespace character ..., this is the end of the word
      while ((position > 0) && (Character.isWhitespace(text[position - 1]) == false))
      {
        position--;
      }
      return position;
    }

  }

  /**
   * Returns the text to be broken up.
   *
   * @return the text.
   */
  public String getText()
  {
    return new String(text);
  }

  /**
   * Sets the text to be broken up.
   *
   * @param text  the text.
   */
  public void setText(final String text)
  {
    position = 0;
    //lastFound = 0;
    this.text = text.toCharArray();
  }

  /**
   * Returns the current parsing position of this iterator.
   *
   * @return returns the current parsing position of this iterator.
   */
  public int getPosition()
  {
    return position;
  }

  /**
   * Defines the current parse position for the word break iterator. The position
   * must be positive and within the range of the current text.
   *
   * @param position the position.
   */
  public void setPosition(final int position)
  {
    if (position < 0)
    {
      throw new IndexOutOfBoundsException("Position < 0");
    }
    if (position > text.length)
    {
      throw new IndexOutOfBoundsException("Position > text.length");
    }
    this.position = position;
  }
/*
  public static void main (String [] args)
  {
    WordBreakIterator wb = new WordBreakIterator("FirstName a verylong text indeeed");
    wb.setPosition(DONE);
    while (wb.previous() != 0)
    {
      System.out.println ("Pos: " + wb.getPosition());
    }
    System.out.println ("---------------------------------------------------------");
    while (wb.nextWithEnd() != DONE)
    {
      System.out.println ("Pos: " + wb.getPosition());
    }
  }
*/
}

⌨️ 快捷键说明

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