File size: 19,324 Bytes
2409829
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
+++
title = "Graphite features"

[extra]
css = ["/page/features.css", "/component/feature-box.css", "/component/feature-icons.css", "/component/youtube-embed.css"]
js = ["/js/youtube-embed.js"]
+++

<section>
<div class="block">

# Graphite features

The current alpha version of Graphite is a tool for vector art and graphic design. It also supports a limited, experimental raster editing toolset. This tooling is built around a procedural graphics engine, letting artists build complex graphics and animations in its visual scripting language.

In 2025, stay tuned for performance improvements, native multiplatform desktop apps, and the beginnings of a full raster editing tool suite.

</div>
</section>

<section>
<div class="block">

<div class="block video-container">
<div>
<div class="youtube-embed aspect-16x9">
	<img data-youtube-embed="ZUbcwUC5lxA" loading="lazy" src="https://static.graphite.rs/content/features/podcast-interview-youtube.avif" onerror="this.onerror = null; this.src = this.src.replace('.avif', '.png')" alt="Rust-Powered Graphics Editor: How Graphite's Syntax Trees Revolutionize Image Editing" />
</div>
</div>
</div>

</div>
</section>

<section>

<div class="diptych">

<div class="block">

## Layers & nodes: hybrid editing

Graphite combines the best ideas from multiple categories of digital content creation software to redefine the workflows of 2D graphics editing. It is influenced by the core editing experience of traditional layer-based raster and vector apps, the nondestructive approaches of VFX compositing programs used by film studios, and the boundless creative possibilities of procedural production tools daily-driven by the 3D industry.

Classic layer-based image editing is easy to understand, with collapsable folders that help artists stay organized. A variety of interactive viewport tools make it easy to manipulate the layers by drawing directly onto the canvas. On the other hand, node-based editing is like artist-friendly programming. It works by describing manipulations as steps in a flowchart, which is vastly more powerful but comes with added complexity.

The hybrid workflow of Graphite offers a classic tool-centric, layer-based editing experience built around a procedural, node-based compositor. Users can ignore the node graph, use it exclusively, or switch back and forth with the press of a button while creating content. Interacting with the canvas using tools will manipulate the nodes behind the scenes. And the layer panel and node graph provide two equivalent, interchangeable views of the same document structure.

</div>
<div class="block">

## Raster & vector: sharp at all sizes

Digital 2D art commonly takes two forms. Raster artwork is made out of pixels which means it can look like anything imaginable, but it becomes blurry or pixelated when upscaling to a higher resolution. Vector artwork is made out of curved shapes which is perfect for some art styles but limiting to others. The magic of vector is that its mathematically-described curves can be enlarged to any size and remain crisp.

Other apps usually focus on just raster or vector, forcing artists to buy and learn both products. Mixing art styles requires shuttling content back and forth between programs. And since picking a raster document resolution is a one-time deal, artists often choose to start really big, resulting in sluggish editing performance and multi-gigabyte documents.

Graphite reinvents raster rendering so it stays sharp at any scale. Artwork is treated as data, not pixels, and is always redrawn at the current viewing resolution. Zoom the viewport and export images at any size— the document's paint brushes, masks, filters, and effects will all be rendered at the current native resolution.

Marrying vector and raster under one roof enables both art forms to complement each other in a cohesive content creation workflow. *(Scalable raster compositing is still in-development.)*

</div>

</div>

</section>

<section>

<div class="diptych">

<div class="block">

## Powered by Graphene

**Graphene** is the purpose-built node graph engine that powers Graphite's compositor and procedural graphics pipeline. It's a visual scripting environment built upon the high-performance Rust programming language. Its runtime is [designed](/blog/distributed-computing-in-the-graphene-runtime/) to distribute rendering across CPU cores, GPUs, and network/cloud machines while optimizing for interactive frame rates.

<!-- Rust programmers may find the following technical details to be of interest. Graphene node graphs are programs built out of reusable Rust functions using Graphite as a visual "code" editor. New nodes and data types can be implemented by writing custom Rust code with a built-in text editor. `no_std` code also gets compiled to GPU compute shaders using [`rust-gpu`](https://github.com/EmbarkStudios/rust-gpu). Each node is independently pre-compiled by `rustc` into portable WASM binaries and linked at runtime. Groups of nodes may be compiled into one unit of execution, utilizing Rust's zero-cost abstractions and optimizations to run with less overhead. And whole node graphs can be compiled into standalone executables for use outside Graphite. -->

</div>
<div class="block">

<!-- ## Proudly written in Rust -->
## Built with Rust

Always on the bleeding edge and built to last— Graphite is written on a robust foundation with Rust, a modern programming language optimized for creating fast, reliable, future-proof software. Even the GPU compute shaders are written in Rust, enabling reuse of CPU code implementations for nodes.

<!-- The underlying node graph engine that computes and renders Graphite documents is called Graphene. The Graphene engine is an extension of the Rust language, acting as a system for chaining together modular functions into useful pipelines with GPU and parallel computation. Artists can harness these powerful capabilities directly in the Graphite editor without touching code. Technical artists and programmers can write reusable Rust functions to extend the capabilities of Graphite and create new nodes to share with the community. -->

</div>

</div>

</section>

<section>
<div class="block">

## Roadmap

<div class="roadmap">
	<div class="feature-icons">
		<!-- Pre-Alpha -->
		<div class="feature-icon complete heading" title="Began February 2021" data-year="2021">
			<h3>— Pre-Alpha —</h3>
		</div>
		<div class="feature-icon complete" title="Development Complete">
			<img class="atlas" style="--atlas-index: 1" src="https://static.graphite.rs/icons/icon-atlas-roadmap__3.png" alt="" />
			<span>Editor systems; basic vector art tools</span>
		</div>
		<!-- Alpha 1 -->
		<div class="feature-icon complete heading" title="Began February 2022" data-year="2022">
			<h3>— Alpha 1 —</h3>
		</div>
		<div class="feature-icon complete" title="Development Complete">
			<img class="atlas" style="--atlas-index: 2" src="https://static.graphite.rs/icons/icon-atlas-roadmap__3.png" alt="" />
			<span>Better tools; node graph prototyping</span>
		</div>
		<!-- Alpha 2 -->
		<div class="feature-icon complete heading" title="Began February 2023" data-year="2023">
			<h3>— Alpha 2 —</h3>
		</div>
		<div class="feature-icon complete" title="Development Complete">
			<img class="atlas" style="--atlas-index: 6" src="https://static.graphite.rs/icons/icon-atlas-roadmap__3.png" alt="" />
			<span>Node graph integration in documents</span>
		</div>
		<!-- Alpha 3 -->
		<div class="feature-icon complete heading" title="Began February 2024" data-year="2024">
			<h3>— Alpha 3 —</h3>
		</div>
		<div class="feature-icon complete" title="Development Complete">
			<img class="atlas" style="--atlas-index: 8" src="https://static.graphite.rs/icons/icon-atlas-roadmap__3.png" alt="" />
			<span>Procedural vector editing and usability</span>
		</div>
		<!-- Alpha 4 -->
		<div class="feature-icon ongoing heading" title="Began February 2025" data-year="2025">
			<h3>— Alpha 4 —</h3>
		</div>
		<div class="feature-icon complete" title="Development Complete">
			<img class="atlas" style="--atlas-index: 46" src="https://static.graphite.rs/icons/icon-atlas-roadmap__3.png" alt="" />
			<span>Parametric animation</span>
		</div>
		<div class="feature-icon complete" title="Development Complete">
			<img class="atlas" style="--atlas-index: 1" src="https://static.graphite.rs/icons/icon-atlas-features__2.png" alt="" />
			<span>Instancer repeat nodes</span>
		</div>
		<div class="feature-icon ongoing" title="Development Ongoing">
			<img class="atlas" style="--atlas-index: 9" src="https://static.graphite.rs/icons/icon-atlas-roadmap__3.png" alt="" />
			<span>Graph data attribute spreadsheets</span>
		</div>
		<div class="feature-icon ongoing" title="Development Ongoing">
			<img class="atlas" style="--atlas-index: 48" src="https://static.graphite.rs/icons/icon-atlas-roadmap__3.png" alt="" />
			<span>Robust vector mesh editing/rendering</span>
		</div>
		<div class="feature-icon ongoing" title="Development Ongoing">
			<img class="atlas" style="--atlas-index: 7" src="https://static.graphite.rs/icons/icon-atlas-roadmap__3.png" alt="" />
			<span>Desktop app (Windows, Mac, Linux)</span>
		</div>
		<div class="feature-icon ongoing" title="Development Ongoing">
			<img class="atlas" style="--atlas-index: 40" src="https://static.graphite.rs/icons/icon-atlas-roadmap__3.png" alt="" />
			<span>Simplified main properties panel</span>
		</div>
		<div class="feature-icon ongoing" title="Development Ongoing">
			<img class="atlas" style="--atlas-index: 12" src="https://static.graphite.rs/icons/icon-atlas-roadmap__3.png" alt="" />
			<span>GPU-accelerated raster rendering</span>
		</div>
		<div class="feature-icon">
			<img class="atlas" style="--atlas-index: 14" src="https://static.graphite.rs/icons/icon-atlas-roadmap__3.png" alt="" />
			<span>Infinitely zoomable/panable raster</span>
		</div>
		<div class="feature-icon">
			<img class="atlas" style="--atlas-index: 21" src="https://static.graphite.rs/icons/icon-atlas-roadmap__3.png" alt="" />
			<span>Select mode (marquee masking)</span>
		</div>
		<div class="feature-icon">
			<img class="atlas" style="--atlas-index: 41" src="https://static.graphite.rs/icons/icon-atlas-roadmap__3.png" alt="" />
			<span>Timeline panel for animation curves</span>
		</div>
		<div class="feature-icon">
			<img class="atlas" style="--atlas-index: 18" src="https://static.graphite.rs/icons/icon-atlas-roadmap__3.png" alt="" />
			<span>Node version management</span>
		</div>
		<div class="feature-icon">
			<img class="atlas" style="--atlas-index: 5" src="https://static.graphite.rs/icons/icon-atlas-roadmap__3.png" alt="" />
			<span>Brush tool rewrite</span>
		</div>
		<div class="feature-icon">
			<img class="atlas" style="--atlas-index: 57" src="https://static.graphite.rs/icons/icon-atlas-roadmap__3.png" alt="" />
			<span>Signed distance field rendering</span>
		</div>
		<div class="feature-icon">
			<img class="atlas" style="--atlas-index: 56" src="https://static.graphite.rs/icons/icon-atlas-roadmap__3.png" alt="" />
			<span>Variable color swatches</span>
		</div>
		<div class="feature-icon">
			<img class="atlas" style="--atlas-index: 52" src="https://static.graphite.rs/icons/icon-atlas-roadmap__3.png" alt="" />
			<span>Command palette and context menus</span>
		</div>
		<div class="feature-icon">
			<img class="atlas" style="--atlas-index: 53" src="https://static.graphite.rs/icons/icon-atlas-roadmap__3.png" alt="" />
			<span>Local fonts access</span>
		</div>
		<div class="feature-icon">
			<img class="atlas" style="--atlas-index: 54" src="https://static.graphite.rs/icons/icon-atlas-roadmap__3.png" alt="" />
			<span>Local file browser for saving/loading</span>
		</div>
		<div class="feature-icon">
			<img class="atlas" style="--atlas-index: 19" src="https://static.graphite.rs/icons/icon-atlas-roadmap__3.png" alt="" />
			<span>Raw photo processing</span>
		</div>
		<div class="feature-icon">
			<img class="atlas" style="--atlas-index: 43" src="https://static.graphite.rs/icons/icon-atlas-roadmap__3.png" alt="" />
			<span>Stylus and touch interaction</span>
		</div>
		<div class="feature-icon">
			<img class="atlas" style="--atlas-index: 24" src="https://static.graphite.rs/icons/icon-atlas-roadmap__3.png" alt="" />
			<span>Dockable workspace panels</span>
		</div>
		<div class="feature-icon">
			<img class="atlas" style="--atlas-index: 17" src="https://static.graphite.rs/icons/icon-atlas-roadmap__3.png" alt="" />
			<span>Stable document format</span>
		</div>
		<!-- <div class="feature-icon ongoing" title="Development Ongoing">
			<img class="atlas" style="--atlas-index: 0" src="https://static.graphite.rs/icons/icon-atlas-roadmap__3.png" alt="" />
			<span>Imaginate tool</span>
		</div> -->
		<!-- Beta -->
		<div class="feature-icon heading">
			<h3>— Beta —</h3>
		</div>
		<div class="feature-icon">
			<img class="atlas" style="--atlas-index: 16" src="https://static.graphite.rs/icons/icon-atlas-roadmap__3.png" alt="" />
			<span>Code editor for custom nodes</span>
		</div>
		<div class="feature-icon">
			<img class="atlas" style="--atlas-index: 22" src="https://static.graphite.rs/icons/icon-atlas-roadmap__3.png" alt="" />
			<span>Frozen-in-time graph references</span>
		</div>
		<div class="feature-icon">
			<img class="atlas" style="--atlas-index: 49" src="https://static.graphite.rs/icons/icon-atlas-roadmap__3.png" alt="" />
			<span>AI nodes and tools (e.g. magic wand)</span>
		</div>
		<div class="feature-icon">
			<img class="atlas" style="--atlas-index: 25" src="https://static.graphite.rs/icons/icon-atlas-roadmap__3.png" alt="" />
			<span>Liquify and non-affine transforms</span>
		</div>
		<div class="feature-icon">
			<img class="atlas" style="--atlas-index: 4" src="https://static.graphite.rs/icons/icon-atlas-roadmap__3.png" alt="" />
			<span>Outliner panel (node graph tree view)</span>
		</div>
		<div class="feature-icon">
			<img class="atlas" style="--atlas-index: 50" src="https://static.graphite.rs/icons/icon-atlas-roadmap__3.png" alt="" />
			<span>Shape builder tool</span>
		</div>
		<div class="feature-icon">
			<img class="atlas" style="--atlas-index: 23" src="https://static.graphite.rs/icons/icon-atlas-roadmap__3.png" alt="" />
			<span>Internationalization and accessibility</span>
		</div>
		<div class="feature-icon">
			<img class="atlas" style="--atlas-index: 18" src="https://static.graphite.rs/icons/icon-atlas-roadmap__3.png" alt="" />
			<span>Document history management</span>
		</div>
		<div class="feature-icon">
			<img class="atlas" style="--atlas-index: 27" src="https://static.graphite.rs/icons/icon-atlas-roadmap__3.png" alt="" />
			<span>Automation and batch processing</span>
		</div>
		<div class="feature-icon">
			<img class="atlas" style="--atlas-index: 28" src="https://static.graphite.rs/icons/icon-atlas-roadmap__3.png" alt="" />
			<span>Construction geometry mode</span>
		</div>
		<div class="feature-icon">
			<img class="atlas" style="--atlas-index: 33" src="https://static.graphite.rs/icons/icon-atlas-roadmap__3.png" alt="" />
			<span>HDR and WCG color handling</span>
		</div>
		<div class="feature-icon">
			<img class="atlas" style="--atlas-index: 55" src="https://static.graphite.rs/icons/icon-atlas-roadmap__3.png" alt="" />
			<span>CMYK and other color spaces</span>
		</div>
		<div class="feature-icon">
			<img class="atlas" style="--atlas-index: 34" src="https://static.graphite.rs/icons/icon-atlas-roadmap__3.png" alt="" />
			<span>Asset libraries and marketplace</span>
		</div>
		<div class="feature-icon">
			<img class="atlas" style="--atlas-index: 31" src="https://static.graphite.rs/icons/icon-atlas-roadmap__3.png" alt="" />
			<span>Advanced typography and typesetting</span>
		</div>
		<div class="feature-icon">
			<img class="atlas" style="--atlas-index: 35" src="https://static.graphite.rs/icons/icon-atlas-roadmap__3.png" alt="" />
			<span>Predictive graph rendering/caching</span>
		</div>
		<!-- 1.0 Release -->
		<div class="feature-icon heading">
			<h3>— 1.0 Release —</h3>
		</div>
		<div class="feature-icon">
			<img class="atlas" style="--atlas-index: 20" src="https://static.graphite.rs/icons/icon-atlas-roadmap__3.png" alt="" />
			<span>Procedural styling of paint brushes</span>
		</div>
		<div class="feature-icon">
			<img class="atlas" style="--atlas-index: 29" src="https://static.graphite.rs/icons/icon-atlas-roadmap__3.png" alt="" />
			<span>CAD-like constraint relationships</span>
		</div>
		<div class="feature-icon">
			<img class="atlas" style="--atlas-index: 30" src="https://static.graphite.rs/icons/icon-atlas-roadmap__3.png" alt="" />
			<span>Responsive design constraint solvers</span>
		</div>
		<div class="feature-icon">
			<img class="atlas" style="--atlas-index: 32" src="https://static.graphite.rs/icons/icon-atlas-roadmap__3.png" alt="" />
			<span>PDF export</span>
		</div>
		<div class="feature-icon">
			<img class="atlas" style="--atlas-index: 11" src="https://static.graphite.rs/icons/icon-atlas-roadmap__3.png" alt="" />
			<span>Finer-grain control over SVG export</span>
		</div>
		<div class="feature-icon">
			<img class="atlas" style="--atlas-index: 45" src="https://static.graphite.rs/icons/icon-atlas-roadmap__3.png" alt="" />
			<span>Portable, embeddable render engine</span>
		</div>
		<div class="feature-icon">
			<img class="atlas" style="--atlas-index: 36" src="https://static.graphite.rs/icons/icon-atlas-roadmap__3.png" alt="" />
			<span>Distributed graph rendering</span>
		</div>
		<div class="feature-icon">
			<img class="atlas" style="--atlas-index: 15" src="https://static.graphite.rs/icons/icon-atlas-roadmap__3.png" alt="" />
			<span>Cloud rendering accelerator service</span>
		</div>
		<div class="feature-icon">
			<img class="atlas" style="--atlas-index: 37" src="https://static.graphite.rs/icons/icon-atlas-roadmap__3.png" alt="" />
			<span>Cloud document storage</span>
		</div>
		<div class="feature-icon">
			<img class="atlas" style="--atlas-index: 38" src="https://static.graphite.rs/icons/icon-atlas-roadmap__3.png" alt="" />
			<span>Multiplayer collaborative editing</span>
		</div>
		<div class="feature-icon">
			<img class="atlas" style="--atlas-index: 39" src="https://static.graphite.rs/icons/icon-atlas-roadmap__3.png" alt="" />
			<span>Offline edit resolution with CRDTs</span>
		</div>
		<div class="feature-icon">
			<img class="atlas" style="--atlas-index: 16" src="https://static.graphite.rs/icons/icon-atlas-features__2.png" alt="" />
			<span>Animated SVG creation</span>
		</div>
		<div class="feature-icon">
			<img class="atlas" style="--atlas-index: 42" src="https://static.graphite.rs/icons/icon-atlas-roadmap__3.png" alt="" />
			<span>Live video compositing</span>
		</div>
		<div class="feature-icon">
			<img class="atlas" style="--atlas-index: 44" src="https://static.graphite.rs/icons/icon-atlas-roadmap__3.png" alt="" />
			<span>iPad app and keyboard-free controls</span>
		</div>
		<div class="feature-icon">
			<img class="atlas" style="--atlas-index: 47" src="https://static.graphite.rs/icons/icon-atlas-roadmap__3.png" alt="" />
			<span><em>…and that's all just the beginning…</em></span>
		</div>
	</div>
</div>

</div>
</section>