?? pricevolumedemo1.java
字號:
/* ---------------------
* PriceVolumeDemo1.java
* ---------------------
* (C) Copyright 2002-2004, by Object Refinery Limited.
*
*/
package demo;
import java.text.DecimalFormat;
import java.text.SimpleDateFormat;
import javax.swing.JPanel;
import org.jfree.chart.ChartFactory;
import org.jfree.chart.ChartPanel;
import org.jfree.chart.JFreeChart;
import org.jfree.chart.axis.NumberAxis;
import org.jfree.chart.labels.StandardXYToolTipGenerator;
import org.jfree.chart.plot.XYPlot;
import org.jfree.chart.renderer.xy.XYBarRenderer;
import org.jfree.chart.renderer.xy.XYItemRenderer;
import org.jfree.data.time.Day;
import org.jfree.data.time.TimeSeries;
import org.jfree.data.time.TimeSeriesCollection;
import org.jfree.data.xy.IntervalXYDataset;
import org.jfree.data.xy.XYDataset;
import org.jfree.date.MonthConstants;
import org.jfree.ui.ApplicationFrame;
import org.jfree.ui.RefineryUtilities;
/**
* A demonstration application showing how to create a price-volume chart.
*/
public class PriceVolumeDemo1 extends ApplicationFrame {
/**
* Constructs a new demonstration application.
*
* @param title the frame title.
*/
public PriceVolumeDemo1(String title) {
super(title);
JFreeChart chart = createChart();
ChartPanel panel = new ChartPanel(chart, true, true, true, false, true);
panel.setPreferredSize(new java.awt.Dimension(500, 270));
setContentPane(panel);
}
/**
* Creates a chart.
*
* @return a chart.
*/
private static JFreeChart createChart() {
XYDataset priceData = createPriceDataset();
String title = "Eurodollar Futures Contract (MAR03)";
JFreeChart chart = ChartFactory.createTimeSeriesChart(
title,
"Date",
"Price",
priceData,
true,
true,
false
);
XYPlot plot = chart.getXYPlot();
NumberAxis rangeAxis1 = (NumberAxis) plot.getRangeAxis();
rangeAxis1.setLowerMargin(0.40); // to leave room for volume bars
DecimalFormat format = new DecimalFormat("00.00");
rangeAxis1.setNumberFormatOverride(format);
XYItemRenderer renderer1 = plot.getRenderer();
renderer1.setToolTipGenerator(
new StandardXYToolTipGenerator(
StandardXYToolTipGenerator.DEFAULT_TOOL_TIP_FORMAT,
new SimpleDateFormat("d-MMM-yyyy"), new DecimalFormat("0.00")
)
);
NumberAxis rangeAxis2 = new NumberAxis("Volume");
rangeAxis2.setUpperMargin(1.00); // to leave room for price line
plot.setRangeAxis(1, rangeAxis2);
plot.setDataset(1, createVolumeDataset());
plot.setRangeAxis(1, rangeAxis2);
plot.mapDatasetToRangeAxis(1, 1);
XYBarRenderer renderer2 = new XYBarRenderer(0.20);
renderer2.setToolTipGenerator(
new StandardXYToolTipGenerator(
StandardXYToolTipGenerator.DEFAULT_TOOL_TIP_FORMAT,
new SimpleDateFormat("d-MMM-yyyy"), new DecimalFormat("0,000.00")
)
);
plot.setRenderer(1, renderer2);
return chart;
}
/**
* Creates a sample dataset.
*
* @return A sample dataset.
*/
private static XYDataset createPriceDataset() {
// create dataset 1...
TimeSeries series1 = new TimeSeries("Price", Day.class);
series1.add(new Day(2, MonthConstants.JANUARY, 2002), 95.565);
series1.add(new Day(3, MonthConstants.JANUARY, 2002), 95.640);
series1.add(new Day(4, MonthConstants.JANUARY, 2002), 95.710);
series1.add(new Day(7, MonthConstants.JANUARY, 2002), 95.930);
series1.add(new Day(8, MonthConstants.JANUARY, 2002), 95.930);
series1.add(new Day(9, MonthConstants.JANUARY, 2002), 95.960);
series1.add(new Day(10, MonthConstants.JANUARY, 2002), 96.055);
series1.add(new Day(11, MonthConstants.JANUARY, 2002), 96.335);
series1.add(new Day(14, MonthConstants.JANUARY, 2002), 96.290);
series1.add(new Day(15, MonthConstants.JANUARY, 2002), 96.275);
series1.add(new Day(16, MonthConstants.JANUARY, 2002), 96.240);
series1.add(new Day(17, MonthConstants.JANUARY, 2002), 96.080);
series1.add(new Day(18, MonthConstants.JANUARY, 2002), 96.145);
series1.add(new Day(22, MonthConstants.JANUARY, 2002), 96.120);
series1.add(new Day(23, MonthConstants.JANUARY, 2002), 96.015);
series1.add(new Day(24, MonthConstants.JANUARY, 2002), 95.890);
series1.add(new Day(25, MonthConstants.JANUARY, 2002), 95.8650);
series1.add(new Day(28, MonthConstants.JANUARY, 2002), 95.880);
series1.add(new Day(29, MonthConstants.JANUARY, 2002), 96.050);
series1.add(new Day(30, MonthConstants.JANUARY, 2002), 96.065);
series1.add(new Day(31, MonthConstants.JANUARY, 2002), 95.910);
series1.add(new Day(1, MonthConstants.FEBRUARY, 2002), 96.015);
series1.add(new Day(4, MonthConstants.FEBRUARY, 2002), 96.140);
series1.add(new Day(5, MonthConstants.FEBRUARY, 2002), 96.195);
series1.add(new Day(6, MonthConstants.FEBRUARY, 2002), 96.245);
series1.add(new Day(7, MonthConstants.FEBRUARY, 2002), 96.220);
series1.add(new Day(8, MonthConstants.FEBRUARY, 2002), 96.280);
series1.add(new Day(11, MonthConstants.FEBRUARY, 2002), 96.265);
series1.add(new Day(12, MonthConstants.FEBRUARY, 2002), 96.160);
series1.add(new Day(13, MonthConstants.FEBRUARY, 2002), 96.120);
series1.add(new Day(14, MonthConstants.FEBRUARY, 2002), 96.125);
series1.add(new Day(15, MonthConstants.FEBRUARY, 2002), 96.265);
series1.add(new Day(19, MonthConstants.FEBRUARY, 2002), 96.290);
series1.add(new Day(20, MonthConstants.FEBRUARY, 2002), 96.275);
series1.add(new Day(21, MonthConstants.FEBRUARY, 2002), 96.280);
series1.add(new Day(22, MonthConstants.FEBRUARY, 2002), 96.305);
series1.add(new Day(25, MonthConstants.FEBRUARY, 2002), 96.265);
series1.add(new Day(26, MonthConstants.FEBRUARY, 2002), 96.185);
series1.add(new Day(27, MonthConstants.FEBRUARY, 2002), 96.305);
series1.add(new Day(28, MonthConstants.FEBRUARY, 2002), 96.215);
series1.add(new Day(1, MonthConstants.MARCH, 2002), 96.015);
series1.add(new Day(4, MonthConstants.MARCH, 2002), 95.970);
series1.add(new Day(5, MonthConstants.MARCH, 2002), 95.935);
series1.add(new Day(6, MonthConstants.MARCH, 2002), 95.935);
series1.add(new Day(7, MonthConstants.MARCH, 2002), 95.705);
series1.add(new Day(8, MonthConstants.MARCH, 2002), 95.4850);
series1.add(new Day(11, MonthConstants.MARCH, 2002), 95.505);
series1.add(new Day(12, MonthConstants.MARCH, 2002), 95.540);
series1.add(new Day(13, MonthConstants.MARCH, 2002), 95.675);
series1.add(new Day(14, MonthConstants.MARCH, 2002), 95.510);
series1.add(new Day(15, MonthConstants.MARCH, 2002), 95.500);
series1.add(new Day(18, MonthConstants.MARCH, 2002), 95.500);
series1.add(new Day(19, MonthConstants.MARCH, 2002), 95.535);
series1.add(new Day(20, MonthConstants.MARCH, 2002), 95.420);
series1.add(new Day(21, MonthConstants.MARCH, 2002), 95.400);
series1.add(new Day(22, MonthConstants.MARCH, 2002), 95.375);
series1.add(new Day(25, MonthConstants.MARCH, 2002), 95.350);
series1.add(new Day(26, MonthConstants.MARCH, 2002), 95.505);
series1.add(new Day(27, MonthConstants.MARCH, 2002), 95.550);
series1.add(new Day(28, MonthConstants.MARCH, 2002), 95.485);
series1.add(new Day(1, MonthConstants.APRIL, 2002), 95.485);
series1.add(new Day(2, MonthConstants.APRIL, 2002), 95.630);
series1.add(new Day(3, MonthConstants.APRIL, 2002), 95.735);
series1.add(new Day(4, MonthConstants.APRIL, 2002), 95.695);
series1.add(new Day(5, MonthConstants.APRIL, 2002), 95.810);
series1.add(new Day(8, MonthConstants.APRIL, 2002), 95.810);
series1.add(new Day(9, MonthConstants.APRIL, 2002), 95.865);
series1.add(new Day(10, MonthConstants.APRIL, 2002), 95.885);
series1.add(new Day(11, MonthConstants.APRIL, 2002), 95.900);
series1.add(new Day(12, MonthConstants.APRIL, 2002), 95.980);
series1.add(new Day(15, MonthConstants.APRIL, 2002), 96.035);
series1.add(new Day(16, MonthConstants.APRIL, 2002), 96.000);
series1.add(new Day(17, MonthConstants.APRIL, 2002), 96.035);
series1.add(new Day(18, MonthConstants.APRIL, 2002), 96.085);
series1.add(new Day(19, MonthConstants.APRIL, 2002), 96.0750);
series1.add(new Day(22, MonthConstants.APRIL, 2002), 96.105);
series1.add(new Day(23, MonthConstants.APRIL, 2002), 96.075);
series1.add(new Day(24, MonthConstants.APRIL, 2002), 96.210);
series1.add(new Day(25, MonthConstants.APRIL, 2002), 96.255);
series1.add(new Day(26, MonthConstants.APRIL, 2002), 96.310);
series1.add(new Day(29, MonthConstants.APRIL, 2002), 96.310);
series1.add(new Day(30, MonthConstants.APRIL, 2002), 96.325);
series1.add(new Day(1, MonthConstants.MAY, 2002), 96.345);
series1.add(new Day(2, MonthConstants.MAY, 2002), 96.285);
series1.add(new Day(3, MonthConstants.MAY, 2002), 96.385);
series1.add(new Day(6, MonthConstants.MAY, 2002), 96.380);
series1.add(new Day(7, MonthConstants.MAY, 2002), 96.485);
series1.add(new Day(8, MonthConstants.MAY, 2002), 96.230);
series1.add(new Day(9, MonthConstants.MAY, 2002), 96.310);
series1.add(new Day(10, MonthConstants.MAY, 2002), 96.445);
series1.add(new Day(13, MonthConstants.MAY, 2002), 96.355);
series1.add(new Day(14, MonthConstants.MAY, 2002), 96.180);
series1.add(new Day(15, MonthConstants.MAY, 2002), 96.240);
?? 快捷鍵說明
復(fù)制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號
Ctrl + =
減小字號
Ctrl + -