28 releases (17 breaking)

0.18.0 Sep 26, 2024
0.17.0 Jul 3, 2024
0.16.1 May 12, 2024
0.14.0 Mar 26, 2024
0.1.3 Mar 24, 2022

#39 in GUI

Download history 3525/week @ 2024-07-31 5271/week @ 2024-08-07 4717/week @ 2024-08-14 3125/week @ 2024-08-21 3929/week @ 2024-08-28 3413/week @ 2024-09-04 2786/week @ 2024-09-11 2259/week @ 2024-09-18 3744/week @ 2024-09-25 4962/week @ 2024-10-02 5119/week @ 2024-10-09 4776/week @ 2024-10-16 3676/week @ 2024-10-23 4970/week @ 2024-10-30 5210/week @ 2024-11-06 5911/week @ 2024-11-13

20,407 downloads per month
Used in 29 crates (7 directly)

MIT/Apache

84KB
1.5K SLoC

A commonmark viewer for egui

Crate Documentation

showcase

While this crate's main focus is commonmark, it also supports a subset of Github's markdown syntax: tables, strikethrough, tasklists and footnotes.

Usage

In Cargo.toml:

egui_commonmark = "0.18"
# Specify what image formats you want to use
image = { version = "0.25", default-features = false, features = ["png"] }
use egui_commonmark::*;
let markdown =
r"# Hello world

* A list
* [ ] Checkbox
";

let mut cache = CommonMarkCache::default();
CommonMarkViewer::new().show(ui, &mut cache, markdown);

Compile time evaluation of markdown

If you want to embed markdown directly the binary then you can enable the macros feature. This will do the parsing of the markdown at compile time and output egui widgets.

Example

use egui_commonmark::{CommonMarkCache, commonmark};
let mut cache = CommonMarkCache::default();
let _response = commonmark!(ui, &mut cache, "# ATX Heading Level 1");

Alternatively you can embed a file

Example

use egui_commonmark::{CommonMarkCache, commonmark_str};
let mut cache = CommonMarkCache::default();
commonmark_str!(ui, &mut cache, "content.md");

Features

  • macros: macros for compile time parsing of markdown
  • better_syntax_highlighting: Syntax highlighting inside code blocks with syntect
  • svg: Support for viewing svg images
  • fetch: Images with urls will be downloaded and displayed

Examples

For an easy intro check out the hello_world example. To see all the different features egui_commonmark has to offer check out the book example.

License

Licensed under either of

at your option.

Dependencies

~5–16MB
~220K SLoC