Source code for plotnine.scales.scale_linetype
from warnings import warn
from ..doctools import document
from ..exceptions import PlotnineError, PlotnineWarning
from ..utils import alias
from .scale import scale_continuous, scale_discrete
LINETYPES = ["solid", "dashed", "dashdot", "dotted"]
[docs]
@document
class scale_linetype(scale_discrete):
"""
Scale for line patterns
Parameters
----------
{superclass_parameters}
Notes
-----
The available linetypes are
``'solid', 'dashed', 'dashdot', 'dotted'``
If you need more custom linetypes, use
:class:`~plotnine.scales.scale_linetype_manual`
"""
_aesthetics = ["linetype"]
def __init__(self, **kwargs):
from mizani.palettes import manual_pal
self.palette = manual_pal(LINETYPES)
super().__init__(**kwargs)
@document
class scale_linetype_ordinal(scale_linetype):
"""
Scale for line patterns
Parameters
----------
{superclass_parameters}
"""
_aesthetics = ["linetype"]
def __init__(self, **kwargs):
warn(
"Using linetype for an ordinal variable is not advised.",
PlotnineWarning,
)
super().__init__(**kwargs)
class scale_linetype_continuous(scale_continuous):
"""
Linetype scale
"""
def __init__(self):
raise PlotnineError(
"A continuous variable can not be mapped to linetype"
)
alias("scale_linetype_discrete", scale_linetype)