Bluefish: Composing Diagrams with Declarative Relations

要旨

Diagrams are essential tools for problem-solving and communication as they externalize conceptual structures using spatial relationships. But when picking a diagramming framework, users are faced with a dilemma. They can either use a highly expressive but low-level toolkit, whose API does not match their domain-specific concepts, or select a high-level typology, which offers a recognizable vocabulary but supports a limited range of diagrams. To address this gap, we introduce Bluefish: a diagramming framework inspired by component-based user interface (UI) libraries. Bluefish lets users create diagrams using relations: declarative, composable, and extensible diagram fragments that relax the concept of a UI component. Unlike a component, a relation does not have sole ownership over its children nor does it need to fully specify their layout. To render diagrams, Bluefish extends a traditional tree-based scenegraph to a compound graph that captures both hierarchical and adjacent relationships between nodes. To evaluate our system, we construct a diverse example gallery covering many domains including mathematics, physics, computer science, and even cooking. We show that Bluefish's relations are effective declarative primitives for diagrams. Bluefish is open source, and we aim to shape it into both a usable tool and a research platform.

著者
Josh M.. Pollock
Massachusetts Institute of Technology, Cambridge, Massachusetts, United States
Catherine Mei
Massachusetts Institute of Technology, Cambridge, Massachusetts, United States
Grace Huang
Massachusetts Institute of Technology, Cambridge, Massachusetts, United States
Elliot Evans
N/A, Ottawa, Ontario, Canada
Daniel Jackson
MIT, Cambridge, Massachusetts, United States
Arvind Satyanarayan
MIT, Cambridge, Massachusetts, United States
論文URL

https://doi.org/10.1145/3654777.3676465

動画

会議: UIST 2024

ACM Symposium on User Interface Software and Technology

セッション: 3. Manipulating Text

Westin: Allegheny 3
4 件の発表
2024-10-14 22:40:00
2024-10-14 23:40:00