This is an example of how to create an interactive genomic visualization using the shiny.gosling package within a Shiny app. It leverages the shiny package for creating the user interface and interactivity.
We create a Shiny app that visualizes genomic data using the shiny.gosling package. It generates an interactive visualization with tracks displaying DNA base counts and annotations, allowing users to explore genomic data related to the SARS-CoV-2 virus.
Below, we use the track_data() function to fetch data from the specified URL. The data represents base counts for the SARS-CoV-2 virus genome, organized into rows and columns. It includes attributes like base, position, count, and categories (A, T, G, C).
“Multivec” is a term used in genomics to refer to a specific type of data format used for representing and visualizing multi-dimensional numerical data across genomic coordinates. It’s commonly used for representing data like ChIP-seq, ATAC-seq, Hi-C, and other genomic experiments where signals or measurements are collected at various genomic positions.
Multivec data is essentially a matrix where rows correspond to different genomic positions or regions, and columns correspond to different samples or experiments. Each entry in the matrix represents a value associated with a specific genomic position and sample. The genomic positions along the rows of the matrix are usually represented as chromosomal coordinates (chromosome name and base pair position). This allows the data to be aligned with the genome, enabling accurate visualization and analysis. There are different tools and file formats that support multivec data, allowing researchers to work with and visualize this type of data. The bigWig and bedGraph formats are commonly used for representing multivec data. Visualization tools and libraries like the UCSC Genome Browser, IGV (Integrative Genomics Viewer), and libraries like “shiny.gosling” can render multivec data visualizations.
Here are some resources and links where you can learn more about multivec data and how it’s used in genomics research:
UCSC Genome Browser:
The UCSC Genome Browser is a widely used tool for visualizing genomic data, including multivec data. Tutorial on visualizing multivec data in the UCSC Genome Browser
IGV (Integrative Genomics Viewer):
IGV is another popular genome visualization tool that supports multivec data. Tutorial on loading and visualizing multivec data in IGV
BedGraph and BigWig Formats:
These are common file formats used for representing multivec data. Explanation of the BedGraph format Explanation of the BigWig format
Here, we define two tracks (track1 and track2) that will be displayed in the visualization. track1 displays the count of DNA bases using a bar mark, and track2 displays text annotations for certain conditions.
track1 <- add_single_track(
  mark = "bar",
  y = visual_channel_y(
    field = "count", type = "quantitative", axis = "none"
  )
)
track2 <- add_single_track(
  dataTransform = track_data_transform(
    type = "filter",
    field = "count",
    oneOf = list(0),
    not = TRUE
  ),
  mark = "text",
  x = visual_channel_x(
    field = "start", type = "genomic"
  ),
  xe = visual_channel_x(
    field = "end", type = "genomic"
  ),
  size = 24,
  color = "white",
  visibility = list(list(
    operation = "less-than",
    measure = "width",
    threshold = "|xe-x|",
    transitionPadding = 30,
    target = "mark"
  ),
  list(
    operation = "LT",
    measure = "zoomLevel",
    threshold = 40,
    target = "track"
  ))
)Now, lets define visual channels for track1. track1_x specifies the genomic position on the x-axis, track1_color assigns colors based on DNA bases, and track1_text specifies text annotations based on DNA bases.
track1_x <- visual_channel_x(
  field = "position", type = "genomic"
)
track1_color <- visual_channel_color(
  field = "base",
  type = "nominal",
  domain = c("A", "T", "G", "C"),
  legend = TRUE
)
track1_text <- visual_channel_text(
  field = "base", type = "nominal"
)
track1_style <- default_track_styles(
  inlineLegend = TRUE
)This code chunk combines the previously defined tracks (track1 and track2) into a single track (track3) and specifies various properties such as title, alignment, data, visual channels, and style.
Lets create a view (view1) that contains the combined track (track3). It specifies properties like multi-view mode, x-axis domain, alignment, and linking.
Next, we arrange views using the arrange_views function. It sets the title, subtitle, assembly information, layout, spacing, and includes the previously defined view1.
Finally, we define the Shiny user interface (UI) using the fluidPage function. It includes the goslingOutput function to create a placeholder for the visualization. We also define the Shiny server logic. It uses the renderGosling function to render the interactive visualization using the combined_view defined earlier.
ui <- fluidPage(
  use_gosling(),
  fluidRow(
    column(6, goslingOutput("gosling_plot"))
  )
)
server <- function(input, output, session) {
  output$gosling_plot <- renderGosling({
    gosling(
      component_id = "sars_cov2",
      combined_view
    )
  })
}
shinyApp(ui, server)
sessionInfo()
#> R version 4.5.0 Patched (2025-04-21 r88169)
#> Platform: aarch64-apple-darwin20
#> Running under: macOS Ventura 13.7.1
#> 
#> Matrix products: default
#> BLAS:   /Library/Frameworks/R.framework/Versions/4.5-arm64/Resources/lib/libRblas.0.dylib 
#> LAPACK: /Library/Frameworks/R.framework/Versions/4.5-arm64/Resources/lib/libRlapack.dylib;  LAPACK version 3.12.1
#> 
#> locale:
#> [1] C/en_US.UTF-8/en_US.UTF-8/C/en_US.UTF-8/en_US.UTF-8
#> 
#> time zone: America/New_York
#> tzcode source: internal
#> 
#> attached base packages:
#> [1] stats4    stats     graphics  grDevices utils     datasets  methods  
#> [8] base     
#> 
#> other attached packages:
#>  [1] sessioninfo_1.2.3                  ggbio_1.57.0                      
#>  [3] ggplot2_3.5.2                      StructuralVariantAnnotation_1.25.0
#>  [5] VariantAnnotation_1.55.0           Rsamtools_2.25.0                  
#>  [7] Biostrings_2.77.0                  XVector_0.49.0                    
#>  [9] SummarizedExperiment_1.39.0        Biobase_2.69.0                    
#> [11] MatrixGenerics_1.21.0              matrixStats_1.5.0                 
#> [13] rtracklayer_1.69.0                 GenomicRanges_1.61.0              
#> [15] GenomeInfoDb_1.45.0                IRanges_2.43.0                    
#> [17] S4Vectors_0.47.0                   BiocGenerics_0.55.0               
#> [19] generics_0.1.3                     shiny_1.10.0                      
#> [21] shiny.gosling_1.5.0               
#> 
#> loaded via a namespace (and not attached):
#>   [1] RColorBrewer_1.1-3       rstudioapi_0.17.1        jsonlite_2.0.0          
#>   [4] magrittr_2.0.3           GenomicFeatures_1.61.0   farver_2.1.2            
#>   [7] rmarkdown_2.29           fs_1.6.6                 BiocIO_1.19.0           
#>  [10] vctrs_0.6.5              memoise_2.0.1            RCurl_1.98-1.17         
#>  [13] base64enc_0.1-3          htmltools_0.5.8.1        S4Arrays_1.9.0          
#>  [16] progress_1.2.3           curl_6.2.2               SparseArray_1.9.0       
#>  [19] Formula_1.2-5            sass_0.4.10              bslib_0.9.0             
#>  [22] fontawesome_0.5.3        htmlwidgets_1.6.4        httr2_1.1.2             
#>  [25] plyr_1.8.9               cachem_1.1.0             GenomicAlignments_1.45.0
#>  [28] shiny.react_0.4.0        mime_0.13                lifecycle_1.0.4         
#>  [31] pkgconfig_2.0.3          Matrix_1.7-3             R6_2.6.1                
#>  [34] fastmap_1.2.0            GenomeInfoDbData_1.2.14  digest_0.6.37           
#>  [37] colorspace_2.1-1         GGally_2.2.1             AnnotationDbi_1.71.0    
#>  [40] OrganismDbi_1.51.0       Hmisc_5.2-3              RSQLite_2.3.9           
#>  [43] filelock_1.0.3           httr_1.4.7               abind_1.4-8             
#>  [46] compiler_4.5.0           bit64_4.6.0-1            withr_3.0.2             
#>  [49] htmlTable_2.4.3          backports_1.5.0          BiocParallel_1.43.0     
#>  [52] DBI_1.2.3                ggstats_0.9.0            biomaRt_2.65.0          
#>  [55] rappdirs_0.3.3           DelayedArray_0.35.1      rjson_0.2.23            
#>  [58] tools_4.5.0              foreign_0.8-90           httpuv_1.6.16           
#>  [61] nnet_7.3-20              glue_1.8.0               restfulr_0.0.15         
#>  [64] promises_1.3.2           grid_4.5.0               checkmate_2.3.2         
#>  [67] cluster_2.1.8.1          reshape2_1.4.4           gtable_0.3.6            
#>  [70] BSgenome_1.77.0          tidyr_1.3.1              ensembldb_2.33.0        
#>  [73] hms_1.1.3                data.table_1.17.0        xml2_1.3.8              
#>  [76] pillar_1.10.2            stringr_1.5.1            later_1.4.2             
#>  [79] dplyr_1.1.4              BiocFileCache_2.99.0     lattice_0.22-7          
#>  [82] bit_4.6.0                biovizBase_1.57.0        RBGL_1.85.0             
#>  [85] tidyselect_1.2.1         knitr_1.50               gridExtra_2.3           
#>  [88] ProtGenerics_1.41.0      xfun_0.52                stringi_1.8.7           
#>  [91] UCSC.utils_1.5.0         lazyeval_0.2.2           yaml_2.3.10             
#>  [94] evaluate_1.0.3           codetools_0.2-20         tibble_3.2.1            
#>  [97] graph_1.87.0             BiocManager_1.30.25      cli_3.6.5               
#> [100] rpart_4.1.24             xtable_1.8-4             jquerylib_0.1.4         
#> [103] dichromat_2.0-0.1        Rcpp_1.0.14              dbplyr_2.5.0            
#> [106] png_0.1-8                XML_3.99-0.18            parallel_4.5.0          
#> [109] assertthat_0.2.1         blob_1.2.4               prettyunits_1.2.0       
#> [112] AnnotationFilter_1.33.0  bitops_1.0-9             pwalign_1.5.0           
#> [115] txdbmaker_1.5.0          scales_1.4.0             purrr_1.0.4             
#> [118] crayon_1.5.3             rlang_1.1.6              KEGGREST_1.49.0