/*
* Copyright (c) 2008 Stiftung Deutsches Elektronen-Synchrotron,
* Member of the Helmholtz Association, (DESY), HAMBURG, GERMANY.
*
* THIS SOFTWARE IS PROVIDED UNDER THIS LICENSE ON AN "../AS IS" BASIS.
* WITHOUT WARRANTY OF ANY KIND, EXPRESSED OR IMPLIED, INCLUDING BUT NOT LIMITED
* TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR PARTICULAR PURPOSE AND
* NON-INFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE
* FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR
* THE USE OR OTHER DEALINGS IN THE SOFTWARE. SHOULD THE SOFTWARE PROVE DEFECTIVE
* IN ANY RESPECT, THE USER ASSUMES THE COST OF ANY NECESSARY SERVICING, REPAIR OR
* CORRECTION. THIS DISCLAIMER OF WARRANTY CONSTITUTES AN ESSENTIAL PART OF THIS LICENSE.
* NO USE OF ANY SOFTWARE IS AUTHORIZED HEREUNDER EXCEPT UNDER THIS DISCLAIMER.
* DESY HAS NO OBLIGATION TO PROVIDE MAINTENANCE, SUPPORT, UPDATES, ENHANCEMENTS,
* OR MODIFICATIONS.
* THE FULL LICENSE SPECIFYING FOR THE SOFTWARE THE REDISTRIBUTION, MODIFICATION,
* USAGE AND OTHER RIGHTS AND OBLIGATIONS IS INCLUDED WITH THE DISTRIBUTION OF THIS
* PROJECT IN THE FILE LICENSE.HTML. IF THE LICENSE IS NOT INCLUDED YOU MAY FIND A COPY
* AT HTTP://WWW.DESY.DE/LEGAL/LICENSE.HTM
*/
package org.csstudio.sds.components.model;
import org.csstudio.sds.model.AbstractWidgetModel;
import org.csstudio.sds.model.BorderStyleEnum;
import org.csstudio.sds.model.WidgetPropertyCategory;
/**
* An arc widget model.
*
* @author jbercic
*
*/
public class ArcModel extends AbstractWidgetModel {
/**
* Unique identifier.
*/
public static final String ID = "org.csstudio.sds.components.Arc";
/**
* The ID of the <i>transparent</i> property.
*/
public static final String PROP_TRANSPARENT = "transparent_background";
/**
* The IDs of the <i>startangle</i> property.
*/
public static final String PROP_STARTANGLE = "start_angle";
/**
* The IDs of the <i>angle</i> property.
*/
public static final String PROP_ANGLE = "angle";
/**
* The IDs of the <i>linewidth</i> property.
*/
public static final String PROP_LINEWIDTH = "linewidth";
/**
* The IDs of the <i>filled</i> property.
*/
public static final String PROP_FILLED = "filled";
/**
* The IDs of the <i>fillcolor</i> property.
*/
public static final String PROP_FILLCOLOR = "color.fill";
/**
* Constructor.
*/
public ArcModel() {
setWidth(50);
setHeight(50);
this.setPropertyValue(PROP_BORDER_STYLE, BorderStyleEnum.SHAPE.getIndex());
}
/**
* {@inheritDoc}
*/
@Override
public String getTypeID() {
return ID;
}
/**
* {@inheritDoc}
*/
@Override
protected void configureProperties() {
addBooleanProperty(PROP_TRANSPARENT, "Transparent Background", WidgetPropertyCategory.FORMAT, true, true, PROP_COLOR_BACKGROUND);
addIntegerProperty(PROP_STARTANGLE, "Start Angle", WidgetPropertyCategory.DISPLAY, 0, 0, 360, true, PROP_TOOLTIP);
addIntegerProperty(PROP_ANGLE, "Angle", WidgetPropertyCategory.DISPLAY, 90, 0, 360, false, PROP_STARTANGLE);
addIntegerProperty(PROP_LINEWIDTH, "Line Width", WidgetPropertyCategory.DISPLAY, 1, false, PROP_ANGLE);
addBooleanProperty(PROP_FILLED, "Filled", WidgetPropertyCategory.DISPLAY, false, false, PROP_LINEWIDTH);
addColorProperty(PROP_FILLCOLOR, "Fill Color", WidgetPropertyCategory.DISPLAY, "#ff0000", false, PROP_FILLED);
}
/**
* {@inheritDoc}
*/
@Override
protected String getDefaultToolTip() {
final StringBuffer buffer = new StringBuffer();
buffer.append(createTooltipParameter(PROP_ALIASES) + "\n");
buffer.append("Start Angle:\t");
buffer.append(createTooltipParameter(PROP_STARTANGLE) + "\n");
buffer.append("Angle:\t");
buffer.append(createTooltipParameter(PROP_ANGLE));
return buffer.toString();
}
/**
* Returns the transparent state of the background.
*
* @return true, if the background is transparent, false otherwise
*/
public boolean getTransparent() {
return getBooleanProperty(PROP_TRANSPARENT);
}
/**
* Returns the value for the start angle.
*
* @return The value for the start angle
*/
public int getStartAngle() {
return getIntegerProperty(PROP_STARTANGLE);
}
/**
* Returns the value for the angle.
*
* @return The value for the angle
*/
public int getAngle() {
return getIntegerProperty(PROP_ANGLE);
}
/**
* Returns the width of the arc.
*
* @return The width of the arc
*/
public int getLineWidth() {
return getIntegerProperty(PROP_LINEWIDTH);
}
/**
* Returns the fill state of the arc.
*
* @return true, if the arc should be filled, false otherwise
*/
public boolean getFill() {
return getBooleanProperty(PROP_FILLED);
}
}