/*******************************************************************************
* Copyright (c) 2000, 2011, 2012 IBM Corporation, Gerhardt Informatics Kft. 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:
* IBM Corporation - initial API and implementation
* Gerhardt Informatics Kft. - GEFGWT port
*******************************************************************************/
package org.eclipse.swt.graphics;
import org.eclipse.swt.SWT;
/**
* <code>LineAttributes</code> defines a set of line attributes that can be
* modified in a GC.
* <p>
* Application code does <em>not</em> need to explicitly release the resources
* managed by each instance when those instances are no longer required, and
* thus no <code>dispose()</code> method is provided.
* </p>
*
* @see GC#getLineAttributes()
* @see GC#setLineAttributes(LineAttributes)
* @see <a href="http://www.eclipse.org/swt/">Sample code and further
* information</a>
*
* @since 3.3
*/
public class LineAttributes {
/**
* The line width.
*/
public float width;
/**
* The line style.
*
* @see org.eclipse.swt.SWT#LINE_CUSTOM
* @see org.eclipse.swt.SWT#LINE_DASH
* @see org.eclipse.swt.SWT#LINE_DASHDOT
* @see org.eclipse.swt.SWT#LINE_DASHDOTDOT
* @see org.eclipse.swt.SWT#LINE_DOT
* @see org.eclipse.swt.SWT#LINE_SOLID
*/
public int style;
/**
* The line cap style.
*
* @see org.eclipse.swt.SWT#CAP_FLAT
* @see org.eclipse.swt.SWT#CAP_ROUND
* @see org.eclipse.swt.SWT#CAP_SQUARE
*/
public int cap;
/**
* The line join style.
*
* @see org.eclipse.swt.SWT#JOIN_BEVEL
* @see org.eclipse.swt.SWT#JOIN_MITER
* @see org.eclipse.swt.SWT#JOIN_ROUND
*/
public int join;
/**
* The line dash style for SWT.LINE_CUSTOM.
*/
public float[] dash;
/**
* The line dash style offset for SWT.LINE_CUSTOM.
*/
public float dashOffset;
/**
* The line miter limit.
*/
public float miterLimit;
/**
* Create a new line attributes with the specified line width.
*
* @param width
* the line width
*/
public LineAttributes(float width) {
this(width, SWT.CAP_FLAT, SWT.JOIN_MITER, SWT.LINE_SOLID, null, 0, 10);
}
/**
* Create a new line attributes with the specified line cap, join and width.
*
* @param width
* the line width
* @param cap
* the line cap style
* @param join
* the line join style
*/
public LineAttributes(float width, int cap, int join) {
this(width, cap, join, SWT.LINE_SOLID, null, 0, 10);
}
/**
* Create a new line attributes with the specified arguments.
*
* @param width
* the line width
* @param cap
* the line cap style
* @param join
* the line join style
* @param style
* the line style
* @param dash
* the line dash style
* @param dashOffset
* the line dash style offset
* @param miterLimit
* the line miter limit
*/
public LineAttributes(float width, int cap, int join, int style,
float[] dash, float dashOffset, float miterLimit) {
this.width = width;
this.cap = cap;
this.join = join;
this.style = style;
this.dash = dash;
this.dashOffset = dashOffset;
this.miterLimit = miterLimit;
}
/**
* Compares the argument to the receiver, and returns true if they represent
* the <em>same</em> object using a class specific comparison.
*
* @param object
* the object to compare with this object
* @return <code>true</code> if the object is the same as this object and
* <code>false</code> otherwise
*
* @see #hashCode()
*/
public boolean equals(Object object) {
if (object == this)
return true;
if (!(object instanceof LineAttributes))
return false;
LineAttributes p = (LineAttributes) object;
if (p.width != width)
return false;
if (p.cap != cap)
return false;
if (p.join != join)
return false;
if (p.style != style)
return false;
if (p.dashOffset != dashOffset)
return false;
if (p.miterLimit != miterLimit)
return false;
if (p.dash != null && dash != null) {
if (p.dash.length != dash.length)
return false;
for (int i = 0; i < dash.length; i++) {
if (p.dash[i] != dash[i])
return false;
}
} else {
if (p.dash != null || dash != null)
return false;
}
return true;
}
/**
* Returns an integer hash code for the receiver. Any two objects that
* return <code>true</code> when passed to <code>equals</code> must return
* the same value for this method.
*
* @return the receiver's hash
*
* @see #equals(Object)
*/
public int hashCode() {
return 0;
}
}