Documentation ¶
Overview ¶
Package vgtex provides a vg.Canvas implementation for LaTeX, targeted at the TikZ/PGF LaTeX package: https://sourceforge.net/projects/pgf
vgtex generates PGF instructions that will be interpreted and rendered by LaTeX. vgtex allows to put any valid LaTeX notation inside plot's strings.
Example ¶
An example of making a LaTeX plot.
package main import ( "image/color" "log" "os" "github.com/elamre/plot" "github.com/elamre/plot/plotter" "github.com/elamre/plot/vg" "github.com/elamre/plot/vg/draw" "github.com/elamre/plot/vg/vgtex" ) func main() { p, err := plot.New() if err != nil { log.Fatal(err) } // p.HideAxes() p.Title.Text = `A scatter plot: $\sqrt{\frac{e^{3i\pi}}{2\cos 3\pi}}$` p.Title.TextStyle.Font.Size = 16 p.X.Label.Text = `$x = \eta$` p.Y.Label.Text = `$y$ is some $\Phi$` scatter1, err := plotter.NewScatter(plotter.XYs{{X: 1, Y: 1}, {X: 0, Y: 1}, {X: 0, Y: 0}}) if err != nil { log.Fatal(err) } scatter1.Color = color.RGBA{R: 255, A: 200} scatter2, err := plotter.NewScatter(plotter.XYs{{X: 1, Y: 0}, {X: 1, Y: 0.5}}) if err != nil { log.Fatal(err) } scatter2.GlyphStyle.Shape = draw.PyramidGlyph{} scatter2.GlyphStyle.Radius = 2 scatter2.Color = color.RGBA{B: 255, A: 200} p.Add(scatter1, scatter2) txtFont := p.X.Label.TextStyle.Font c := vgtex.NewDocument(5*vg.Centimeter, 5*vg.Centimeter) p.Draw(draw.New(c)) c.SetColor(color.Black) c.FillString(txtFont, vg.Point{X: 2.5 * vg.Centimeter, Y: 2.5 * vg.Centimeter}, "x") f, err := os.Create("testdata/scatter.tex") if err != nil { log.Fatal(err) } defer f.Close() if _, err = c.WriteTo(f); err != nil { log.Fatal(err) } err = f.Close() if err != nil { log.Fatal(err) } }
Output:
Index ¶
- type Canvas
- func (c *Canvas) DrawImage(rect vg.Rectangle, img image.Image)
- func (c *Canvas) Fill(p vg.Path)
- func (c *Canvas) FillString(f vg.Font, pt vg.Point, text string)
- func (c *Canvas) Pop()
- func (c *Canvas) Push()
- func (c *Canvas) Rotate(rad float64)
- func (c *Canvas) Scale(x, y float64)
- func (c *Canvas) SetColor(clr color.Color)
- func (c *Canvas) SetLineDash(pattern []vg.Length, offset vg.Length)
- func (c *Canvas) SetLineWidth(w vg.Length)
- func (c *Canvas) Size() (w, h vg.Length)
- func (c *Canvas) Stroke(p vg.Path)
- func (c *Canvas) Translate(pt vg.Point)
- func (c *Canvas) WriteTo(w io.Writer) (int64, error)
Examples ¶
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type Canvas ¶
type Canvas struct {
// contains filtered or unexported fields
}
Canvas implements the vg.Canvas interface, translating drawing primitives from gonum/plot to PGF.
func NewDocument ¶
NewDocument returns a new LaTeX canvas that can be readily compiled into a standalone document.
func (*Canvas) DrawImage ¶
DrawImage implements the vg.Canvas.DrawImage method. DrawImage will first save the image inside a PNG file and have the generated LaTeX reference that file. The file name will be "gonum-pgf-image-<canvas-id>-<time.Now()>.png
func (*Canvas) FillString ¶
FillString implements the vg.Canvas.FillString method.
func (*Canvas) SetLineDash ¶
SetLineDash implements the vg.Canvas.SetLineDash method.
func (*Canvas) SetLineWidth ¶
SetLineWidth implements the vg.Canvas.SetLineWidth method.