matplotlib.lines.Line2D#
- classmatplotlib.lines.Line2D(xdata,ydata,*,linewidth=None,linestyle=None,color=None,gapcolor=None,marker=None,markersize=None,markeredgewidth=None,markeredgecolor=None,markerfacecolor=None,markerfacecoloralt='none',fillstyle=None,antialiased=None,dash_capstyle=None,solid_capstyle=None,dash_joinstyle=None,solid_joinstyle=None,pickradius=5,drawstyle=None,markevery=None,**kwargs)[source]#
Bases:
Artist
A line - the line can have both a solid linestyle connecting allthe vertices, and a marker at each vertex. Additionally, thedrawing of the solid line is influenced by the drawstyle, e.g., onecan create "stepped" lines in various styles.
Create a
Line2D
instance withx andy data in sequences ofxdata,ydata.Additional keyword arguments are
Line2D
properties:Property
Description
a filter function, which takes a (m, n, 3) float array and a dpi value, and returns a (m, n, 3) array and two offsets from the bottom left corner of the image
float or None
bool
bool
BboxBase
or Nonebool
Patch or (Path, Transform) or None
CapStyle
or {'butt', 'projecting', 'round'}JoinStyle
or {'miter', 'round', 'bevel'}sequence of floats (on/off ink in points) or (None, None)
(2, N) array or two 1D arrays
{'default', 'steps', 'steps-pre', 'steps-mid', 'steps-post'}, default: 'default'
{'full', 'left', 'right', 'bottom', 'top', 'none'}
color or None
str
bool
object
{'-', '--', '-.', ':', '', (offset, on-off-seq), ...}
float
marker style string,
Path
orMarkerStyle
float
markersize
orms
float
None or int or (int, int) or slice or list[int] or float or (float, float) or list[bool]
bool
list of
AbstractPathEffect
float or callable[[Artist, Event], tuple[bool, dict]]
float
bool
(scale: float, length: float, randomness: float)
bool or None
CapStyle
or {'butt', 'projecting', 'round'}JoinStyle
or {'miter', 'round', 'bevel'}unknown
str
bool
1D array
1D array
float
See
set_linestyle()
for a description of the line styles,set_marker()
for a description of the markers, andset_drawstyle()
for a description of the draw styles.- contains(mouseevent)[source]#
Test whethermouseevent occurred on the line.
An event is deemed to have occurred "on" the line if it is lessthan
self.pickradius
(default: 5 points) away from it. Useget_pickradius
orset_pickradius
to get or setthe pick radius.- Parameters:
- mouseevent
MouseEvent
- mouseevent
- Returns:
- containsbool
Whether any values are within the radius.
- detailsdict
A dictionary
{'ind':pointlist}
, wherepointlist is alist of points of the line that are within the pickradius aroundthe event position.TODO: sort returned indices by distance
- draw(renderer)[source]#
Draw the Artist (and its children) using the given renderer.
This has no effect if the artist is not visible (
Artist.get_visible
returns False).- Parameters:
- renderer
RendererBase
subclass.
- renderer
Notes
This method is overridden in the Artist subclasses.
- drawStyleKeys=['default','steps-mid','steps-pre','steps-post','steps']#
- drawStyles={'default':'_draw_lines','steps':'_draw_steps_pre','steps-mid':'_draw_steps_mid','steps-post':'_draw_steps_post','steps-pre':'_draw_steps_pre'}#
- fillStyles=('full','left','right','bottom','top','none')#
- filled_markers=('.','o','v','^','<','>','8','s','p','*','h','H','D','d','P','X')#
- get_aa()[source]#
Alias for
get_antialiased
.
- get_dash_capstyle()[source]#
Return the
CapStyle
for dashed lines.See also
set_dash_capstyle
.
- get_dash_joinstyle()[source]#
Return the
JoinStyle
for dashed lines.See also
set_dash_joinstyle
.
- get_data(orig=True)[source]#
Return the line data as an
(xdata,ydata)
pair.Iforig isTrue, return the original data.
- get_drawstyle()[source]#
Return the drawstyle.
See also
set_drawstyle
.
- get_ds()[source]#
Alias for
get_drawstyle
.
- get_fillstyle()[source]#
Return the marker fill style.
See also
set_fillstyle
.
- get_gapcolor()[source]#
Return the line gapcolor.
See also
set_gapcolor
.
- get_linestyle()[source]#
Return the linestyle.
See also
set_linestyle
.
- get_linewidth()[source]#
Return the linewidth in points.
See also
set_linewidth
.
- get_ls()[source]#
Alias for
get_linestyle
.
- get_lw()[source]#
Alias for
get_linewidth
.
- get_marker()[source]#
Return the line marker.
See also
set_marker
.
- get_markeredgecolor()[source]#
Return the marker edge color.
See also
set_markeredgecolor
.
- get_markeredgewidth()[source]#
Return the marker edge width in points.
See also
set_markeredgewidth
.
- get_markerfacecolor()[source]#
Return the marker face color.
See also
set_markerfacecolor
.
- get_markerfacecoloralt()[source]#
Return the alternate marker face color.
See also
set_markerfacecoloralt
.
- get_markersize()[source]#
Return the marker size in points.
See also
set_markersize
.
- get_markevery()[source]#
Return the markevery setting for marker subsampling.
See also
set_markevery
.
- get_mec()[source]#
Alias for
get_markeredgecolor
.
- get_mew()[source]#
Alias for
get_markeredgewidth
.
- get_mfc()[source]#
Alias for
get_markerfacecolor
.
- get_mfcalt()[source]#
Alias for
get_markerfacecoloralt
.
- get_ms()[source]#
Alias for
get_markersize
.
- get_pickradius()[source]#
Return the pick radius used for containment tests.
See
contains
for more details.
- get_solid_capstyle()[source]#
Return the
CapStyle
for solid lines.See also
set_solid_capstyle
.
- get_solid_joinstyle()[source]#
Return the
JoinStyle
for solid lines.See also
set_solid_joinstyle
.
- get_window_extent(renderer=None)[source]#
Get the artist's bounding box in display space.
The bounding box's width and height are non-negative.
Subclasses should override for inclusion in the bounding box"tight" calculation. Default is to return an empty boundingbox at 0, 0.
Warning
The extent can change due to any changes in the transform stack, suchas changing the Axes limits, the figure size, the canvas used (as isdone when saving a figure), or the DPI.
Relying on a once-retrieved window extent can lead to unexpectedbehavior in various cases such as interactive figures being resized ormoved to a screen with different dpi, or figures that look fine onscreen render incorrectly when saved to file.
To get accurate results you may need to manually call
matplotlib.figure.Figure.savefig
ormatplotlib.figure.Figure.draw_without_rendering
to have Matplotlibcompute the rendered size.
- get_xdata(orig=True)[source]#
Return the xdata.
Iforig isTrue, return the original data, else theprocessed data.
- get_ydata(orig=True)[source]#
Return the ydata.
Iforig isTrue, return the original data, else theprocessed data.
- is_dashed()[source]#
Return whether line has a dashed linestyle.
A custom linestyle is assumed to be dashed, we do not inspect the
onoffseq
directly.See also
set_linestyle
.
- lineStyles={'':'_draw_nothing','':'_draw_nothing','-':'_draw_solid','--':'_draw_dashed','-.':'_draw_dash_dot',':':'_draw_dotted','None':'_draw_nothing'}#
- markers={'':'nothing','':'nothing','*':'star','+':'plus',',':'pixel','.':'point','1':'tri_down','2':'tri_up','3':'tri_left','4':'tri_right','8':'octagon','<':'triangle_left','>':'triangle_right','D':'diamond','H':'hexagon2','None':'nothing','P':'plus_filled','X':'x_filled','^':'triangle_up','_':'hline','d':'thin_diamond','h':'hexagon1','none':'nothing','o':'circle','p':'pentagon','s':'square','v':'triangle_down','x':'x','|':'vline',0:'tickleft',1:'tickright',10:'caretupbase',11:'caretdownbase',2:'tickup',3:'tickdown',4:'caretleft',5:'caretright',6:'caretup',7:'caretdown',8:'caretleftbase',9:'caretrightbase'}#
- set(*,agg_filter=<UNSET>,alpha=<UNSET>,animated=<UNSET>,antialiased=<UNSET>,clip_box=<UNSET>,clip_on=<UNSET>,clip_path=<UNSET>,color=<UNSET>,dash_capstyle=<UNSET>,dash_joinstyle=<UNSET>,dashes=<UNSET>,data=<UNSET>,drawstyle=<UNSET>,fillstyle=<UNSET>,gapcolor=<UNSET>,gid=<UNSET>,in_layout=<UNSET>,label=<UNSET>,linestyle=<UNSET>,linewidth=<UNSET>,marker=<UNSET>,markeredgecolor=<UNSET>,markeredgewidth=<UNSET>,markerfacecolor=<UNSET>,markerfacecoloralt=<UNSET>,markersize=<UNSET>,markevery=<UNSET>,mouseover=<UNSET>,path_effects=<UNSET>,picker=<UNSET>,pickradius=<UNSET>,rasterized=<UNSET>,sketch_params=<UNSET>,snap=<UNSET>,solid_capstyle=<UNSET>,solid_joinstyle=<UNSET>,transform=<UNSET>,url=<UNSET>,visible=<UNSET>,xdata=<UNSET>,ydata=<UNSET>,zorder=<UNSET>)[source]#
Set multiple properties at once.
Supported properties are
Property
Description
a filter function, which takes a (m, n, 3) float array and a dpi value, and returns a (m, n, 3) array and two offsets from the bottom left corner of the image
float or None
bool
bool
BboxBase
or Nonebool
Patch or (Path, Transform) or None
CapStyle
or {'butt', 'projecting', 'round'}JoinStyle
or {'miter', 'round', 'bevel'}sequence of floats (on/off ink in points) or (None, None)
(2, N) array or two 1D arrays
{'default', 'steps', 'steps-pre', 'steps-mid', 'steps-post'}, default: 'default'
{'full', 'left', 'right', 'bottom', 'top', 'none'}
color or None
str
bool
object
{'-', '--', '-.', ':', '', (offset, on-off-seq), ...}
float
marker style string,
Path
orMarkerStyle
float
float
None or int or (int, int) or slice or list[int] or float or (float, float) or list[bool]
bool
list of
AbstractPathEffect
float or callable[[Artist, Event], tuple[bool, dict]]
float
bool
(scale: float, length: float, randomness: float)
bool or None
CapStyle
or {'butt', 'projecting', 'round'}JoinStyle
or {'miter', 'round', 'bevel'}unknown
str
bool
1D array
1D array
float
- set_aa(b)[source]#
Alias for
set_antialiased
.
- set_dash_capstyle(s)[source]#
How to draw the end caps if the line is
is_dashed
.The default capstyle is
rcParams["lines.dash_capstyle"]
(default:<CapStyle.butt:'butt'>
).- Parameters:
- s
CapStyle
or {'butt', 'projecting', 'round'}
- s
- set_dash_joinstyle(s)[source]#
How to join segments of the line if it
is_dashed
.The default joinstyle is
rcParams["lines.dash_joinstyle"]
(default:<JoinStyle.round:'round'>
).- Parameters:
- s
JoinStyle
or {'miter', 'round', 'bevel'}
- s
- set_dashes(seq)[source]#
Set the dash sequence.
The dash sequence is a sequence of floats of even length describingthe length of dashes and spaces in points.
For example, (5, 2, 1, 2) describes a sequence of 5 point and 1 pointdashes separated by 2 point spaces.
See also
set_gapcolor
, which allows those spaces to befilled with a color.- Parameters:
- seqsequence of floats (on/off ink in points) or (None, None)
Ifseq is empty or
(None,None)
, the linestyle will be setto solid.
- set_drawstyle(drawstyle)[source]#
Set the drawstyle of the plot.
The drawstyle determines how the points are connected.
- Parameters:
- drawstyle{'default', 'steps', 'steps-pre', 'steps-mid', 'steps-post'}, default: 'default'
For 'default', the points are connected with straight lines.
The steps variants connect the points with step-like lines,i.e. horizontal lines with vertical steps. They differ in thelocation of the step:
'steps-pre': The step is at the beginning of the line segment,i.e. the line will be at the y-value of point to the right.
'steps-mid': The step is halfway between the points.
'steps-post: The step is at the end of the line segment,i.e. the line will be at the y-value of the point to the left.
'steps' is equal to 'steps-pre' and is maintained forbackward-compatibility.
For examples seeStep Demo.
- set_ds(drawstyle)[source]#
Alias for
set_drawstyle
.
- set_fillstyle(fs)[source]#
Set the marker fill style.
- Parameters:
- fs{'full', 'left', 'right', 'bottom', 'top', 'none'}
Possible values:
'full': Fill the whole marker with themarkerfacecolor.
'left', 'right', 'bottom', 'top': Fill the marker half atthe given side with themarkerfacecolor. The otherhalf of the marker is filled withmarkerfacecoloralt.
'none': No filling.
For examples seeMarker fill styles.
- set_gapcolor(gapcolor)[source]#
Set a color to fill the gaps in the dashed line style.
Note
Striped lines are created by drawing two interleaved dashed lines.There can be overlaps between those two, which may result inartifacts when using transparency.
This functionality is experimental and may change.
- Parameters:
- gapcolorcolor or None
The color with which to fill the gaps. If None, the gaps areunfilled.
- set_linestyle(ls)[source]#
Set the linestyle of the line.
- Parameters:
- ls{'-', '--', '-.', ':', '', (offset, on-off-seq), ...}
Possible values:
A string:
linestyle
description
'-'
or'solid'
solid line
'--'
or'dashed'
dashed line
'-.'
or'dashdot'
dash-dotted line
':'
or'dotted'
dotted line
''
or'none'
(discouraged:'None'
,''
)draw nothing
Alternatively a dash tuple of the following form can beprovided:
(offset,onoffseq)
where
onoffseq
is an even length tuple of on and off inkin points. See alsoset_dashes()
.
For examples seeLinestyles.
- set_ls(ls)[source]#
Alias for
set_linestyle
.
- set_lw(w)[source]#
Alias for
set_linewidth
.
- set_marker(marker)[source]#
Set the line marker.
- Parameters:
- markermarker style string,
Path
orMarkerStyle
See
markers
for full description of possiblearguments.
- markermarker style string,
- set_markeredgewidth(ew)[source]#
Set the marker edge width in points.
- Parameters:
- ewfloat
Marker edge width, in points.
- set_markevery(every)[source]#
Set the markevery property to subsample the plot when using markers.
e.g., if
every=5
, every 5-th marker will be plotted.- Parameters:
- everyNone or int or (int, int) or slice or list[int] or float or (float, float) or list[bool]
Which markers to plot.
every=None
: every point will be plotted.every=N
: every N-th marker will be plotted starting withmarker 0.every=(start,N)
: every N-th marker, starting at indexstart, will be plotted.every=slice(start,end,N)
: every N-th marker, starting atindexstart, up to but not including indexend, will beplotted.every=[i,j,m,...]
: only markers at the given indiceswill be plotted.every=[True,False,True,...]
: only positions that are Truewill be plotted. The list must have the same length as the datapoints.every=0.1
, (i.e. a float): markers will be spaced atapproximately equal visual distances along the line; the distancealong the line between markers is determined by multiplying thedisplay-coordinate distance of the Axes bounding-box diagonalby the value ofevery.every=(0.5,0.1)
(i.e. a length-2 tuple of float): similartoevery=0.1
but the first marker will be offset along theline by 0.5 multiplied by thedisplay-coordinate-diagonal-distance along the line.
For examples seeMarkevery Demo.
Notes
Settingmarkevery will still only draw markers at actual data points.While the float argument form aims for uniform visual spacing, it hasto coerce from the ideal spacing to the nearest available data point.Depending on the number and distribution of data points, the resultmay still not look evenly spaced.
When using a start offset to specify the first marker, the offset willbe from the first data point which may be different from the firstthe visible data point if the plot is zoomed in.
If zooming in on a plot when using float arguments then the actualdata points that have markers will change because the distance betweenmarkers is always determined from the display-coordinatesaxes-bounding-box-diagonal regardless of the actual axes data limits.
- set_mec(ec)[source]#
Alias for
set_markeredgecolor
.
- set_mew(ew)[source]#
Alias for
set_markeredgewidth
.
- set_mfc(fc)[source]#
Alias for
set_markerfacecolor
.
- set_mfcalt(fc)[source]#
Alias for
set_markerfacecoloralt
.
- set_ms(sz)[source]#
Alias for
set_markersize
.
- set_picker(p)[source]#
Set the event picker details for the line.
- Parameters:
- pfloat or callable[[Artist, Event], tuple[bool, dict]]
If a float, it is used as the pick radius in points.
- set_pickradius(pickradius)[source]#
Set the pick radius used for containment tests.
See
contains
for more details.- Parameters:
- pickradiusfloat
Pick radius, in points.
- set_solid_capstyle(s)[source]#
How to draw the end caps if the line is solid (not
is_dashed
)The default capstyle is
rcParams["lines.solid_capstyle"]
(default:<CapStyle.projecting:'projecting'>
).- Parameters:
- s
CapStyle
or {'butt', 'projecting', 'round'}
- s
- set_solid_joinstyle(s)[source]#
How to join segments if the line is solid (not
is_dashed
).The default joinstyle is
rcParams["lines.solid_joinstyle"]
(default:<JoinStyle.round:'round'>
).- Parameters:
- s
JoinStyle
or {'miter', 'round', 'bevel'}
- s
- zorder=2#
Examples usingmatplotlib.lines.Line2D
#

SkewT-logP diagram: using transforms and custom projections