YLegend ...
This commit is contained in:
parent
f30e8174f5
commit
95f563aa0e
@ -1,4 +1,4 @@
|
|||||||
#Wed, 04 Oct 2017 11:09:53 +0200
|
#Thu, 05 Oct 2017 22:01:54 +0200
|
||||||
annotation.processing.enabled=true
|
annotation.processing.enabled=true
|
||||||
annotation.processing.enabled.in.editor=false
|
annotation.processing.enabled.in.editor=false
|
||||||
annotation.processing.processors.list=
|
annotation.processing.processors.list=
|
||||||
|
@ -29,6 +29,7 @@ import chart.painter.CandleStickChartPainter;
|
|||||||
import chart.painter.ChartPainter;
|
import chart.painter.ChartPainter;
|
||||||
import chart.painter.XLegendPainter;
|
import chart.painter.XLegendPainter;
|
||||||
import chart.painter.ChartCrossPainter;
|
import chart.painter.ChartCrossPainter;
|
||||||
|
import chart.painter.YLegendPainter;
|
||||||
import gui.Globals;
|
import gui.Globals;
|
||||||
import sesim.Exchange.QuoteReceiver;
|
import sesim.Exchange.QuoteReceiver;
|
||||||
import sesim.OHLCData;
|
import sesim.OHLCData;
|
||||||
@ -64,14 +65,19 @@ public class MasterChart extends javax.swing.JPanel implements QuoteReceiver, Ch
|
|||||||
xLegend.addChartPainter(p);
|
xLegend.addChartPainter(p);
|
||||||
xLegend.setXSCrollBar(xScrollBar);
|
xLegend.setXSCrollBar(xScrollBar);
|
||||||
|
|
||||||
p = new CandleStickChartPainter();
|
ChartPainter pc = new CandleStickChartPainter();
|
||||||
p.setDataProvider(this);
|
pc.setDataProvider(this);
|
||||||
|
|
||||||
chart.addChartPainter(p);
|
chart.addChartPainter(pc);
|
||||||
chart.setXSCrollBar(xScrollBar);
|
chart.setXSCrollBar(xScrollBar);
|
||||||
|
|
||||||
p = new ChartCrossPainter();
|
ChartPainter yp = new YLegendPainter(chart);
|
||||||
this.chart.addChartPainter(p);
|
yp.setDataProvider(this);
|
||||||
|
|
||||||
|
this.chart.addChartPainter(yp);
|
||||||
|
|
||||||
|
this.yLegend.addChartPainter(p);
|
||||||
|
this.yLegend.addChartPainter(pc);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -27,6 +27,7 @@ package chart.painter;
|
|||||||
|
|
||||||
import chart.ChartDef;
|
import chart.ChartDef;
|
||||||
import chart.ChartPanel;
|
import chart.ChartPanel;
|
||||||
|
import java.awt.Dimension;
|
||||||
import java.awt.Graphics2D;
|
import java.awt.Graphics2D;
|
||||||
import sesim.OHLCData;
|
import sesim.OHLCData;
|
||||||
|
|
||||||
@ -62,6 +63,11 @@ abstract public class ChartPainter {
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected int getBars(ChartPanel p, ChartDef def){
|
||||||
|
Dimension dim = p.getSize();
|
||||||
|
return (int) (dim.width / (def.x_unit_width * em_size));
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Init method scould be called before painting the chart
|
* Init method scould be called before painting the chart
|
||||||
* @param g Graphics context
|
* @param g Graphics context
|
||||||
|
@ -27,7 +27,6 @@ package chart.painter;
|
|||||||
|
|
||||||
import chart.ChartDef;
|
import chart.ChartDef;
|
||||||
import chart.ChartPanel;
|
import chart.ChartPanel;
|
||||||
import chart.painter.ChartPainter;
|
|
||||||
import java.awt.Color;
|
import java.awt.Color;
|
||||||
import java.awt.Dimension;
|
import java.awt.Dimension;
|
||||||
import java.awt.Graphics2D;
|
import java.awt.Graphics2D;
|
||||||
@ -36,7 +35,7 @@ import javax.swing.JScrollBar;
|
|||||||
import sesim.MinMax;
|
import sesim.MinMax;
|
||||||
import sesim.OHLCData;
|
import sesim.OHLCData;
|
||||||
import sesim.OHLCDataItem;
|
import sesim.OHLCDataItem;
|
||||||
import static sun.awt.geom.Curve.prev;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
|
85
src/chart/painter/YLegendPainter.java
Normal file
85
src/chart/painter/YLegendPainter.java
Normal file
@ -0,0 +1,85 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2017, 7u83 <7u83@mail.ru>
|
||||||
|
* All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions are met:
|
||||||
|
*
|
||||||
|
* * Redistributions of source code must retain the above copyright notice, this
|
||||||
|
* list of conditions and the following disclaimer.
|
||||||
|
* * Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer in the documentation
|
||||||
|
* and/or other materials provided with the distribution.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
||||||
|
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
||||||
|
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
||||||
|
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||||||
|
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
||||||
|
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
||||||
|
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
|
* POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
package chart.painter;
|
||||||
|
|
||||||
|
import chart.Chart;
|
||||||
|
import chart.ChartDef;
|
||||||
|
import chart.ChartPanel;
|
||||||
|
import java.awt.Dimension;
|
||||||
|
import java.awt.Graphics2D;
|
||||||
|
import java.awt.Rectangle;
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @author 7u83 <7u83@mail.ru>
|
||||||
|
*/
|
||||||
|
public class YLegendPainter extends ChartPainter {
|
||||||
|
|
||||||
|
ChartPanel master;
|
||||||
|
|
||||||
|
public YLegendPainter (ChartPanel master){
|
||||||
|
this.master=master;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void drawChart(Graphics2D g, ChartPanel p, ChartDef def) {
|
||||||
|
init(g);
|
||||||
|
|
||||||
|
Dimension dim = master.getSize();
|
||||||
|
int first_bar = getFirstBar(master);
|
||||||
|
int bars = getBars(master,def);
|
||||||
|
|
||||||
|
//Rectangle dim;
|
||||||
|
// dim = p.getSize();
|
||||||
|
// dim = this.clip_bounds;
|
||||||
|
|
||||||
|
// Dimension rv = this.getSize();
|
||||||
|
// int yw = (int) (this.yl_width * em_size);
|
||||||
|
|
||||||
|
// g.drawLine(dim.width + dim.x - yw, 0, dim.width + dim.x - yw, dim.height);
|
||||||
|
|
||||||
|
/*
|
||||||
|
float y1 = ctx.getY(mm.getMin(false));
|
||||||
|
float y2 = ctx.getY(c_mm.getMax(false));
|
||||||
|
float ydiff = y1 - y2;
|
||||||
|
// System.out.printf("%s y1: %f, y2: %f, diff %f\n", Boolean.toString(c_mm.isLog()), y1, y2, ydiff);
|
||||||
|
|
||||||
|
for (int yp = (int) y2; yp < y1; yp += em_width * 5) {
|
||||||
|
g.drawLine(dim.width + dim.x - yw, yp, dim.width + dim.x - yw + em_width, yp);
|
||||||
|
double v1 = ctx.getValAtY(yp);
|
||||||
|
g.drawString(String.format("%.2f", v1), dim.width + dim.x - yw + em_width * 1.5f, yp + c_font_height / 3);
|
||||||
|
}
|
||||||
|
|
||||||
|
double v1, v2;
|
||||||
|
v1 = ctx.getValAtY(y1);
|
||||||
|
v2 = ctx.getValAtY(y2);
|
||||||
|
*/
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user