// Plot implements the plot.Plotter interface. func (g *Grid) Plot(da plot.DrawArea, plt *plot.Plot) { trX, trY := plt.Transforms(&da) if g.Vertical.Color == nil { goto horiz } for _, tk := range plt.X.Tick.Marker(plt.X.Min, plt.X.Max) { if tk.IsMinor() { continue } x := trX(tk.Value) da.StrokeLine2(g.Vertical, x, da.Min.Y, x, da.Min.Y+da.Size.Y) } horiz: if g.Horizontal.Color == nil { return } for _, tk := range plt.Y.Tick.Marker(plt.Y.Min, plt.Y.Max) { if tk.IsMinor() { continue } y := trY(tk.Value) da.StrokeLine2(g.Horizontal, da.Min.X, y, da.Min.X+da.Size.X, y) } }
func (b *QuartPlot) Plot(da plot.DrawArea, plt *plot.Plot) { trX, trY := plt.Transforms(&da) x := trX(b.Location) if !da.ContainsX(x) { return } x += b.Offset med := plot.Pt(x, trY(b.Median)) q1 := trY(b.Quartile1) q3 := trY(b.Quartile3) aLow := trY(b.AdjLow) aHigh := trY(b.AdjHigh) da.StrokeLine2(b.WhiskerStyle, x, aHigh, x, q3) if da.ContainsY(med.Y) { da.DrawGlyphNoClip(b.MedianStyle, med) } da.StrokeLine2(b.WhiskerStyle, x, aLow, x, q1) ostyle := b.MedianStyle ostyle.Radius = b.MedianStyle.Radius / 2 for _, out := range b.Outside { y := trY(b.Value(out)) if da.ContainsY(y) { da.DrawGlyphNoClip(ostyle, plot.Pt(x, y)) } } }
// Thumbnail the thumbnail for the Line, // implementing the plot.Thumbnailer interface. func (pts *Line) Thumbnail(da *plot.DrawArea) { if pts.ShadeColor != nil { points := []plot.Point{ {da.Min.X, da.Min.Y}, {da.Min.X, da.Max().Y}, {da.Max().X, da.Max().Y}, {da.Max().X, da.Min.Y}, } poly := da.ClipPolygonY(points) da.FillPolygon(*pts.ShadeColor, poly) points = append(points, plot.Pt(da.Min.X, da.Min.Y)) } else { y := da.Center().Y da.StrokeLine2(pts.LineStyle, da.Min.X, y, da.Max().X, y) } }
// drawCap draws the cap if it is not clipped. func (e *YErrorBars) drawCap(da *plot.DrawArea, x, y vg.Length) { if !da.Contains(plot.Pt(x, y)) { return } da.StrokeLine2(e.LineStyle, x-e.CapWidth/2, y, x+e.CapWidth/2, y) }