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

org.eclipse.swt.graphics.FontMetrics Maven / Gradle / Ivy

Go to download

The Rich Ajax Platform lets you build rich, Ajax-enabled Web applications.

There is a newer version: 3.29.0
Show newest version
/*******************************************************************************
 * Copyright (c) 2010, 2013 EclipseSource and others.
 * All rights reserved. This program and the accompanying materials
 * are made available under the terms of the Eclipse Public License v1.0
 * which accompanies this distribution, and is available at
 * http://www.eclipse.org/legal/epl-v10.html
 *
 * Contributors:
 *    EclipseSource - initial API and implementation
 ******************************************************************************/
package org.eclipse.swt.graphics;

import org.eclipse.rap.rwt.internal.textsize.TextSizeUtil;

/**
 * Instances of this class provide measurement information about fonts . FontMetrics are obtained from GCs using the
 * getFontMetrics() method.
 *
 * @see GC#getFontMetrics
 * @since 1.3
 */
public final class FontMetrics {

  private Font font;

  /**
   * Prevents instances from being created outside the package.
   */
  FontMetrics( Font font ) {
    this.font = font;
  }

  /**
   * Returns the average character width, measured in pixels, of the font
   * described by the receiver.
   *
   * @return the average character width of the font
   */
  public int getAverageCharWidth() {
    return ( int )TextSizeUtil.getAvgCharWidth( font );
  }

  /**
   * Returns the height of the font described by the receiver, measured in
   * pixels. A font's height is the sum of its ascent, descent and
   * leading area.
   *
   * @return the height of the font
   */
  public int getHeight() {
    return TextSizeUtil.getCharHeight( font );
  }

  /**
   * Compares the argument to the receiver, and returns true if they represent
   * the same object using a class specific comparison.
   *
   * @param object the object to compare with this object
   * @return true if the object is the same as this object and
   *         false otherwise
   * @see #hashCode
   */
  @Override
  public boolean equals( Object object ) {
    boolean result = false;
    if( object == this ) {
      result = true;
    } else if( object instanceof FontMetrics ) {
      FontMetrics other = ( FontMetrics )object;
      result = font.equals( other.font );
    }
    return result;
  }

  /**
   * Returns an integer hash code for the receiver. Any two objects that return
   * true when passed to equals must return the same
   * value for this method.
   *
   * @return the receiver's hash
   * @see #equals
   */
  @Override
  public int hashCode() {
    return font.hashCode();
  }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy