GR Reference

module GR

GR is a universal framework for cross-platform visualization applications. It offers developers a compact, portable and consistent graphics library for their programs. Applications range from publication quality 2D graphs to the representation of complex 3D scenes.

See https://gr-framework.org/julia.html for full documentation.

Basic usage: ```julia using GR GR.init() # optional plot(

[0, 0.2, 0.4, 0.6, 0.8, 1.0], [0.3, 0.5, 0.4, 0.2, 0.6, 0.7]

) # GR.show() # Use if in a Jupyter Notebook ```

function isijulia()

function isatom()

function ispluto()

function isvscode()

function setraw!(raw)

function init(always::Bool = false)

init(always::Bool = false)

Initialize GR’s environmental variables before plotting and ensure that the binary shared libraries are loaded. Initialization usually only needs to be done once, but reinitialized may be required when settings change.

The always argument is true if initialization should be forced in the current and subsequent calls. It is false by default so that initialization only is done once.

# Extended Help

Environmental variables which influence init: GRDISPLAY - if “js” or “pluto”, javascript support is initialized GKS_NO_GUI - no initialization is done GKS_IGNORE_ENCODING - Force use of UTF-8 for font encoding, ignore GKS_ENCODING

Environmental variables set by init: GKS_FONTPATH - path to GR fonts, often the same as GRDIR GKS_USE_CAIRO_PNG GKSwstype - Graphics workstation type, see help for openws GKS_QT - Command to start QT backend via gksqt executable GKS_ENCODING - Sets the text encoding (e.g. Latin1 or UTF-8)

function initgr()

function opengks()

function closegks()

function osc_seq()

function st_seq()

function is_dark_mode()

function inqdspsize()

function openws(workstation_id::Int, connection, workstation_type::Int)

openws(workstation_id::Int, connection, workstation_type::Int)

Open a graphical workstation.

Parameters:

workstation_id :

A workstation identifier.

connection :

A connection identifier.

workstation_type :

The desired workstation type.

Available workstation types:

5

Workstation Independent Segment Storage

7, 8

Computer Graphics Metafile (CGM binary, clear text)

41

Windows GDI

51

Mac Quickdraw

61 - 64

PostScript (b/w, color)

101, 102

Portable Document Format (plain, compressed)

210 - 213

X Windows

214

Sun Raster file (RF)

215, 218

Graphics Interchange Format (GIF87, GIF89)

216

Motif User Interface Language (UIL)

320

Windows Bitmap (BMP)

321

JPEG image file

322

Portable Network Graphics file (PNG)

323

Tagged Image File Format (TIFF)

370

Xfig vector graphics file

371

Gtk

380

wxWidgets

381

Qt4

382

Scaleable Vector Graphics (SVG)

390

Windows Metafile

400

Quartz

410

Socket driver

415

0MQ driver

420

OpenGL

430

HTML5 Canvas

function closews(workstation_id::Int)

closews(workstation_id::Int)

Close the specified workstation.

Parameters:

workstation_id :

A workstation identifier.

function activatews(workstation_id::Int)

activatews(workstation_id::Int)

Activate the specified workstation.

Parameters:

workstation_id :

A workstation identifier.

function deactivatews(workstation_id::Int)

deactivatews(workstation_id::Int)

Deactivate the specified workstation.

Parameters:

workstation_id :

A workstation identifier.

function clearws()

function updatews()

function polyline(x, y)

polyline(x, y)

Draw a polyline using the current line attributes, starting from the first data point and ending at the last data point.

Parameters:

x :

A list containing the X coordinates

y :

A list containing the Y coordinates

The values for x and y are in world coordinates. The attributes that control the appearance of a polyline are linetype, linewidth and color index.

function polymarker(x, y)

polymarker(x, y)

Draw marker symbols centered at the given data points.

Parameters:

x :

A list containing the X coordinates

y :

A list containing the Y coordinates

The values for x and y are in world coordinates. The attributes that control the appearance of a polymarker are marker type, marker size scale factor and color index.

function latin1(string)

function text(x::Real, y::Real, string)

text(x::Real, y::Real, string)

Draw a text at position x, y using the current text attributes.

Parameters:

x :

The X coordinate of starting position of the text string

y :

The Y coordinate of starting position of the text string

string :

The text to be drawn

The values for x and y are in normalized device coordinates. The attributes that control the appearance of text are text font and precision, character expansion factor, character spacing, text color index, character height, character up vector, text path and text alignment.

function inqtext(x, y, string)

function textx(x::Real, y::Real, string, opts::UInt32)

function inqtextx(x, y, string, opts::UInt32)

function fillarea(x, y)

fillarea(x, y)

Allows you to specify a polygonal shape of an area to be filled.

Parameters:

x :

A list containing the X coordinates

y :

A list containing the Y coordinates

The attributes that control the appearance of fill areas are fill area interior style, fill area style index and fill area color index.

function cellarray(xmin::Real, xmax::Real, ymin::Real, ymax::Real, dimx::Int, dimy::Int, color)

cellarray(xmin::Real, xmax::Real, ymin::Real, ymax::Real, dimx::Int, dimy::Int, color)

Display rasterlike images in a device-independent manner. The cell array function partitions a rectangle given by two corner points into DIMX X DIMY cells, each of them colored individually by the corresponding color index of the given cell array.

Parameters:

xmin, ymin :

Lower left point of the rectangle

xmax, ymax :

Upper right point of the rectangle

dimx, dimy :

X and Y dimension of the color index array

color :

Color index array

The values for xmin, xmax, ymin and ymax are in world coordinates.

function nonuniformcellarray(x, y, dimx::Int, dimy::Int, color)

nonuniformcellarray(x, y, dimx::Int, dimy::Int, color)

Display a two dimensional color index array with nonuniform cell sizes.

Parameters:

x, y :

X and Y coordinates of the cell edges

dimx, dimy :

X and Y dimension of the color index array

color :

Color index array

The values for x and y are in world coordinates. x must contain dimx + 1 elements and y must contain dimy + 1 elements. The elements i and i+1 are respectively the edges of the i-th cell in X and Y direction.

function polarcellarray(xorg::Real, yorg::Real, phimin::Real, phimax::Real, rmin::Real, rmax::Real, dimphi::Int, dimr::Int, color)

polarcellarray(xorg::Real, yorg::Real, phimin::Real, phimax::Real, rmin::Real, rmax::Real, imphi::Int, dimr::Int, color)

Display a two dimensional color index array mapped to a disk using polar coordinates.

Parameters:

xorg :

X coordinate of the disk center in world coordinates

yorg :

Y coordinate of the disk center in world coordinates

phimin :

start angle of the disk sector in degrees

phimax :

end angle of the disk sector in degrees

rmin :

inner radius of the punctured disk in world coordinates

rmax :

outer radius of the punctured disk in world coordinates

dimiphi, dimr :

Phi (X) and iR (Y) dimension of the color index array

color :

Color index array

The two dimensional color index array is mapped to the resulting image by interpreting the X-axis of the array as the angle and the Y-axis as the radius. The center point of the resulting disk is located at xorg, yorg and the radius of the disk is rmax.

function nonuniformpolarcellarray(x, y, dimx::Int, dimy::Int, color)

nonuniformpolarcellarray(x, y, dimx::Int, dimy::Int, color)

Display a two dimensional color index array mapped to a disk using nonuniform polar coordinates.

Parameters:

x, y :

X and Y coordinates of the cell edges

dimx, dimy :

X and Y dimension of the color index array

color :

Color index array

The two dimensional color index array is mapped to the resulting image by interpreting the X-axis of the array as the angle and the Y-axis as the radius.

function gdp(x, y, primid, datrec)

gdp(x, y, primid, datrec)

Generates a generalized drawing primitive (GDP) of the type you specify, using specified points and any additional information contained in a data record.

Parameters:

x :

A list containing the X coordinates

y :

A list containing the Y coordinates

primid :

Primitive identifier

datrec :

Primitive data record

function path(x, y, codes)

path(x, y, codes)

Draw paths using the given vertices and path codes.

Parameters:

x :

A list containing the X coordinates

y :

A list containing the Y coordinates

codes :

A list containing the path codes

The values for x and y are in world coordinates. The codes describe several path primitives that can be used to create compound paths.

The following path codes are recognized:

Code

Description

x

y

M, m

move

x

y

L, l

line

x

y

Q, q

quadratic Bezier

x1, x2

y1, y2

C, c

cubic Bezier

x1, x2, x3

y1, y2, y3

A, a

arc

rx, a1, reserved

ry, a2, reserved

Z

close path

S

stroke

s

close path and stroke

f

close path and fill

F

close path, fill and stroke

  • Move: M, m

    Moves the current position to (x, y). The new position is either absolute (M) or relative to the current position (m). The initial position of path is (0, 0).

    Example:

    >>> path([0.5, -0.1], [0.2, 0.1], "Mm")
    

    The first move command in this example moves the current position to the absolute coordinates (0.5, 0.2). The second move to performs a movement by (-0.1, 0.1) relative to the current position resulting in the point (0.4, 0.3).

  • Line: L, l

    Draws a line from the current position to the given position (x, y). The end point of the line is either absolute (L) or relative to the current position (l). The current position is set to the end point of the line.

    Example:

    >>> path([0.1, 0.5, 0.0], [0.1, 0.1, 0.2], "MLlS")
    

    The first line to command draws a straight line from the current position (0.1, 0.1) to the absolute position (0.5, 0.1) resulting in a horizontal line. The second line to command draws a vertical line relative to the current position resulting in the end point (0.5, 0.3).

  • Quadratic Bezier curve: Q, q

    Draws a quadratic bezier curve from the current position to the end point (x2, y2) using (x1, y1) as the control point. Both points are either absolute (Q) or relative to the current position (q). The current position is set to the end point of the bezier curve.

    Example:

    >>> path([0.1, 0.3, 0.5, 0.2, 0.4], [0.1, 0.2, 0.1, 0.1, 0.0], "MQqS")
    

    This example will generate two bezier curves whose start and end points are each located at y=0.1. As the control points are horizontally in the middle of each bezier curve with a higher y value both curves are symmetrical and bend slightly upwards in the middle. The current position is set to (0.9, 0.1) at the end.

  • Cubic Bezier curve: C, c

    Draws a cubic bezier curve from the current position to the end point (x3, y3) using (x1, y1) and (x2, y2) as the control points. All three points are either absolute (C) or relative to the current position (c). The current position is set to the end point of the bezier curve.

    Example:

    >>> path(
    ...     [0.1, 0.2, 0.3, 0.4, 0.1, 0.2, 0.3],
    ...     [0.1, 0.2, 0.0, 0.1, 0.1, -0.1, 0.0],
    ...     "MCcS"
    ... )
    

    This example will generate two bezier curves whose start and end points are each located at y=0.1. As the control points are equally spaced along the x-axis and the first is above and the second is below the start and end points this creates a wave-like shape for both bezier curves. The current position is set to (0.8, 0.1) at the end.

  • Ellipctical arc: A, a

    Draws an elliptical arc starting at the current position. The major axis of the ellipse is aligned with the x-axis and the minor axis is aligned with the y-axis of the plot. rx and ry are the ellipses radii along the major and minor axis. a1 and a2 define the start and end angle of the arc in radians. The current position is set to the end point of the arc. If a2 is greater than a1 the arc is drawn counter-clockwise, otherwise it is drawn clockwise. The a and A commands draw the same arc. The third coordinates of the x and y array are ignored and reserved for future use.

    Examples:

    >>> path([0.1, 0.2, -3.14159 / 2, 0.0], [0.1, 0.4, 3.14159 / 2, 0.0], "MAS")
    

    This example draws an arc starting at (0.1, 0.1). As the start angle -pi/2 is smaller than the end angle pi/2 the arc is drawn counter-clockwise. In this case the right half of an ellipse with an x radius of 0.2 and a y radius of 0.4 is shown. Therefore the current position is set to (0.1, 0.9) at the end.

    >>> path([0.1, 0.2, 3.14159 / 2, 0.0], [0.9, 0.4, -3.14159 / 2, 0.0], "MAS")
    

    This examples draws the same arc as the previous one. The only difference is that the starting point is now at (0.1, 0.9) and the start angle pi/2 is greater than the end angle -pi/2 so that the ellipse arc is drawn clockwise. Therefore the current position is set to (0.1, 0.1) at the end.

  • Close path: Z

    Closes the current path by connecting the current position to the target position of the last move command (m or M) with a straight line. If no move to was performed in this path it connects the current position to (0, 0). When the path is stroked this line will also be drawn.

  • Stroke path: S, s

    Strokes the path with the current border width and border color (set with gr.setborderwidth and gr.setbordercolorind). In case of s the path is closed beforehand, which is equivalent to ZS.

  • Fill path: F, f

    Fills the current path using the even-odd-rule using the current fill color. Filling a path implicitly closes the path. The fill color can be set using gr.setfillcolorind. In case of F the path is also stroked using the current border width and color afterwards.

function to_rgb_color(z)

function polyline(x, y, linewidth, line_z)

function polymarker(x, y, markersize, marker_z)

function spline(x, y, m, method)

spline(x, y, m, method)

Generate a cubic spline-fit, starting from the first data point and ending at the last data point.

Parameters:

x :

A list containing the X coordinates

y :

A list containing the Y coordinates

m :

The number of points in the polygon to be drawn (m > len(x))

method :

The smoothing method

The values for x and y are in world coordinates. The attributes that control the appearance of a spline-fit are linetype, linewidth and color index.

If method is > 0, then a generalized cross-validated smoothing spline is calculated. If method is 0, then an interpolating natural cubic spline is calculated. If method is < -1, then a cubic B-spline is calculated.

function gridit(xd, yd, zd, nx, ny)

function setlinetype(style::Int)

setlinetype(style::Int)

Specify the line style for polylines.

Parameters:

style :

The polyline line style

The available line types are:

LINETYPE_SOLID

1

Solid line

LINETYPE_DASHED

2

Dashed line

LINETYPE_DOTTED

3

Dotted line

LINETYPE_DASHED_DOTTED

4

Dashed-dotted line

LINETYPE_DASH_2_DOT

-1

Sequence of one dash followed by two dots

LINETYPE_DASH_3_DOT

-2

Sequence of one dash followed by three dots

LINETYPE_LONG_DASH

-3

Sequence of long dashes

LINETYPE_LONG_SHORT_DASH

-4

Sequence of a long dash followed by a short dash

LINETYPE_SPACED_DASH

-5

Sequence of dashes double spaced

LINETYPE_SPACED_DOT

-6

Sequence of dots double spaced

LINETYPE_DOUBLE_DOT

-7

Sequence of pairs of dots

LINETYPE_TRIPLE_DOT

-8

Sequence of groups of three dots

function setlinewidth(width::Real)

setlinewidth(width::Real)

Define the line width of subsequent polyline output primitives.

Parameters:

width :

The polyline line width scale factor

The line width is calculated as the nominal line width generated on the workstation multiplied by the line width scale factor. This value is mapped by the workstation to the nearest available line width. The default line width is 1.0, or 1 times the line width generated on the graphics device.

function setlinecolorind(color::Int)

setlinecolorind(color::Int)

Define the color of subsequent polyline output primitives.

Parameters:

color :

The polyline color index (COLOR < 1256)

function setmarkertype(mtype::Int)

setmarkertype(mtype::Int)

Specifiy the marker type for polymarkers.

Parameters:

style :

The polymarker marker type

The available marker types are:

MARKERTYPE_DOT

1

Smallest displayable dot

MARKERTYPE_PLUS

2

Plus sign

MARKERTYPE_ASTERISK

3

Asterisk

MARKERTYPE_CIRCLE

4

Hollow circle

MARKERTYPE_DIAGONAL_CROSS

5

Diagonal cross

MARKERTYPE_SOLID_CIRCLE

-1

Filled circle

MARKERTYPE_TRIANGLE_UP

-2

Hollow triangle pointing upward

MARKERTYPE_SOLID_TRI_UP

-3

Filled triangle pointing upward

MARKERTYPE_TRIANGLE_DOWN

-4

Hollow triangle pointing downward

MARKERTYPE_SOLID_TRI_DOWN

-5

Filled triangle pointing downward

MARKERTYPE_SQUARE

-6

Hollow square

MARKERTYPE_SOLID_SQUARE

-7

Filled square

MARKERTYPE_BOWTIE

-8

Hollow bowtie

MARKERTYPE_SOLID_BOWTIE

-9

Filled bowtie

MARKERTYPE_HGLASS

-10

Hollow hourglass

MARKERTYPE_SOLID_HGLASS

-11

Filled hourglass

MARKERTYPE_DIAMOND

-12

Hollow diamond

MARKERTYPE_SOLID_DIAMOND

-13

Filled Diamond

MARKERTYPE_STAR

-14

Hollow star

MARKERTYPE_SOLID_STAR

-15

Filled Star

MARKERTYPE_TRI_UP_DOWN

-16

Hollow triangles pointing up and down overlaid

MARKERTYPE_SOLID_TRI_RIGHT

-17

Filled triangle point right

MARKERTYPE_SOLID_TRI_LEFT

-18

Filled triangle pointing left

MARKERTYPE_HOLLOW PLUS

-19

Hollow plus sign

MARKERTYPE_SOLID PLUS

-20

Solid plus sign

MARKERTYPE_PENTAGON

-21

Pentagon

MARKERTYPE_HEXAGON

-22

Hexagon

MARKERTYPE_HEPTAGON

-23

Heptagon

MARKERTYPE_OCTAGON

-24

Octagon

MARKERTYPE_STAR_4

-25

4-pointed star

MARKERTYPE_STAR_5

-26

5-pointed star (pentagram)

MARKERTYPE_STAR_6

-27

6-pointed star (hexagram)

MARKERTYPE_STAR_7

-28

7-pointed star (heptagram)

MARKERTYPE_STAR_8

-29

8-pointed star (octagram)

MARKERTYPE_VLINE

-30

verical line

MARKERTYPE_HLINE

-31

horizontal line

MARKERTYPE_OMARK

-32

o-mark

Polymarkers appear centered over their specified coordinates.

function setmarkersize(mtype::Real)

setmarkersize(mtype::Real)

Specify the marker size for polymarkers.

Parameters:

size :

Scale factor applied to the nominal marker size

The polymarker size is calculated as the nominal size generated on the graphics device multiplied by the marker size scale factor.

function setmarkercolorind(color::Int)

setmarkercolorind(color::Int)

Define the color of subsequent polymarker output primitives.

Parameters:

color :

The polymarker color index (COLOR < 1256)

function settextfontprec(font::Int, precision::Int)

settextfontprec(font::Int, precision::Int)

Specify the text font and precision for subsequent text output primitives.

Parameters:

font :

Text font (see tables below)

precision :

Text precision (see table below)

The available text fonts are:

FONT_TIMES_ROMAN

101

FONT_TIMES_ITALIC

102

FONT_TIMES_BOLD

103

FONT_TIMES_BOLDITALIC

104

FONT_HELVETICA

105

FONT_HELVETICA_OBLIQUE

106

FONT_HELVETICA_BOLD

107

FONT_HELVETICA_BOLDOBLIQUE

108

FONT_COURIER

109

FONT_COURIER_OBLIQUE

110

FONT_COURIER_BOLD

111

FONT_COURIER_BOLDOBLIQUE

112

FONT_SYMBOL

113

FONT_BOOKMAN_LIGHT

114

FONT_BOOKMAN_LIGHTITALIC

115

FONT_BOOKMAN_DEMI

116

FONT_BOOKMAN_DEMIITALIC

117

FONT_NEWCENTURYSCHLBK_ROMAN

118

FONT_NEWCENTURYSCHLBK_ITALIC

119

FONT_NEWCENTURYSCHLBK_BOLD

120

FONT_NEWCENTURYSCHLBK_BOLDITALIC

121

FONT_AVANTGARDE_BOOK

122

FONT_AVANTGARDE_BOOKOBLIQUE

123

FONT_AVANTGARDE_DEMI

124

FONT_AVANTGARDE_DEMIOBLIQUE

125

FONT_PALATINO_ROMAN

126

FONT_PALATINO_ITALIC

127

FONT_PALATINO_BOLD

128

FONT_PALATINO_BOLDITALIC

129

FONT_ZAPFCHANCERY_MEDIUMITALIC

130

FONT_ZAPFDINGBATS

131

The available text precisions are:

TEXT_PRECISION_STRING

0

String precision (higher quality)

TEXT_PRECISION_CHAR

1

Character precision (medium quality)

TEXT_PRECISION_STROKE

2

Stroke precision (lower quality)

The appearance of a font depends on the text precision value specified. STRING, CHARACTER or STROKE precision allows for a greater or lesser realization of the text primitives, for efficiency. STRING is the default precision for GR and produces the highest quality output.

function setcharexpan(factor::Real)

setcharexpan(factor::Real)

Set the current character expansion factor (width to height ratio).

Parameters:

factor :

Text expansion factor applied to the nominal text width-to-height ratio

setcharexpan defines the width of subsequent text output primitives. The expansion factor alters the width of the generated characters, but not their height. The default text expansion factor is 1, or one times the normal width-to-height ratio of the text.

function setcharspace(spacing::Real)

function settextcolorind(color::Int)

settextcolorind(color::Int)

Sets the current text color index.

Parameters:

color :

The text color index (COLOR < 1256)

settextcolorind defines the color of subsequent text output primitives. GR uses the default foreground color (black=1) for the default text color index.

function setcharheight(height::Real)

setcharheight(height::Real)

Set the current character height.

Parameters:

height :

Text height value

setcharheight defines the height of subsequent text output primitives. Text height is defined as a percentage of the default window. GR uses the default text height of 0.027 (2.7% of the height of the default window).

function inqcharheight()

function setcharup(ux::Real, uy::Real)

setcharup(ux::Real, uy::Real)

Set the current character text angle up vector.

Parameters:

ux, uy :

Text up vector

setcharup defines the vertical rotation of subsequent text output primitives. The text up vector is initially set to (0, 1), horizontal to the baseline.

function settextpath(path::Int)

settextpath(path::Int)

Define the current direction in which subsequent text will be drawn.

Parameters:

path :

Text path (see table below)

TEXT_PATH_RIGHT

0

left-to-right

TEXT_PATH_LEFT

1

right-to-left

TEXT_PATH_UP

2

downside-up

TEXT_PATH_DOWN

3

upside-down

function settextalign(horizontal::Int, vertical::Int)

settextalign(horizontal::Int, vertical::Int)

Set the current horizontal and vertical alignment for text.

Parameters:

horizontal :

Horizontal text alignment (see the table below)

vertical :

Vertical text alignment (see the table below)

settextalign specifies how the characters in a text primitive will be aligned in horizontal and vertical space. The default text alignment indicates horizontal left alignment and vertical baseline alignment.

TEXT_HALIGN_NORMAL

0

TEXT_HALIGN_LEFT

1

Left justify

TEXT_HALIGN_CENTER

2

Center justify

TEXT_HALIGN_RIGHT

3

Right justify

TEXT_VALIGN_NORMAL

0

TEXT_VALIGN_TOP

1

Align with the top of the characters

TEXT_VALIGN_CAP

2

Aligned with the cap of the characters

TEXT_VALIGN_HALF

3

Aligned with the half line of the characters

TEXT_VALIGN_BASE

4

Aligned with the base line of the characters

TEXT_VALIGN_BOTTOM

5

Aligned with the bottom line of the characters

function setfillintstyle(style::Int)

setfillintstyle(style::Int)

Set the fill area interior style to be used for fill areas.

Parameters:

style :

The style of fill to be used

setfillintstyle defines the interior style for subsequent fill area output primitives. The default interior style is HOLLOW.

HOLLOW

0

No filling. Just draw the bounding polyline

SOLID

1

Fill the interior of the polygon using the fill color index

PATTERN

2

Fill the interior of the polygon using the style index as a pattern index

HATCH

3

Fill the interior of the polygon using the style index as a cross-hatched style

function setfillstyle(index::Int)

setfillstyle(index::Int)

Sets the fill style to be used for subsequent fill areas.

Parameters:

index :

The fill style index to be used

setfillstyle specifies an index when PATTERN fill or HATCH fill is requested by the setfillintstyle function. If the interior style is set to PATTERN, the fill style index points to a device-independent pattern table. If interior style is set to HATCH the fill style index indicates different hatch styles. If HOLLOW or SOLID is specified for the interior style, the fill style index is unused.

function setfillcolorind(color::Int)

setfillcolorind(color::Int)

Sets the current fill area color index.

Parameters:

color :

The fill area color index (COLOR < 1256)

setfillcolorind defines the color of subsequent fill area output primitives. GR uses the default foreground color (black=1) for the default fill area color index.

function setcolorrep(index::Int, red::Real, green::Real, blue::Real)

setcolorrep(index::Int, red::Real, green::Real, blue::Real)

setcolorrep allows to redefine an existing color index representation by specifying an RGB color triplet.

Parameters:

index :

Color index in the range 0 to 1256

red :

Red intensity in the range 0.0 to 1.0

green :

Green intensity in the range 0.0 to 1.0

blue:

Blue intensity in the range 0.0 to 1.0

function setscale(options::Int)

setscale(options::Int)

setscale sets the type of transformation to be used for subsequent GR output primitives.

Parameters:

options :

Scale specification (see Table below)

OPTION_X_LOG

Logarithmic X-axis

OPTION_Y_LOG

Logarithmic Y-axis

OPTION_Z_LOG

Logarithmic Z-axis

OPTION_FLIP_X

Flip X-axis

OPTION_FLIP_Y

Flip Y-axis

OPTION_FLIP_Z

Flip Z-axis

OPTION_X_LOG2

log2 scaled X-axis

OPTION_Y_LOG2

log2 scaled Y-axis

OPTION_Z_LOG2

log2 scaled Z-axis

OPTION_X_LN

ln scaled X-axis

OPTION_Y_LN

ln scaled Y-axis

OPTION_Z_LN

ln scaled Z-axis

setscale defines the current transformation according to the given scale specification which may be or’ed together using any of the above options. GR uses these options for all subsequent output primitives until another value is provided. The scale options are used to transform points from an abstract logarithmic or semi-logarithmic coordinate system, which may be flipped along each axis, into the world coordinate system.

Note: When applying a logarithmic transformation to a specific axis, the system assumes that the axes limits are greater than zero.

function inqscale()

function setwindow(xmin::Real, xmax::Real, ymin::Real, ymax::Real)

setwindow(xmin::Real, xmax::Real, ymin::Real, ymax::Real)

setwindow establishes a window, or rectangular subspace, of world coordinates to be plotted. If you desire log scaling or mirror-imaging of axes, use the SETSCALE function.

Parameters:

xmin :

The left horizontal coordinate of the window (xmin < xmax).

xmax :

The right horizontal coordinate of the window.

ymin :

The bottom vertical coordinate of the window (ymin < ymax).

ymax :

The top vertical coordinate of the window.

setwindow defines the rectangular portion of the World Coordinate space (WC) to be associated with the specified normalization transformation. The WC window and the Normalized Device Coordinates (NDC) viewport define the normalization transformation through which all output primitives are mapped. The WC window is mapped onto the rectangular NDC viewport which is, in turn, mapped onto the display surface of the open and active workstation, in device coordinates. By default, GR uses the range [0,1] x [0,1], in world coordinates, as the normalization transformation window.

function inqwindow()

function setviewport(xmin::Real, xmax::Real, ymin::Real, ymax::Real)

setviewport(xmin::Real, xmax::Real, ymin::Real, ymax::Real)

setviewport establishes a rectangular subspace of normalized device coordinates.

Parameters:

xmin :

The left horizontal coordinate of the viewport.

xmax :

The right horizontal coordinate of the viewport (0 <= xmin < xmax <= 1).

ymin :

The bottom vertical coordinate of the viewport.

ymax :

The top vertical coordinate of the viewport (0 <= ymin < ymax <= 1).

setviewport defines the rectangular portion of the Normalized Device Coordinate (NDC) space to be associated with the specified normalization transformation. The NDC viewport and World Coordinate (WC) window define the normalization transformation through which all output primitives pass. The WC window is mapped onto the rectangular NDC viewport which is, in turn, mapped onto the display surface of the open and active workstation, in device coordinates.

function inqviewport()

function selntran(transform::Int)

selntran(transform::Int)

selntran selects a predefined transformation from world coordinates to normalized device coordinates.

Parameters:

transform :

A normalization transformation number.

0

Selects the identity transformation in which both the window and viewport have the range of 0 to 1

>= 1

Selects a normalization transformation as defined by setwindow and setviewport

function setclip(indicator::Int)

setclip(indicator::Int)

Set the clipping indicator.

Parameters:

indicator :

An indicator specifying whether clipping is on or off.

0

Clipping is off. Data outside of the window will be drawn.

1

Clipping is on. Data outside of the window will not be drawn.

setclip enables or disables clipping of the image drawn in the current window. Clipping is defined as the removal of those portions of the graph that lie outside of the defined viewport. If clipping is on, GR does not draw generated output primitives past the viewport boundaries. If clipping is off, primitives may exceed the viewport boundaries, and they will be drawn to the edge of the workstation window. By default, clipping is on.

function setwswindow(xmin::Real, xmax::Real, ymin::Real, ymax::Real)

setwswindow(xmin::Real, xmax::Real, ymin::Real, ymax::Real)

Set the area of the NDC viewport that is to be drawn in the workstation window.

Parameters:

xmin :

The left horizontal coordinate of the workstation window.

xmax :

The right horizontal coordinate of the workstation window (0 <= xmin < xmax <= 1).

ymin :

The bottom vertical coordinate of the workstation window.

ymax :

The top vertical coordinate of the workstation window (0 <= ymin < ymax <= 1).

setwswindow defines the rectangular area of the Normalized Device Coordinate space to be output to the device. By default, the workstation transformation will map the range [0,1] x [0,1] in NDC onto the largest square on the workstation’s display surface. The aspect ratio of the workstation window is maintained at 1 to 1.

function setwsviewport(xmin::Real, xmax::Real, ymin::Real, ymax::Real)

setwsviewport(xmin::Real, xmax::Real, ymin::Real, ymax::Real)

Define the size of the workstation graphics window in meters.

Parameters:

xmin :

The left horizontal coordinate of the workstation viewport.

xmax :

The right horizontal coordinate of the workstation viewport.

ymin :

The bottom vertical coordinate of the workstation viewport.

ymax :

The top vertical coordinate of the workstation viewport.

setwsviewport places a workstation window on the display of the specified size in meters. This command allows the workstation window to be accurately sized for a display or hardcopy device, and is often useful for sizing graphs for desktop publishing applications.

function createseg(segment::Int)

function copyseg(segment::Int)

function redrawseg()

function setsegtran(segment::Int, fx::Real, fy::Real, transx::Real, transy::Real, phi::Real, scalex::Real, scaley::Real)

function closeseg()

function samplelocator()

function emergencyclosegks()

function updategks()

function setspace(zmin::Real, zmax::Real, rotation::Int, tilt::Int)

setspace(zmin::Real, zmax::Real, rotation::Int, tilt::Int)

Set the abstract Z-space used for mapping three-dimensional output primitives into the current world coordinate space.

Parameters:

zmin :

Minimum value for the Z-axis.

zmax :

Maximum value for the Z-axis.

rotation :

Angle for the rotation of the X axis, in degrees.

tilt :

Viewing angle of the Z axis in degrees.

setspace establishes the limits of an abstract Z-axis and defines the angles for rotation and for the viewing angle (tilt) of a simulated three-dimensional graph, used for mapping corresponding output primitives into the current window. These settings are used for all subsequent three-dimensional output primitives until other values are specified. Angles of rotation and viewing angle must be specified between 0° and 90°.

function textext(x::Real, y::Real, string)

textext(x::Real, y::Real, string)

Draw a text at position x, y using the current text attributes. Strings can be defined to create basic mathematical expressions and Greek letters.

Parameters:

x :

The X coordinate of starting position of the text string

y :

The Y coordinate of starting position of the text string

string :

The text to be drawn

The values for X and Y are in normalized device coordinates. The attributes that control the appearance of text are text font and precision, character expansion factor, character spacing, text color index, character height, character up vector, text path and text alignment.

The character string is interpreted to be a simple mathematical formula. The following notations apply:

Subscripts and superscripts: These are indicated by carets (‘^’) and underscores (‘_’). If the sub/superscript contains more than one character, it must be enclosed in curly braces (‘{}’).

Fractions are typeset with A ‘/’ B, where A stands for the numerator and B for the denominator.

To include a Greek letter you must specify the corresponding keyword after a backslash (‘’) character. The text translator produces uppercase or lowercase Greek letters depending on the case of the keyword.

Letter

Keyword

Α α

alpha

Β β

beta

Γ γ

gamma

Δ δ

delta

Ε ε

epsilon

Ζ ζ

zeta

Η η

eta

Θ θ

theta

Ι ι

iota

Κ κ

kappa

Λ λ

lambda

Μ μ

mu

Ν ν

nu

Ξ ξ

xi

Ο ο

omicron

Π π

pi

Ρ ρ

rho

Σ σ

sigma

Τ τ

tau

Υ υ

upsilon

Φ φ

phi

Χ χ

chi

Ψ ψ

psi

Ω ω

omega

For more sophisticated mathematical formulas, you should use the gr.mathtex function.

function inqtextext(x::Real, y::Real, string)

function axes2d(x_tick::Real, y_tick::Real, x_org::Real, y_org::Real, major_x::Int, major_y::Int, tick_size::Real)

axes2d(x_tick::Real, y_tick::Real, x_org::Real, y_org::Real, major_x::Int, major_y::Int, tick_size::Real)

Draw X and Y coordinate axes with linearly and/or logarithmically spaced tick marks.

Parameters:

x_tick, y_tick :

The interval between minor tick marks on each axis.

x_org, y_org :

The world coordinates of the origin (point of intersection) of the X and Y axes.

major_x, major_y :

Unitless integer values specifying the number of minor tick intervals between major tick marks. Values of 0 or 1 imply no minor ticks. Negative values specify no labels will be drawn for the associated axis.

tick_size :

The length of minor tick marks specified in a normalized device coordinate unit. Major tick marks are twice as long as minor tick marks. A negative value reverses the tick marks on the axes from inward facing to outward facing (or vice versa).

Tick marks are positioned along each axis so that major tick marks fall on the axes origin (whether visible or not). Major tick marks are labeled with the corresponding data values. Axes are drawn according to the scale of the window. Axes and tick marks are drawn using solid lines; line color and width can be modified using the setlinetype and setlinewidth functions. Axes are drawn according to the linear or logarithmic transformation established by the setscale function.

function axes(x_tick::Real, y_tick::Real, x_org::Real, y_org::Real, major_x::Int, major_y::Int, tick_size::Real)

function axeslbl(x_tick::Real, y_tick::Real, x_org::Real, y_org::Real, major_x::Int, major_y::Int, tick_size::Real, fx::Function, fy::Function)

function axeslbl(x_tick::Real, y_tick::Real, x_org::Real, y_org::Real, major_x::Int, major_y::Int, tick_size::Real, fpx::Function, fpy::Function)

Draw X and Y coordinate axes with linearly and/or logarithmically spaced tick marks.

Tick marks are positioned along each axis so that major tick marks fall on the axes origin (whether visible or not). Major tick marks are labeled with the corresponding data values. Axes are drawn according to the scale of the window. Axes and tick marks are drawn using solid lines; line color and width can be modified using the setlinetype and setlinewidth functions. Axes are drawn according to the linear or logarithmic transformation established by the setscale function.

Parameters:

x_tick, y_tick :

The interval between minor tick marks on each axis.

x_org, y_org :

The world coordinates of the origin (point of intersection) of the X and Y axes.

major_x, major_y :

Unitless integer values specifying the number of minor tick intervals between major tick marks. Values of 0 or 1 imply no minor ticks. Negative values specify no labels will be drawn for the associated axis.

tick_size :

The length of minor tick marks specified in a normalized device coordinate unit. Major tick marks are twice as long as minor tick marks. A negative value reverses the tick marks on the axes from inward facing to outward facing (or vice versa).

fx, fy :

Functions that returns a label for a given tick on the X or Y axis. Those functions should have the following arguments:

x, y :

Normalized device coordinates of the label in X and Y directions.

svalue :

Internal string representation of the text drawn at (x,y).

value :

Floating point representation of the label drawn at (x,y).

function grid(x_tick::Real, y_tick::Real, x_org::Real, y_org::Real, major_x::Int, major_y::Int)

grid(x_tick::Real, y_tick::Real, x_org::Real, y_org::Real, major_x::Int, major_y::Int)

Draw a linear and/or logarithmic grid.

Parameters:

x_tick, y_tick :

The length in world coordinates of the interval between minor grid lines.

x_org, y_org :

The world coordinates of the origin (point of intersection) of the grid.

major_x, major_y :

Unitless integer values specifying the number of minor grid lines between major grid lines. Values of 0 or 1 imply no grid lines.

Major grid lines correspond to the axes origin and major tick marks whether visible or not. Minor grid lines are drawn at points equal to minor tick marks. Major grid lines are drawn using black lines and minor grid lines are drawn using gray lines.

function grid3d(x_tick::Real, y_tick::Real, z_tick::Real, x_org::Real, y_org::Real, z_org::Real, major_x::Int, major_y::Int, major_z::Int)

function verrorbars(px, py, e1, e2)

verrorbars(px, py, e1, e2)

Draw a standard vertical error bar graph.

Parameters:

px :

A list of length N containing the X coordinates

py :

A list of length N containing the Y coordinates

e1 :

The absolute values of the lower error bar data

e2 :

The absolute values of the upper error bar data

function herrorbars(px, py, e1, e2)

herrorbars(px, py, e1, e2)

Draw a standard horizontal error bar graph.

Parameters:

px :

A list of length N containing the X coordinates

py :

A list of length N containing the Y coordinates

e1 :

The absolute values of the lower error bar data

e2 :

The absolute values of the upper error bar data

function polyline3d(px, py, pz)

polyline3d(px, py, pz)

Draw a 3D curve using the current line attributes, starting from the first data point and ending at the last data point.

Parameters:

x :

A list of length N containing the X coordinates

y :

A list of length N containing the Y coordinates

z :

A list of length N containing the Z coordinates

The values for x, y and z are in world coordinates. The attributes that control the appearance of a polyline are linetype, linewidth and color index.

function polymarker3d(px, py, pz)

polymarker3d(px, py, pz)

Draw marker symbols centered at the given 3D data points.

Parameters:

x :

A list of length N containing the X coordinates

y :

A list of length N containing the Y coordinates

z :

A list of length N containing the Z coordinates

The values for x, y and z are in world coordinates. The attributes that control the appearance of a polymarker are marker type, marker size scale factor and color index.

function axes3d(x_tick::Real, y_tick::Real, z_tick::Real, x_org::Real, y_org::Real, z_org::Real, major_x::Int, major_y::Int, major_z::Int, tick_size::Real)

function settitles3d(x_title, y_title, z_title)

settitles3d(x_title, y_title, z_title)

Set axis titles to be displayed in subsequent axes calls.

Parameters:

x_title, y_title, z_title :

The text to be displayed on each axis

function titles3d(x_title, y_title, z_title)

titles3d(x_title, y_title, z_title)

Display axis titles just outside of their respective axes.

Parameters:

x_title, y_title, z_title :

The text to be displayed on each axis

function surface(px, py, pz, option::Int)

surface(px, py, pz, option::Int)

Draw a three-dimensional surface plot for the given data points.

Parameters:

x :

A list containing the X coordinates

y :

A list containing the Y coordinates

z :

A list of length len(x) * len(y) or an appropriately dimensioned array containing the Z coordinates

option :

Surface display option (see table below)

x and y define a grid. z is a singly dimensioned array containing at least nx * ny data points. Z describes the surface height at each point on the grid. Data is ordered as shown in the following table:

LINES

0

Use X Y polylines to denote the surface

MESH

1

Use a wire grid to denote the surface

FILLED_MESH

2

Applies an opaque grid to the surface

Z_SHADED_MESH

3

Applies Z-value shading to the surface

COLORED_MESH

4

Applies a colored grid to the surface

CELL_ARRAY

5

Applies a grid of individually-colored cells to the surface

SHADED_MESH

6

Applies light source shading to the 3-D surface

function contour(px, py, h, pz, major_h::Int)

contour(px, py, h, pz, major_h::Int)

Draw contours of a three-dimensional data set whose values are specified over a rectangular mesh. Contour lines may optionally be labeled.

Parameters:

x :

A list containing the X coordinates

y :

A list containing the Y coordinates

h :

A list containing the Z coordinate for the height values

z :

A list of length len(x) * len(y) or an appropriately dimensioned array containing the Z coordinates

major_h :

Directs GR to label contour lines. For example, a value of 3 would label every third line. A value of 1 will label every line. A value of 0 produces no labels. To produce colored contour lines, add an offset of 1000 to major_h.

function contourf(px, py, h, pz, major_h::Int)

contourf(px, py, h, pz, major_h::Int)

Draw filled contours of a three-dimensional data set whose values are specified over a rectangular mesh.

Parameters:

x :

A list containing the X coordinates

y :

A list containing the Y coordinates

h :

A list containing the Z coordinate for the height values

z :

A list of length len(x) * len(y) or an appropriately dimensioned array containing the Z coordinates

major_h :

(intended for future use)

function hexbin(x, y, nbins)

function setcolormap(index::Int)

function colorbar()

function inqcolor(color::Int)

function inqcolorfromrgb(red::Real, green::Real, blue::Real)

function hsvtorgb(h::Real, s::Real, v::Real)

function tick(amin::Real, amax::Real)

function validaterange(amin::Real, amax::Real)

function adjustlimits(amin::Real, amax::Real)

function adjustrange(amin::Real, amax::Real)

function beginprint(pathname)

beginprint(pathname)

Open and activate a print device.

Parameters:

pathname :

Filename for the print device.

beginprint opens an additional graphics output device. The device type is obtained from the given file extension. The following file types are supported:

.ps, .eps

PostScript

.pdf

Portable Document Format

.bmp

Windows Bitmap (BMP)

.jpeg, .jpg

JPEG image file

.png

Portable Network Graphics file (PNG)

.tiff, .tif

Tagged Image File Format (TIFF)

.fig

Xfig vector graphics file

.svg

Scalable Vector Graphics

.wmf

Windows Metafile

function beginprintext(pathname, mode, fmt, orientation)

beginprintext(pathname, mode, fmt, orientation)

Open and activate a print device with the given layout attributes.

Parameters:

pathname :

Filename for the print device.

mode :

Output mode (Color, GrayScale)

fmt :

Output format (see table below)

orientation :

Page orientation (Landscape, Portait)

The available formats are:

A4

0.210 x 0.297

B5

0.176 x 0.250

Letter

0.216 x 0.279

Legal

0.216 x 0.356

Executive

0.191 x 0.254

A0

0.841 x 1.189

A1

0.594 x 0.841

A2

0.420 x 0.594

A3

0.297 x 0.420

A5

0.148 x 0.210

A6

0.105 x 0.148

A7

0.074 x 0.105

A8

0.052 x 0.074

A9

0.037 x 0.052

B0

1.000 x 1.414

B1

0.500 x 0.707

B10

0.031 x 0.044

B2

0.500 x 0.707

B3

0.353 x 0.500

B4

0.250 x 0.353

B6

0.125 x 0.176

B7

0.088 x 0.125

B8

0.062 x 0.088

B9

0.044 x 0.062

C5E

0.163 x 0.229

Comm10E

0.105 x 0.241

DLE

0.110 x 0.220

Folio

0.210 x 0.330

Ledger

0.432 x 0.279

Tabloid

0.279 x 0.432

function endprint()

function ndctowc(x::Real, y::Real)

function wctondc(x::Real, y::Real)

function wc3towc(x::Real, y::Real, z::Real)

function drawrect(xmin::Real, xmax::Real, ymin::Real, ymax::Real)

drawrect(xmin::Real, xmax::Real, ymin::Real, ymax::Real)

Draw a rectangle using the current line attributes.

Parameters:

xmin :

Lower left edge of the rectangle

xmax :

Lower right edge of the rectangle

ymin :

Upper left edge of the rectangle

ymax :

Upper right edge of the rectangle

function fillrect(xmin::Real, xmax::Real, ymin::Real, ymax::Real)

fillrect(xmin::Real, xmax::Real, ymin::Real, ymax::Real)

Draw a filled rectangle using the current fill attributes.

Parameters:

xmin :

Lower left edge of the rectangle

xmax :

Lower right edge of the rectangle

ymin :

Upper left edge of the rectangle

ymax :

Upper right edge of the rectangle

function drawarc(xmin::Real, xmax::Real, ymin::Real, ymax::Real, a1::Real, a2::Real)

drawarc(xmin::Real, xmax::Real, ymin::Real, ymax::Real, a1::Real, a2::Real)

Draw a circular or elliptical arc covering the specified rectangle.

Parameters:

xmin :

Lower left edge of the rectangle

xmax :

Lower right edge of the rectangle

ymin :

Upper left edge of the rectangle

ymax :

Upper right edge of the rectangle

a1 :

The start angle

a2 :

The end angle

The resulting arc begins at a1 and ends at a2 degrees. Angles are interpreted such that 0 degrees is at the 3 o’clock position. The center of the arc is the center of the given rectangle.

function fillarc(xmin::Real, xmax::Real, ymin::Real, ymax::Real, a1::Real, a2::Real)

fillarc(xmin::Real, xmax::Real, ymin::Real, ymax::Real, a1::Real, a2::Real)

Fill a circular or elliptical arc covering the specified rectangle.

Parameters:

xmin :

Lower left edge of the rectangle

xmax :

Lower right edge of the rectangle

ymin :

Upper left edge of the rectangle

ymax :

Upper right edge of the rectangle

a1 :

The start angle

a2 :

The end angle

The resulting arc begins at a1 and ends at a2 degrees. Angles are interpreted such that 0 degrees is at the 3 o’clock position. The center of the arc is the center of the given rectangle.

function drawpath(points, codes, fill::Int)

drawpath(points, codes, fill::Int)

Draw simple and compound outlines consisting of line segments and bezier curves.

Parameters:

points :

(N, 2) array of (x, y) vertices

codes :

N-length array of path codes

fill :

A flag indication whether resulting path is to be filled or not

The following path codes are recognized:

STOP

end the entire path

MOVETO

move to the given vertex

LINETO

draw a line from the current position to the given vertex

CURVE3

draw a quadratic Bézier curve

CURVE4

draw a cubic Bézier curve

CLOSEPOLY

draw a line segment to the start point of the current path

function setarrowstyle(style::Int)

setarrowstyle(style::Int)

Set the arrow style to be used for subsequent arrow commands.

Parameters:

style :

The arrow style to be used

setarrowstyle defines the arrow style for subsequent arrow primitives. The default arrow style is 1.

1

simple, single-ended

2

simple, single-ended, acute head

3

hollow, single-ended

4

filled, single-ended

5

triangle, single-ended

6

filled triangle, single-ended

7

kite, single-ended

8

filled kite, single-ended

9

simple, double-ended

10

simple, double-ended, acute head

11

hollow, double-ended

12

filled, double-ended

13

triangle, double-ended

14

filled triangle, double-ended

15

kite, double-ended

16

filled kite, double-ended

17

double line, single-ended

18

double line, double-ended

function setarrowsize(size::Real)

setarrowsize(size::Real)

Set the arrow size to be used for subsequent arrow commands.

Parameters:

size :

The arrow size to be used

setarrowsize defines the arrow size for subsequent arrow primitives. The default arrow size is 1.

function drawarrow(x1::Real, y1::Real, x2::Real, y2::Real)

drawarrow(x1::Real, y1::Real, x2::Real, y2::Real)

Draw an arrow between two points.

Parameters:

x1, y1 :

Starting point of the arrow (tail)

x2, y2 :

Head of the arrow

Different arrow styles (angles between arrow tail and wing, optionally filled heads, double headed arrows) are available and can be set with the setarrowstyle function.

function readimage(path)

function drawimage(xmin::Real, xmax::Real, ymin::Real, ymax::Real, width::Int, height::Int, data, model::Int = 0)

drawimage(xmin::Real, xmax::Real, ymin::Real, ymax::Real, width::Int, height::Int, data, model::Int = 0)

Draw an image into a given rectangular area.

Parameters:

xmin, ymin :

First corner point of the rectangle

xmax, ymax :

Second corner point of the rectangle

width, height :

The width and the height of the image

data :

An array of color values dimensioned width by height

model :

Color model (default=0)

The available color models are:

MODEL_RGB

0

AABBGGRR

MODEL_HSV

1

AAVVSSHH

The points (xminx, ymin) and (xmax, ymax) are world coordinates defining diagonally opposite corner points of a rectangle. This rectangle is divided into width by height cells. The two-dimensional array data specifies colors for each cell.

function importgraphics(path)

function setshadow(offsetx::Real, offsety::Real, blur::Real)

setshadow(offsetx::Real, offsety::Real, blur::Real)

setshadow allows drawing of shadows, realized by images painted underneath, and offset from, graphics objects such that the shadow mimics the effect of a light source cast on the graphics objects.

Parameters:

offsetx :

An x-offset, which specifies how far in the horizontal direction the shadow is offset from the object

offsety :

A y-offset, which specifies how far in the vertical direction the shadow is offset from the object

blur :

A blur value, which specifies whether the object has a hard or a diffuse edge

function settransparency(alpha::Real)

settransparency(alpha::Real)

Set the value of the alpha component associated with GR colors.

Parameters:

alpha :

An alpha value (0.0 - 1.0)

function setcoordxform(mat)

setcoordxform(mat)

Change the coordinate transformation according to the given matrix.

Parameters:

mat[3][2] :

2D transformation matrix

function begingraphics(path)

begingraphics(path)

Open a file for graphics output.

Parameters:

path :

Filename for the graphics file.

begingraphics allows to write all graphics output into a XML-formatted file until the endgraphics functions is called. The resulting file may later be imported with the importgraphics function.

function endgraphics()

function getgraphics()

function drawgraphics(string)

function startlistener()

function mathtex(x::Real, y::Real, string)

mathtex(x::Real, y::Real, string)

Generate a character string starting at the given location. Strings can be defined to create mathematical symbols and Greek letters using LaTeX syntax.

Parameters:

x, y :

Position of the text string specified in world coordinates

string :

The text string to be drawn

function inqmathtex(x, y, string)

type SVG

type PNG

type HTML

function show(io::IO, ::#= none:3666 =# @MIME_str "image/svg+xml", x::SVG)

function show(io::IO, ::#= none:3667 =# @MIME_str "image/png", x::PNG)

function show(io::IO, ::#= none:3668 =# @MIME_str "text/html", x::HTML)

type c_tick_t

type c_tick_label_t

type GRTick

type GRTickLabel

function _readfile(path)

function isinline()

function displayname()

function inline(mime = "svg", scroll = true)

function reset()

function show()

function setregenflags(flags = 0)

function inqregenflags()

function savestate()

function restorestate()

function selectcontext(context::Int)

function destroycontext(context::Int)

function uselinespec(linespec)

function delaunay(x, y)

function interp2(X, Y, Z, Xq, Yq, method::Int = 0, extrapval = 0)

function trisurface(x, y, z)

trisurface(x, y, z)

Draw a triangular surface plot for the given data points.

Parameters:

x :

A list containing the X coordinates

y :

A list containing the Y coordinates

z :

A list containing the Z coordinates

function tricontour(x, y, z, levels)

tricontour(x, y, z, levels)

Draw a contour plot for the given triangle mesh.

Parameters:

x :

A list containing the X coordinates

y :

A list containing the Y coordinates

z :

A list containing the Z coordinates

levels :

A list containing the contour levels

function gradient(x, y, z)

function quiver(x, y, u, v, color::Bool = false)

function reducepoints(xd, yd, n)

function version()

function check_for_updates()

function openmeta(target = 0, device = "localhost", port = 8002)

function sendmeta(handle, string::AbstractString)

function sendmetaref(handle, key::AbstractString, fmt::Char, data, len = -1)

function recvmeta(handle, args = C_NULL)

function plotmeta(args)

function deletemeta(args)

function closemeta(handle)

function shadepoints(x, y; dims = [1200, 1200], xform = 1)

function shadelines(x, y; dims = [1200, 1200], xform = 1)

function setcolormapfromrgb(r, g, b; positions = Nothing)

function panzoom(x, y, zoom)

function setborderwidth(width::Real)

setborderwidth(width::Real)

Define the border width of subsequent path output primitives.

Parameters:

width :

The border width scale factor

function setbordercolorind(color::Int)

setbordercolorind(color::Int)

Define the color of subsequent path output primitives.

Parameters:

color :

The border color index (COLOR < 1256)

function setprojectiontype(type::Int)

function setperspectiveprojection(near_plane::Real, far_plane::Real, fov::Real)

function setorthographicprojection(left::Real, right::Real, bottom::Real, top::Real, near_plane::Real, far_plane::Real)

function settransformationparameters(camera_pos_x::Real, camera_pos_y::Real, camera_pos_z::Real, up_x::Real, up_y::Real, up_z::Real, focus_point_x::Real, focus_point_y::Real, focus_point_z::Real)

function setresamplemethod(method::UInt32)

function setwindow3d(xmin::Real, xmax::Real, ymin::Real, ymax::Real, zmin::Real, zmax::Real)

function setspace3d(rot::Real, tilt::Real, fov::Real, dist::Real)

function text3d(x::Real, y::Real, z::Real, string, axis::Int)

function inqtext3d(x::Real, y::Real, z::Real, string, axis::Int)

function settextencoding(encoding)

function inqtextencoding()

function loadfont(name::String)

function inqvpsize()

function setpicturesizeforvolume(width::Int, height::Int)

function inqtransformationparameters()

function polygonmesh3d(px, py, pz, connections, colors)

function setscientificformat(format_option)

function setresizebehaviour(flag)

function inqprojectiontype()

function beginselection(index, type)

function endselection()

function moveselection(x, y)

function setmathfont(font::Int)

function inqmathfont()

function setclipregion(region::Int)

function inqclipregion()

function axis(which::Char; min::Real = NaN, max::Real = NaN, tick::Real = NaN, org::Real = NaN, position::Real = NaN, major_count::Int = 1, ticks::Union{Vector{GRTick}, Nothing} = nothing, tick_size::Real = NaN, tick_labels::Union{Vector{GRTickLabel}, Nothing} = nothing, label_position::Real = NaN, draw_axis_line::Int = 1)

function to_c_axis(axis::GRAxis)

function drawaxis(which::Char, axis::GRAxis)

function drawaxes(x_axis::Union{GRAxis, Nothing}, y_axis::Union{GRAxis, Nothing}, options::Int = (AXES_SIMPLE_AXES | AXES_TWIN_AXES) | AXES_WITH_GRID)