Show HN: TikZ Editor – WYSIWYG editor for figures in LaTeX
174 points
2 hours ago
| 18 comments
| tikz.dev
| HN
Hi all! TikZ is a widely-used LaTeX package for drawing figures in papers. It uses commands like \draw[->] (0,0) -- (1,2); to draw lines, shapes, text, etc. Academics usually code up their figures by hand, so there is lots of twiddling around with the coordinates and recompiling until things look nice. I guess it’s a bit like SVG, but it’s more code than markup, for example it has loops with \foreach.

I built an open-source WYSIWYG TikZ editor (available for web and desktop) that allows you to edit your TikZ source code visually by dragging and resizing elements. It simultaneously shows the source code and the rendered figure, and lets you edit either one while the two views stay in sync. I’m not aware of any other editors that are simultaneously source editors and WYSIWYG (even for editing SVG or HTML), and I’m quite pleased with how well the combination works.

The way the app is implemented is by parsing the TikZ code, and at all times keeping track of the exact source location of each object. Thereby, when a user drags an element to a new position, the app can override just the numbers in the coordinate without changing anything else in the code (such as line breaks or indentation).

This approach essentially required reimplementing a large fraction of TikZ, which is the kind of task that no human would ever want to do. I think building software that doesn’t exist yet because it would be impossibly tedious to code up is one of the great new possibilities thanks to coding agents, and it’s worth brainstorming for other examples. (This app was built almost entirely by Codex.)

Implementing the app came with lots of fun side quests, including building converters from SVG / pptx / ipe to TikZ, re-implementing the LaTeX hyphenation and line-breaking algorithm to support multi-line nodes, and making a color picker that uses the red!20!black color mixing notation used in LaTeX papers.

srean
1 minute ago
[-]
Is their anyone here old enough to remember Xfig ?

I was quite proud of the hours of work I had put in to configure it just so, with the 3d look and all.

reply
j2kun
1 hour ago
[-]
Neat! I also enjoyed https://q.uiver.app/ by https://github.com/varkor which is a bit more specialized.
reply
DominikPeters
1 hour ago
[-]
Yes, there are several editors for more specialized things. Other nice examples: https://tikzit.github.io/ and https://www.circuit2tikz.tf.fau.de/designer/ and https://tikzcd.yichuanshen.de/
reply
master-lincoln
1 hour ago
[-]
As a student I really wanted something like this. Thanks for making it open source. My theoretical computer science prof happened to be Till Tantau the inventor of TikZ. An awesome communicator too.
reply
DominikPeters
1 hour ago
[-]
Schleswig-Holsteiners are everywhere :) Till Tantau also started the beamer package for making LaTeX presentations. Both beamer and tikz are very important contributions to science communication.
reply
sorenjan
1 hour ago
[-]
Looks really nice. You might consider adding some presets to make it easier to get started, like some common neural net architectures and other use cases for TikZ.
reply
DominikPeters
1 hour ago
[-]
Good idea. There is File > Open Example, but it could be extended for sure. On desktop you can even directly open an arXiv paper!
reply
delta_p_delta_x
1 hour ago
[-]
This is superb. Will you consider adding support for pgfplots[1]? When I was a student I was long considering writing a native application for real-time TikZing.

[1]: https://ctan.org/pkg/pgfplots?lang=en

reply
DominikPeters
1 hour ago
[-]
I think pgfplots should in principle be possible. I've postponed it thus far because pgfplots is GPL licensed, while the editor is MIT licensed, so I would need to distribute pgfplots support as a separate add-on. But in due course, putting in add-on infrastructure could make sense, because it would also allow adding support for stuff like tikzcd and CircuiTikZ (or tikzpingus!).
reply
cubefox
5 minutes ago
[-]
That's cool. I guess it doesn't support TikZ' relative positioning (left of etc) because WYSIWYG features like drag-and-drop require absolute positioning?
reply
GL26
1 hour ago
[-]
All STEM students and researches from the world thank you
reply
whatever1
1 hour ago
[-]
OMG! Psychiatrists are going to lose all of their graduate customers!

The world thanks you.

reply
__mharrison__
1 hour ago
[-]
This is very cool, but I'm going to say the inevitable...

How hard would it be to support cetz? I'm not touching LaTeX if I can avoid it, but I'm using Typst all the time.

reply
adityamwagh
1 hour ago
[-]
Hey! I've always wanted something like this! Thanks for building this!
reply
dvorka
1 hour ago
[-]
I needed exactly this for years excellent work!
reply
emil-lp
1 hour ago
[-]
Here's what I would need: the ability to position five nodes in a circular fashion, so that they are evenly spaced.
reply
DominikPeters
1 hour ago
[-]
Intriguing thought. Of course by writing code it can be done

  \foreach \i in {1,...,5} {
    \node[circle, draw] (n\i) at ({90 - 72*(\i-1)}:1cm) {$\i$};
  }
but I'm not sure how to expose that as a UI in a nice way (maybe: if something uses polar coordinates and the user holds shift, then during drag the radius stays fixed, and I nudge towards even angular spacing + multiples of 15 degrees?)
reply
e2e8
1 hour ago
[-]
That sounds like the array modifier in Blender
reply
Littice
1 hour ago
[-]
The killer feature for me is not drawing TikZ visually, but being able to touch old TikZ without turning the source into generated-looking soup.
reply
DominikPeters
1 hour ago
[-]
Exactly, I wanted to avoid that. In contrast, if you open an SVG in (for example) Inkscape and make a minimal change and save, the resulting file has little to do with the original.
reply
dima-quant
1 hour ago
[-]
This is great, nice concept! Good use of coding agents. Now I can make diagrams much faster.
reply
hosteur
1 hour ago
[-]
Wow. I would have loved something like this when I was studying in University.
reply
quantummagic
1 hour ago
[-]
Great job! Thank you for making it open source.

At some point the people who seethe with hate for AI, and claim it's all hallucinations and illegitimate hype, are going to have to admit they were wrong. Projects like this are the proof staring them right in the face, if they care to look.

reply
Barbing
1 hour ago
[-]
They’ve updated their criticisms since - bottom of career ladder disruption, skill atrophy.

(Not on HN but I do still see some folks who last tested LLMs before Nov ‘25, those folks might still be mostly out of touch.)

reply
david_2107
1 hour ago
[-]
That's awesome! Long overdue.
reply
k33n
1 hour ago
[-]
Wow, this is really, really great. Congratulations on an excellent offering and piece of tech!
reply