module Graphics.Rendering.Chart.Plot.FillBetween(
PlotFillBetween(..),
defaultPlotFillBetween,
plot_fillbetween_title,
plot_fillbetween_style,
plot_fillbetween_values,
) where
import Control.Lens
import Graphics.Rendering.Chart.Geometry
import Graphics.Rendering.Chart.Drawing
import Graphics.Rendering.Chart.Renderable
import Graphics.Rendering.Chart.Plot.Types
import Data.Colour (opaque)
import Data.Colour.Names (black, blue)
import Data.Colour.SRGB (sRGB)
import Data.Default.Class
data PlotFillBetween x y = PlotFillBetween {
_plot_fillbetween_title :: String,
_plot_fillbetween_style :: FillStyle,
_plot_fillbetween_values :: [ (x, (y,y))]
}
instance ToPlot PlotFillBetween where
toPlot p = Plot {
_plot_render = renderPlotFillBetween p,
_plot_legend = [(_plot_fillbetween_title p,renderPlotLegendFill p)],
_plot_all_points = plotAllPointsFillBetween p
}
renderPlotFillBetween :: PlotFillBetween x y -> PointMapFn x y -> ChartBackend ()
renderPlotFillBetween p pmap =
renderPlotFillBetween' p (_plot_fillbetween_values p) pmap
renderPlotFillBetween' p [] _ = return ()
renderPlotFillBetween' p vs pmap =
withFillStyle (_plot_fillbetween_style p) $ do
ps <- alignFillPoints $ [p0] ++ p1s ++ reverse p2s ++ [p0]
fillPointPath ps
where
pmap' = mapXY pmap
(p0:p1s) = map pmap' [ (x,y1) | (x,(y1,y2)) <- vs ]
p2s = map pmap' [ (x,y2) | (x,(y1,y2)) <- vs ]
renderPlotLegendFill :: PlotFillBetween x y -> Rect -> ChartBackend ()
renderPlotLegendFill p r =
withFillStyle (_plot_fillbetween_style p) $ do
fillPath (rectPath r)
plotAllPointsFillBetween :: PlotFillBetween x y -> ([x],[y])
plotAllPointsFillBetween p = ( [ x | (x,(_,_)) <- pts ]
, concat [ [y1,y2] | (_,(y1,y2)) <- pts ] )
where
pts = _plot_fillbetween_values p
defaultPlotFillBetween :: PlotFillBetween x y
defaultPlotFillBetween = def
instance Default (PlotFillBetween x y) where
def = PlotFillBetween
{ _plot_fillbetween_title = ""
, _plot_fillbetween_style = solidFillStyle (opaque $ sRGB 0.5 0.5 1.0)
, _plot_fillbetween_values = []
}
$( makeLenses ''PlotFillBetween )