djot
djot copied to clipboard
Figures
We need a general way of producing a figure with a caption and label.
Pandoc's "implicit figures" are too limiting. Figures can include multiple images, and also non-image content like code.
Do you mean supporting a feature where you can write something like, "see figure 4", and that will render as a link to an image (as in data:image/s3,"s3://crabby-images/24a6f/24a6f8f106ba690f7b7fa1f49f73d61771177167" alt="figure 4"
?
No, this is about creating the figure itself: an environment that may contain one or more images, or perhaps other things, plus a caption and a label that can be the target of references.
Would the current way to get something similar to this be to add the figure as an image, like this:
data:image/s3,"s3://crabby-images/24a6f/24a6f8f106ba690f7b7fa1f49f73d61771177167" alt="figure 4"{#fig-4}
and then link to it with "[see figure 4](#fig-4)
"?
In pandoc's markdown that will produce a figure (implicit_figures
extension), but we haven't implemented that here. I think I'd prefer to have something more explicit for generating figures.
What about
!!!label
data:image/s3,"s3://crabby-images/ebcd0/ebcd054102dd3179af9844d804af4926073465f1" alt="alt text"
data:image/s3,"s3://crabby-images/acb59/acb5939259c1101805460762ea51753a7cd62ca9" alt="other alt text"
:: Short caption on one line
Long caption which may have multiple lines/paragraphs.
!!!
And if you need a grid you simply use table structure (pipe or list).
Ok, I understand. Thanks.
I wonder if there's a way to re-use the div syntax for this, like
::: figure
foo ...
:::
Similar to the list tables idea https://github.com/jgm/djot/issues/27 .
Actually, if I were "delimiter-shopping" for a punctuation character to use for figures, it would be hard to beat &
--- I mean, it looks just like a figure that a figure skater might make. Stealing @bpj 's example:
&&& label
data:image/s3,"s3://crabby-images/ebcd0/ebcd054102dd3179af9844d804af4926073465f1" alt="alt text"
data:image/s3,"s3://crabby-images/acb59/acb5939259c1101805460762ea51753a7cd62ca9" alt="other alt text"
Short caption on one line
Long caption which may have multiple
lines/paragraphs.
&&&
The point of using the exclamation point is that it is already used to differentiate inline images from links.
Yeah, I see that, though I don't think the !!!
looks good.
If ---
is free, this looks good:
--- figure 4
data:image/s3,"s3://crabby-images/ebcd0/ebcd054102dd3179af9844d804af4926073465f1" alt="alt text"
data:image/s3,"s3://crabby-images/acb59/acb5939259c1101805460762ea51753a7cd62ca9" alt="other alt text"
Short caption on one line
Long caption which may have multiple
lines/paragraphs.
---
I don't know how you could enhance that to support figures containing subfigures, as in "figure 4(a), 4(b), etc." Maybe using a definition list inside the figure block, e.g.:
--- figure 4
: figure 4(a)
data:image/s3,"s3://crabby-images/66769/667696a3a1aaea76ffea8dde5ad16f4bb3296900" alt="alt text"
Short caption for fig 4(a), on one line
Long caption which may have multiple
lines/paragraphs.
: figure 4(b)
data:image/s3,"s3://crabby-images/315f3/315f3b2dd37ca228a5cf4ed7901fed78108044f1" alt="alt text"
Short caption for fig 4(b), on one line
Long caption which may have multiple
lines/paragraphs.
---
Whatever solution is considered for figures and subfigures, captions should probably be generalized with a consistent syntax across blocks where they are appropriate:
- Tables (we do have the
^
caption syntax currently...) - Code blocks (-> captioned listings)
- Figures (-> captioned blocks of images or whatnots)
- Quotes (-> captioned quotes)
- Others?
See also #28
FWIW: Given how flexible Djot’s syntax already is, it may not be necessary to introduce new syntax – e.g.:
[Figure](#fig:diagram){!float} visualizes how everything is connected.
{!float for="Figure" #fig:diagram}
:::
data:image/s3,"s3://crabby-images/f8d88/f8d881b917b081b49feeba2c90d3b90920c9b5c3" alt=""{width="277.164" height="176.5"}
---
Visual explanation.
:::
[Table](#tbl:summary){!float} contains a summary.
{!float for="Table" #tbl:summary}
:::
| Output | Vector | Bitmap |
|--------|--------|--------|
| HTML | `.svg` | `.jpg` |
| LaTeX | `.pdf` | `.jpg` |
---
Brief summary.
:::
Notes:
-
!float
is a command (which I use in my Markdown dialect), it could also be the class.float
. Commands work much like classes but have a separate namespace and don’t produce output – unless there is a plugin/filter.