Package org.fest.swing.driver

Source Code of org.fest.swing.driver.JTableHeaderLocation

/*
* Created on Mar 13, 2008
*
* Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on
* an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the
* specific language governing permissions and limitations under the License.
*
* Copyright @2008-2010 the original author or authors.
*/
package org.fest.swing.driver;

import static java.lang.String.valueOf;
import static org.fest.util.Strings.concat;

import java.awt.Point;
import java.awt.Rectangle;

import javax.swing.table.JTableHeader;

import org.fest.swing.annotation.RunsInCurrentThread;
import org.fest.swing.exception.LocationUnavailableException;
import org.fest.swing.util.Pair;
import org.fest.swing.util.TextMatcher;

/**
* Understands the location of a <code>{@link JTableHeader}</code> (a coordinate, column index or value.)
*
* @author Yvonne Wang
* @author Alex Ruiz
*/
public class JTableHeaderLocation {

  /**
   * Returns the index and the coordinates of the column which name matches the value in the given
   * <code>{@link TextMatcher}</code>.
   * <p>
   * <b>Note:</b> This method is <b>not</b> executed in the event dispatch thread (EDT.) Clients are responsible for
   * invoking this method in the EDT.
   * </p>
   * @param tableHeader the target <code>JTableHeader</code>.
   * @param matcher indicates which is the matching column name.
   * @return the index and the coordinates of the column under the given index.
   * @throws LocationUnavailableException if a column with a matching value cannot be found.
   */
  @RunsInCurrentThread
  public Pair<Integer, Point> pointAt(JTableHeader tableHeader, TextMatcher matcher) {
    int index = indexOf(tableHeader, matcher);
    if (isValidIndex(tableHeader, index)) return new Pair<Integer, Point>(index, point(tableHeader, index));
    throw new LocationUnavailableException(
        concat("Unable to find column with name matching ", matcher.description(), " ", matcher.formattedValues()));
  }

  @RunsInCurrentThread
  private boolean isValidIndex(JTableHeader tableHeader, int index) {
    int itemCount = columnCount(tableHeader);
    return (index >= 0 && index < itemCount);
  }

  /**
   * Returns the coordinates of the column under the given index.
   * <p>
   * <b>Note:</b> This method is <b>not</b> executed in the event dispatch thread (EDT.) Clients are responsible for
   * invoking this method in the EDT.
   * </p>
   * @param tableHeader the target <code>JTableHeader</code>.
   * @param index the given index.
   * @return the coordinates of the column under the given index.
   * @throws IndexOutOfBoundsException if the index is out of bounds.
   */
  @RunsInCurrentThread
  public Point pointAt(JTableHeader tableHeader, int index) {
    return point(tableHeader, validatedIndex(tableHeader, index));
  }

  @RunsInCurrentThread
  private static Point point(JTableHeader tableHeader, int index) {
    Rectangle r = tableHeader.getHeaderRect(index);
    return new Point(r.x + r.width / 2, r.y + r.height / 2);
  }

  @RunsInCurrentThread
  private int validatedIndex(JTableHeader tableHeader, int index) {
    int itemCount = columnCount(tableHeader);
    if (index >= 0 && index < itemCount) return index;
    throw new IndexOutOfBoundsException(concat(
        "Item index (", valueOf(index), ") should be between [", valueOf(0), "] and [",  valueOf(itemCount - 1),
        "] (inclusive)"));
  }

  /**
   * Returns the index of the column which name matches the value in the given <code>{@link TextMatcher}</code>, or -1
   * if a matching column was not found.
   * <p>
   * <b>Note:</b> This method is <b>not</b> executed in the event dispatch thread (EDT.) Clients are responsible for
   * invoking this method in the EDT.
   * </p>
   * @param tableHeader the target <code>JTableHeader</code>.
   * @param matcher indicates which is the matching column name.
   * @return the index of a matching column or -1 if a matching column was not found.
   */
  @RunsInCurrentThread
  public int indexOf(JTableHeader tableHeader, TextMatcher matcher) {
    int size = columnCount(tableHeader);
    for (int i = 0; i < size; i++)
      if (matcher.isMatching(columnName(tableHeader, i))) return i;
    return -1;
  }

  @RunsInCurrentThread
  private int columnCount(JTableHeader header) {
    return header.getColumnModel().getColumnCount();
  }

  @RunsInCurrentThread
  private String columnName(JTableHeader tableHeader, int index) {
    return tableHeader.getTable().getModel().getColumnName(index);
  }
}
TOP

Related Classes of org.fest.swing.driver.JTableHeaderLocation

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.