commonMain.org.jetbrains.letsPlot.gggrid.kt Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of lets-plot-kotlin-kernel Show documentation
Show all versions of lets-plot-kotlin-kernel Show documentation
Lets-Plot Kotlin API without dependencies.
/*
* Copyright (c) 2021. JetBrains s.r.o.
* Use of this source code is governed by the MIT license that can be found in the LICENSE file.
*/
package org.jetbrains.letsPlot
import org.jetbrains.letsPlot.core.spec.Option.SubPlots
import org.jetbrains.letsPlot.core.spec.Option.SubPlots.Grid.Scales.SHARE_ALL
import org.jetbrains.letsPlot.core.spec.Option.SubPlots.Grid.Scales.SHARE_NONE
import org.jetbrains.letsPlot.intern.OptionsMap
import org.jetbrains.letsPlot.intern.figure.SubPlotsFigure
import org.jetbrains.letsPlot.intern.figure.SubPlotsLayoutSpec
import org.jetbrains.letsPlot.intern.filterNonNullValues
/**
* Combines several plots on one figure, organized in a regular grid.
*
* ## Examples
*
* - [plot_grid.ipynb](https://nbviewer.jupyter.org/github/JetBrains/lets-plot-kotlin/blob/master/docs/examples/jupyter-notebooks/f-4.3.0/plot_grid.ipynb)
* - [gggrid_scale_share.ipynb](https://nbviewer.org/github/JetBrains/lets-plot-kotlin/blob/master/docs/examples/jupyter-notebooks/f-4.6.0/gggrid_scale_share.ipynb).
*
* @param plots Collection of plots.
* Use Null-value to fill-in empty cells in grid.
* @param ncol Number of columns in grid.
* If not specified, shows plots horizontally, in one row.
* @param widths Relative width of each column of grid, left to right.
* @param heights Relative height of each row of grid, top-down.
* @param hspace default = 4. Cell horizontal spacing in px.
* @param vspace default = 4. Cell vertical spacing in px.
* @param fit default = true.
* Whether to stretch each plot to match the aspect ratio of its cell (`fit = true`),
* or to preserve the original aspect ratio of plots (`fit = false`).
* @param align default = false.
* If `true`, align inner areas (i.e. "geom" bounds) of plots.
* However, cells containing other (sub)grids are not participating in the plot "inner areas" layouting.
* @param sharex String or Boolean
* Controls sharing of X-axis limits between subplots in the grid.
* - 'all'/True - share limits between all subplots.
* - 'none'/False - do not share limits between subplots.
* - 'row' - share limits between subplots in the same row.
* - 'col' - share limits between subplots in the same column.
* @param sharey String or Boolean
* Controls sharing of Y-axis limits between subplots in the grid.
* - 'all'/True - share limits between all subplots.
* - 'none'/False - do not share limits between subplots.
* - 'row' - share limits between subplots in the same row.
* - 'col' - share limits between subplots in the same column.
*
* @return SubPlotsFigure object.
*/
@Suppress("SpellCheckingInspection")
fun gggrid(
plots: Iterable