module Graphics.Rendering.Chart.Plot.FillBetween(
PlotFillBetween(..),
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.Plot.Types
import Data.Colour (opaque)
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 -> BackendProgram ()
renderPlotFillBetween p =
renderPlotFillBetween' p (_plot_fillbetween_values p)
renderPlotFillBetween' ::
PlotFillBetween x y
-> [(a, (b, b))]
-> ((Limit a, Limit b) -> Point)
-> BackendProgram ()
renderPlotFillBetween' _ [] _ = 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,_)) <- vs ]
p2s = map pmap' [ (x,y2) | (x,(_,y2)) <- vs ]
renderPlotLegendFill :: PlotFillBetween x y -> Rect -> BackendProgram ()
renderPlotLegendFill p r =
withFillStyle (_plot_fillbetween_style p) $
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
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 )