|
Components |
|
| |||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
com.sas.graphics.components.piechart.PieChart
public class PieChart
The PieChart component is a Swing component that produces pie charts that support the visualization of multiple response variables. Pie charts use the size of pie slices to graphically represent the value of a statistic for a data range; they are useful for examining how the values of a variable contribute to the whole and for comparing the values of several variables.
Note. This class can be used to render client-side graphs in Java applications or applets. The com.sas.servlet.tbeans.graphics.html.PieChart class can be used to render server-side graphs in Java servlets or JavaServer Pages (JSP). Both classes use the models in the com.sas.graphics.components package.
Graph
,
GraphStyle
,
NoteModel
,
PieChartModel
,
PieChartDataModel
,
PieChartTableDataModel
,
PieChartOLAPDataModel
,
Serialized FormField Summary | |
---|---|
static java.lang.String |
RB_KEY
|
Fields inherited from class com.sas.graphics.components.Graph |
---|
footnoteContainer, titleContainer |
Constructor Summary | |
---|---|
PieChart()
Construct a PieChart using the default GraphStyle (GraphStyle.STYLE_CONVENTION). |
|
PieChart(PieChartDataModel pieChartDataModel)
Construct a PieChart, assigning pieChartDataModel, and using the default GraphStyle (GraphStyle.STYLE_CONVENTION). |
|
PieChart(PieChartDataModel pieChartDataModel,
GraphStyle defaultGraphStyle)
Construct a PieChart assigning pieChartDataModel and applying defaultGraphStyle. |
Method Summary | |
---|---|
void |
applyColorScheme(ColorScheme scheme)
Apply a color scheme to this graph's display attributes. |
protected void |
applyDataModel()
Intended for internalUse only |
protected void |
applyGraphModel()
For internal use only. |
void |
applyGraphStyle(GraphStyle graphStyle)
Apply the GraphStyle display properties onto the PieChart. |
PieChartDataModel |
getDataModel()
Returns the PieChartDataModel that provides a handle to the data along with any associated mapping properties. |
static com.sas.beans.ExtendedBeanInfo |
getExtendedBeanInfo()
Returns information used by the com.sas.beans.Introspector to
augment the automatically introspected information about this PieChart. |
PieChartModel |
getGraphModel()
Returns the PieChartModel that encapsulates most of the PieChart's display properties. |
ChartImageMapInfo |
getImageMapInfo()
Returns the image mapping of the pie chart. |
boolean |
isAnimationEnabled()
|
boolean |
isAutoRepaintEnabled()
Returns whether or not the graph automatically repaints when any of its properties (contained in associated models GraphModel, DataModel, NoteModel, etc) has changed. |
void |
prepareToPaint()
Notify this component that an application is about to call paint directly. |
protected void |
selectionChanged()
Internal use only. |
void |
setAnimationEnabled(boolean enabled)
|
void |
setAutoRepaintEnabled(boolean b)
Sets whether or not the graph automatically repaints when any of its properties (contained in associated models GraphModel, DataModel, NoteModel, etc) has changed. |
void |
setDataModel(PieChartDataModel newDataModel)
Sets the PieChartDataModel which provides a handle to the data, along with associated mapping properties, to define the number and arrangement of data elements (that is slices). |
void |
setGraphModel(PieChartModel newPieChartModel)
Sets a PieChartModel to define most of the PieChart's display properties. |
void |
setLocale(java.util.Locale locale)
Sets the locale of this component. |
protected void |
updateDataModelListeners()
Internal use only. |
Field Detail |
---|
public static final java.lang.String RB_KEY
Constructor Detail |
---|
public PieChart()
GraphStyle
public PieChart(PieChartDataModel pieChartDataModel)
A null PieChartDataModel parameter is equivalent to using the default constructor.
pieChartDataModel
- the data to be used by this graphGraphStyle
,
PieChartTableDataModel
,
PieChartOLAPDataModel
public PieChart(PieChartDataModel pieChartDataModel, GraphStyle defaultGraphStyle)
pieChartDataModel
- provides a data handle with associated mapping propertiesdefaultGraphStyle
- the set of graph display propertiesNoteModel
,
PieChartModel
,
PieChartTableDataModel
,
PieChartOLAPDataModel
Method Detail |
---|
public void setAnimationEnabled(boolean enabled)
public boolean isAnimationEnabled()
public void prepareToPaint()
As per java standard practices; "paint" should never be called directly by an application. However if it is necessary to render the Graph directly then the use of paintAll(Graphics) or printAll(Graphics) is acceptable.
Graphs asynchronously update to keep their view in sync with their model properties (Graphmodel, DataModel, NoteModel etc.). A direct call to paintAll or printAll does not allow for the graph to asynchronously sync up with their model proeprties. prepareToPaint provides this synchronization point necessary for the Graphs to update their component structure as needed.
Note: Used in a headless environment, Graphs will never asynchronously update and therefore require a call to prepareToPaint to render into a GraphicsContext.
The headless and non-headless cases can be handled slightly differently. In the non-headless case the asynchronous updating needs to be halted. This is done by setting the "autoRepaintEnabled" property to false. The default for autoRepaintEnabled is true, allowing the graph to automatically resync and repaint as model properties are modified.
Example writing to an image. Note for readability exception handling has been ignored.
static public void main(String args[]) { BufferedImage bi = new BufferedImage(640,480,BufferedImage.TYPE_INT_RGB); Graphics ig = bi.createGraphics(); // Create Graph PieChart graph = new PieChart(); // This call is not necessary if you are running in a headless environment. graph.setAutoRepaintEnabled(false); // ... assign data and model properties here ... graph.setDataModel(newGraphData()); {// Render sequence graph.setBounds(0,0,bi.getWidth(null),bi.getHeight(null)); // Define the size of the Graph graph.addNotify(); // Makes the component displayable. graph.prepareToPaint(); // do property synchronization graph.paintAll(ig); // render into some graphics context } // Dispose of image graphics context ig.dispose(); // Save immage to disk File file = new File("graph.jpg"); try { ImageIO.write(bi, "jpg", file); } catch (IOException e) { System.out.println("ImageIO.write failed."); } }
prepareToPaint
in class Graph
public void setAutoRepaintEnabled(boolean b)
The setting of this property to false implies that the application will be responsible for synchronizing the graph with its models using the prepareToPaint method.
This method was added to support rendering into an off screen graphics context such as an image.
setAutoRepaintEnabled
in class Graph
b
- true means to automatically updateisAutoRepaintEnabled()
public boolean isAutoRepaintEnabled()
isAutoRepaintEnabled
in class Graph
setAutoRepaintEnabled(boolean)
public static com.sas.beans.ExtendedBeanInfo getExtendedBeanInfo()
com.sas.beans.Introspector
to
augment the automatically introspected information about this PieChart.
public void setLocale(java.util.Locale locale)
setLocale
in class java.awt.Component
locale
- the locale to become this component's localeGraph.getLocale()
public void setGraphModel(PieChartModel newPieChartModel) throws java.lang.IllegalArgumentException
Typically, applyGraphStyle is used to modify the graph's display properties.
newPieChartModel
- the PieChartModel that encapsulates the PieChart's display properties
java.lang.IllegalArgumentException
- if newPieChartModel is null.getGraphModel()
,
PieChartModel.apply(com.sas.graphics.components.piechart.PieChartModel)
,
GraphStyle
public PieChartModel getGraphModel()
setGraphModel(com.sas.graphics.components.piechart.PieChartModel)
,
PieChartModel.apply(com.sas.graphics.components.piechart.PieChartModel)
public void setDataModel(PieChartDataModel newDataModel)
Any change in the PieChartDataModel properties will cause the PieChart to update. The update is asynchronous and delayed so modifying multiple properties in quick succession will result in only a single update. The FullPaintInterface can be used if greater control over the PieChart's paint behavior is needed.
Note: Data value changes will also trigger PieChart to update.
A valid PieChartDataModel is required to draw a graph.
newDataModel
- provides a handle to the data
along with any associated mapping propertiesgetDataModel()
,
PieChartTableDataModel
,
PieChartOLAPDataModel
public PieChartDataModel getDataModel()
setDataModel(com.sas.graphics.components.piechart.PieChartDataModel)
,
PieChartTableDataModel
,
PieChartOLAPDataModel
public ChartImageMapInfo getImageMapInfo()
protected void applyDataModel()
Graph
applyDataModel
in class Graph
protected void applyGraphModel()
applyGraphModel
in class Graph
public void applyGraphStyle(GraphStyle graphStyle)
The GraphStyle enforces certain constraints that are not enforced on the Graph's display models (PieChartModel and NoteModels). For example only one value text color may be specified on the GraphStyle, whereas the PieChartModel supports setting different value text colors between axes, legends and data element text. Most presentations only require a single color for all types of value text, which is easily achieved by applying a GraphStyle.
Applying a GraphStyle will modify the display properties of the PieChartModel and the title and footnote NoteModels. The PieChart does not retain a link to the GraphStyle after this method has been called. Modifying any of the GraphStyle properties after this method has been called will have no affect on the PieChart. Similarly modifying any of PieChart's display properties after this method has been called will have no affect on the GraphStyle properties. To affect any change in the PieChart display appearance the modified GraphStyle or a different GraphStyle would need to be applied again.
A blind PropertyChangeEvent is fired by the PieChart after the apply is made.
No action is taken if a null GraphStyle is passed in.
applyGraphStyle
in class Graph
graphStyle
- the GraphStyle whose properties are conveyed to the PieChartNoteModel
,
PieChartModel
public void applyColorScheme(ColorScheme scheme)
applyColorScheme
in class Graph
scheme
- ColorScheme object containing a set of colors for the charts.protected void selectionChanged()
selectionChanged
in class Graph
protected void updateDataModelListeners()
updateDataModelListeners
in class Graph
Graph.updateDataModelListeners(Object model, Object selectionModel)
|
Components |
|
| |||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |