Skip to contents

ggalign (development version)

Breaking changes

  • Now, all *_free() layouts have been removed, all layout has been splitted into two type: align discrete or continous vairables.

New features

  • new helper function memo_order() to reorder the oncoplot samples.

  • new geom_subrect() and geom_subtile() to subdivide rectangles with shared borders into a grid.

  • new cross_link function to reset the layout ordering index or layout panel group, and add plot to connect selected observations.

  • new cross_mark function to reset the layout ordering index or layout panel group, and add plot to annotate observations.

  • new pair_links() function to create pairs of observation groups.

  • new mark_draw(), mark_line(), mark_tetragon() to define the links to connect the marked observations.

  • new link_draw(), link_line(), link_tetragon() to define the links to connect a pair of observations

  • new ggmark() to add a plot to annotate selected observations.

  • new element_vec() functions to apply function to the vectorized fields of the theme element object.

  • new no_expansion() function to remove scale expansion.

  • new layout circle_layout() to arrange plot in a circular.

  • new raster_magick() function to post-processing the image raster with magick package was added.

  • new fortify_matrix.GISTIC() method for GISTIC object from maftools package (#24).

  • + operator now will respect with_quad().

  • new ggalign_attr_set() and ggalign_attr_get() for basic operations of attached attribute.

  • new geom_draw() function to draw ggplot2 layer with customized draw function.

Bug fixes

Improvements

  • Now, with_quad() wraps the object into a list with the class with_quad. This approach offers greater flexibility in defining the actions associated with with_quad, allowing for more customizable behavior (#26, @Yunuuuu).

  • Now, panel will be reordered when initializing the layout parameters, we don’t need to reorder the panel when drawing.

  • free_gg, align and the new cross_link objects have been collapsed to one class ggalign_plot

ggalign 0.0.5

CRAN release: 2024-11-14

Breaking changes

  • direction argument in stack_layout()/ggstack() is soft-deprecated now, user must provide it manually.

  • set_context, order, and name arguments in align_*() and ggheatmap() are soft-deprecated, which is advised to use active argument.

  • guides, free_guides, free_spaces, free_labs, and plot_data arguments in align_*() and ggheatmap() are deprecated, which is advised to use scheme_align function instead.

  • theme argument in align_*() and ggheatmap() is deprecated, which is advised to use plot_theme function.

  • what argument in stack_active() is soft-deprecated, user is advised to use stack_switch() to change the active plot with what.

  • align_panel()/ggpanel() is deprecated, user is advised to use ggalign(data = NULL) instead.

New features

Bug fixes

  • fix bug when apply free_border in alignpatches object.

  • fix bug when provide a function in distance argument of align_dendro()

  • fix bug when provide hclust or dendrogram in method argument of align_dendro()

  • fix bug of coord_ggalign() for discrete scale

Improvements

  • merge function has been implemented with vctrs for performance

  • for large matrix (> 20000 cells), automatically use geom_raster()

  • {data.table} is now removed from the dependency

ggalign 0.0.4

CRAN release: 2024-10-12

  • layout_heatmap()/ggheatmap() arguments width/height have been renamed .width/.height to helps avoid conflicts with arguments from geom_tile().

  • the nestet alignpatches theme by default will inherit from the parent alignpatches

  • new layout_title() function, now layout_annotation() only control the layout theme

  • add ggrastr::rasterize method for both ggheatmap() and ggstack()

  • set_context argument in align_dendro() now depends on plot_dendrogram by default

  • align_dendro() gain a new argument reorder_dendrogram to control whether to reorder the generated dendrogram based on the mean values.

  • align_reorder() now splitted into two function align_order() and align_reorder()

  • dendrogram_data() gain a new argument reorder_branches to control whether to reorder the input leaf_braches based on the tree.

  • align_dendro() gain new argument merge_dendrogram to control whether the dendrograms in multiple groups should be merged

  • dendrogram height axis will be automatically reversed in bottom and left annotation stack

  • heatmap fill color scale now default use scale_fill_gradient2(low = "blue", high = "red") for continuous values.

  • Coord is used to set limits instead of Scale

  • all free_* arguments now accept the same argument of the corresponding free_* functions.

  • new theme_ggalign() function for the default theme of ggalign package

  • export option ggalign.default_theme allow user to change the global default theme

  • new free_guide() function, to override the layout guides argument for single plot

  • geom_draw() now utilize patch() function to convert objects into grob

  • internal changes: all vectors have been operated with vctrs package

  • stack_layout(): gain sizes argument to control the relative sizes of the stack

  • align_()*: now order argument only control the plot area.

  • align_reorder() now can accept an ordering character names.

  • export order2() function

  • align_reorder(): fun argument has been renamed to order argument, and it can now accept the ordering integer index directly

  • fun in align_reorder() now can return any statistics which can be handled by order2()

  • fix ggheatmap() order not work when put in a stack layout

  • method in hclust2() can now return any objects which can be coerced into hclust, or you can provide such object directly in method.

  • hclust2() now can accept distance = NULL

  • hmanno(), stack_active(), and align_*() functions gain a new argument theme to control the theme for the plot.

  • new layout_annotation() and layout_theme() to modify the layout components

  • borders argument in free_space() has been renamed to spaces

  • {tibble} is now removed from the dependency

  • align_plots() now can accept gList, function, recordedplot, trellis, pheatmap, Heatmap, HeatmapAnnotation, and HeatmapList, we have added alignpatch method for these objects.

  • add patch method for gList, function, recordedplot, trellis, pheatmap, Heatmap, HeatmapAnnotation, and HeatmapList

  • fix a bug in wrap() function where duplicated names in gtable cause some grobs missing

  • new free_vp() function to customize the viewport when aligning.

  • StackLayout and HeatmapLayout methods have been collapsed into one method for Layout class

  • New Patch class, now we can extend the alignment process of any object and customize the building process with ggproto.

  • fix missing variable labs in the free_space method of PatchAlignpatches

ggalign 0.0.3

CRAN release: 2024-09-15

  • Add package logo

  • new inset() function

  • add package quotes in DESCRIPTION

  • add return value docs for exported function or methods

ggalign 0.0.2

  • omit the redudnant description and add single quote for package name

ggalign 0.0.1

Features

ggalign pacakge provides two layout to arrange ggplot objects:

  • heatmap_layout()/ggheatmap(): Arrange ggplot into a Heatmap layout. See vignette("heatmap-layout") for details.

  • stack_layout()/ggstack(): Arrange ggplot vertically or horizontally. See vignette("stack-layout") for details.

To further customize these layouts, we offer following functions:

  • align_group(): Group layout axis into panel with a group variable.
  • align_kmeans(): Group layout axis into panel by kmeans
  • align_reorder(): Reorders layout observations based on weights or summary statistics.
  • align_dendro(): Reorder or Group layout based on hierarchical clustering

For more detailed instructions on customizing layouts, see the vignette: vignette("layout-customize").

Additionally, plots can be added in the layout with following functions:

For more information on adding plots, refer to the vignette: vignette("layout-plot").