David Austin, Grand Valley State University
Alexei Kolesnikov, Towson University
Tactile Reading and Graphics Conference
June 3, 2025
Slides at gvsu.edu/s/3cD
PreFigure is an authoring system for creating accessible mathematical diagrams. PreFigure is to figures what PreTeXt is to text.
Open source and freely available.
Write once, read everywhere. From the same source, PreFigure creates
annotated SVG for HTML,
PDF for print,
tactile graphics for embossing,
more ….
Key | Action |
---|---|
Enter, A | Activate keyboard driven exploration |
B | Activate menu driven exploration |
Escape | Leave exploration mode |
Cursor down | Explore next lower level |
Cursor up | Explore next upper level |
Cursor right | Explore next element on level |
Cursor left | Explore previous element on level |
X | Toggle expert mode |
W | Extra details if available |
Space | Repeat speech |
M | Activate step magnification |
Comma | Activate direct magnification |
N | Deactivate magnification |
Z | Toggle subtitles |
C | Cycle contrast settings |
T | Monochrome colours |
L | Toggle language (if available) |
K | Kill current sound |
Y | Stop sound output |
O | Start and stop sonification |
P | Repeat sonification output |
Foreground components have a clear outline.
MathJax produces mathematics in Nemeth Braille.
Labels are rendered in the Braille29 font to facilitate embossing.
<diagram dimensions="(300,300)" margins="5">
<definition>a=1</definition>
<definition>f(x)=exp(x/3)*cos(x)</definition>
<coordinates bbox="[-4,-4,4,4]">
<grid-axes xlabel="x" ylabel="y"/>
<graph function="f"/>
<tangent-line function="f" point="a"/>
<point p="(a, f(a))">
<m>(a,f(a))</m>
</point>
</coordinates>
</diagram>
PreFigure playground, thanks to Jason Siefken, gvsu.edu/s/35f.
PreFigure codespace, gvsu.edu/s/35e
Install locally from instructions at prefigure.org
PreFigure documentation: prefigure.org
In the Playground, (gvsu.edu/s/35f) modify the original diagram:
Change the aspect ratio with dimensions="(300,200)"
Change the bounding box with bbox="(-1,-2,4,5)"
Change the function f
or the point a
where the tangent line is drawn.
Add another function and include stroke="green"
.
Add another point with a label.
Recreate one of the tactile samples.
Explore samples in the Examples
link.
Funding for this work was provided by the National Science Foundation, DUE IUSE #2334767, 2334768, 2334769. Any opinions, findings, and conclusions or recommendations expressed in this material are those of the author(s) and do not necessarily reflect the views of the National Science Foundation.