blob: cdf8ba3e4af9b46c6c1083217ba80b40ded94c70 [file] [log] [blame]
/*******************************************************************************
* Copyright (c) 2000, 2017 IBM Corporation and others.
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License v. 2.0 which is available at
* http://www.eclipse.org/legal/epl-2.0.
*
* SPDX-License-Identifier: EPL-2.0
*
*******************************************************************************/
package org.eclipse.dltk.internal.ui.callhierarchy;
import org.eclipse.dltk.ui.DLTKPluginImages;
import org.eclipse.dltk.ui.DLTKUIPlugin;
import org.eclipse.jface.resource.CompositeImageDescriptor;
import org.eclipse.jface.resource.ImageDescriptor;
import org.eclipse.swt.graphics.ImageData;
import org.eclipse.swt.graphics.Point;
public class CallHierarchyImageDescriptor extends CompositeImageDescriptor {
/** Flag to render the recursive adornment */
public final static int RECURSIVE= 0x001;
/** Flag to render the callee adornment */
public final static int MAX_LEVEL= 0x002;
private ImageDescriptor fBaseImage;
private int fFlags;
private Point fSize;
/**
* Creates a new CallHierarchyImageDescriptor.
*
* @param baseImage an image descriptor used as the base image
* @param flags flags indicating which adornments are to be rendered. See <code>setAdornments</code>
* for valid values.
* @param size the size of the resulting image
* @see #setAdornments(int)
*/
public CallHierarchyImageDescriptor(ImageDescriptor baseImage, int flags, Point size) {
fBaseImage= baseImage;
fFlags= flags;
fSize= size;
}
/**
* Sets the descriptors adornments. Valid values are: <code>RECURSIVE</code>, <code>CALLER</code>,
* <code>CALLEE</code>, <code>MAX_LEVEL</code>, or any combination of those.
*
* @param adornments the image descritpors adornments
*/
public void setAdornments(int adornments) {
fFlags= adornments;
}
/**
* Returns the current adornments.
*
* @return the current adornments
*/
public int getAdronments() {
return fFlags;
}
/**
* Sets the size of the image created by calling <code>createImage()</code>.
*
* @param size the size of the image returned from calling <code>createImage()</code>
* @see ImageDescriptor#createImage()
*/
public void setImageSize(Point size) {
fSize= size;
}
/**
* Returns the size of the image created by calling <code>createImage()</code>.
*
* @return the size of the image created by calling <code>createImage()</code>
* @see ImageDescriptor#createImage()
*/
public Point getImageSize() {
return new Point(fSize.x, fSize.y);
}
@Override
protected Point getSize() {
return fSize;
}
@Override
public boolean equals(Object object) {
if (object == null || !CallHierarchyImageDescriptor.class.equals(object.getClass()))
return false;
CallHierarchyImageDescriptor other= (CallHierarchyImageDescriptor)object;
return (fBaseImage.equals(other.fBaseImage) && fFlags == other.fFlags && fSize.equals(other.fSize));
}
@Override
public int hashCode() {
return fBaseImage.hashCode() | fFlags | fSize.hashCode();
}
@Override
protected void drawCompositeImage(int width, int height) {
ImageData bg= getImageData(fBaseImage);
drawImage(bg, 0, 0);
drawBottomLeft();
}
private ImageData getImageData(ImageDescriptor descriptor) {
ImageData data= descriptor.getImageData(); // see bug 51965: getImageData can return null
if (data == null) {
data= DEFAULT_IMAGE_DATA;
DLTKUIPlugin.logErrorMessage("Image data not available: " + descriptor.toString()); //$NON-NLS-1$
}
return data;
}
private void drawBottomLeft() {
Point size= getSize();
int x= 0;
ImageData data= null;
if ((fFlags & RECURSIVE) != 0) {
data= getImageData(DLTKPluginImages.DESC_OVR_RECURSIVE);
drawImage(data, x, size.y - data.height);
x+= data.width;
}
if ((fFlags & MAX_LEVEL) != 0) {
data= getImageData(DLTKPluginImages.DESC_OVR_MAX_LEVEL);
drawImage(data, x, size.y - data.height);
x+= data.width;
}
}
}