Compare commits
3 Commits
Author | SHA1 | Date | |
---|---|---|---|
3aca407ce5 | |||
64278c924c | |||
4e125ef40c |
@ -56,7 +56,7 @@ For more information, see the [manual](manual.pdf)
|
|||||||
|
|
||||||
To use this package, simply import [circuiteria](https://typst.app/universe/package/circuiteria) and call the `circuit` function:
|
To use this package, simply import [circuiteria](https://typst.app/universe/package/circuiteria) and call the `circuit` function:
|
||||||
```typ
|
```typ
|
||||||
#import "@preview/circuiteria:0.2.0"
|
#import "@preview/circuiteria:0.1.0"
|
||||||
#circuiteria.circuit({
|
#circuiteria.circuit({
|
||||||
import circuiteria: *
|
import circuiteria: *
|
||||||
...
|
...
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
#import "@preview/cetz:0.3.2": draw
|
#import "@preview/cetz:0.2.2": draw
|
||||||
#import "../src/circuit.typ": circuit
|
#import "../src/circuit.typ": circuit
|
||||||
#import "../src/util.typ"
|
#import "../src/util.typ"
|
||||||
|
|
||||||
|
40
gallery.bash
Normal file
@ -0,0 +1,40 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
PDFS=false
|
||||||
|
|
||||||
|
while getopts "p" flag
|
||||||
|
do
|
||||||
|
case "${flag}" in
|
||||||
|
p) PDFS=true;;
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
|
||||||
|
echo "Generating gallery images"
|
||||||
|
|
||||||
|
set -- ./gallery/*.typ
|
||||||
|
cnt="$#"
|
||||||
|
i=1
|
||||||
|
for f
|
||||||
|
do
|
||||||
|
f2="${f/typ/png}"
|
||||||
|
echo "($i/$cnt) $f -> $f2"
|
||||||
|
typst c --root ./ "$f" "$f2"
|
||||||
|
i=$((i+1))
|
||||||
|
done
|
||||||
|
|
||||||
|
if [ "$PDFS" = true ]
|
||||||
|
then
|
||||||
|
echo
|
||||||
|
echo "Generating gallery PDFs"
|
||||||
|
|
||||||
|
set -- ./gallery/*.typ
|
||||||
|
cnt="$#"
|
||||||
|
i=1
|
||||||
|
for f
|
||||||
|
do
|
||||||
|
f2="${f/typ/pdf}"
|
||||||
|
echo "($i/$cnt) $f -> $f2"
|
||||||
|
typst c --root ./ "$f" "$f2"
|
||||||
|
i=$((i+1))
|
||||||
|
done
|
||||||
|
fi
|
Before Width: | Height: | Size: 45 KiB After Width: | Height: | Size: 45 KiB |
BIN
gallery/test.png
Before Width: | Height: | Size: 142 KiB After Width: | Height: | Size: 142 KiB |
Before Width: | Height: | Size: 142 KiB After Width: | Height: | Size: 142 KiB |
Before Width: | Height: | Size: 66 KiB After Width: | Height: | Size: 66 KiB |
@ -1,4 +1,4 @@
|
|||||||
#import "@preview/cetz:0.3.2": draw
|
#import "@preview/cetz:0.2.2": draw
|
||||||
#import "../src/lib.typ": circuit, element, util, wire
|
#import "../src/lib.typ": circuit, element, util, wire
|
||||||
|
|
||||||
#set page(width: auto, height: auto, margin: .5cm)
|
#set page(width: auto, height: auto, margin: .5cm)
|
||||||
|
Before Width: | Height: | Size: 159 KiB After Width: | Height: | Size: 159 KiB |
@ -1,4 +1,4 @@
|
|||||||
#import "@preview/cetz:0.3.2": draw
|
#import "@preview/cetz:0.2.2": draw
|
||||||
#import "../src/lib.typ": *
|
#import "../src/lib.typ": *
|
||||||
|
|
||||||
#set page(width: auto, height: auto, margin: .5cm)
|
#set page(width: auto, height: auto, margin: .5cm)
|
||||||
|
Before Width: | Height: | Size: 275 KiB After Width: | Height: | Size: 276 KiB |
@ -1,4 +1,4 @@
|
|||||||
#import "@preview/cetz:0.3.2": draw
|
#import "@preview/cetz:0.2.2": draw
|
||||||
#import "../src/lib.typ": *
|
#import "../src/lib.typ": *
|
||||||
|
|
||||||
#set page(width: auto, height: auto, margin: .5cm)
|
#set page(width: auto, height: auto, margin: .5cm)
|
||||||
|
Before Width: | Height: | Size: 76 KiB After Width: | Height: | Size: 76 KiB |
@ -1,4 +1,4 @@
|
|||||||
#import "@preview/cetz:0.3.2": draw, vector
|
#import "@preview/cetz:0.2.2": draw, vector
|
||||||
#import "../src/lib.typ": *
|
#import "../src/lib.typ": *
|
||||||
|
|
||||||
#set page(width: auto, height: auto, margin: .5cm)
|
#set page(width: auto, height: auto, margin: .5cm)
|
||||||
|
11
justfile
@ -1,11 +0,0 @@
|
|||||||
# Local Variables:
|
|
||||||
# mode: makefile
|
|
||||||
# End:
|
|
||||||
gallery_dir := "./gallery"
|
|
||||||
set shell := ["bash", "-uc"]
|
|
||||||
|
|
||||||
manual:
|
|
||||||
typst c manual.typ manual.pdf
|
|
||||||
|
|
||||||
gallery:
|
|
||||||
for f in "{{gallery_dir}}"/*.typ; do typst c --root . "$f" "${f%typ}png"; done
|
|
BIN
manual.pdf
41
manual.typ
@ -1,5 +1,5 @@
|
|||||||
#import "@preview/tidy:0.4.1"
|
#import "@preview/tidy:0.3.0"
|
||||||
#import "@preview/cetz:0.3.2": draw, canvas
|
#import "@preview/cetz:0.2.2": draw, canvas
|
||||||
#import "src/lib.typ"
|
#import "src/lib.typ"
|
||||||
#import "doc/examples.typ"
|
#import "doc/examples.typ"
|
||||||
#import "src/circuit.typ": circuit
|
#import "src/circuit.typ": circuit
|
||||||
@ -12,7 +12,7 @@
|
|||||||
numbering("1.1", ..num)
|
numbering("1.1", ..num)
|
||||||
})
|
})
|
||||||
#{
|
#{
|
||||||
outline(indent: auto, depth: 3)
|
outline(indent: true, depth: 3)
|
||||||
}
|
}
|
||||||
|
|
||||||
#show link: set text(blue)
|
#show link: set text(blue)
|
||||||
@ -47,7 +47,7 @@
|
|||||||
|
|
||||||
#set page(numbering: "1/1", header: align(right)[circuiteria #sym.dash.em v#lib.version])
|
#set page(numbering: "1/1", header: align(right)[circuiteria #sym.dash.em v#lib.version])
|
||||||
#set page(
|
#set page(
|
||||||
header: context {
|
header: locate(loc => {
|
||||||
let txt = [circuiteria #sym.dash.em v#lib.version]
|
let txt = [circuiteria #sym.dash.em v#lib.version]
|
||||||
let cnt = counter(heading)
|
let cnt = counter(heading)
|
||||||
let cnt-val = cnt.get()
|
let cnt-val = cnt.get()
|
||||||
@ -65,8 +65,8 @@
|
|||||||
#rect(width: 100%, height: .5em, radius: .25em, stroke: none, fill: util.colors.values().at(i))
|
#rect(width: 100%, height: .5em, radius: .25em, stroke: none, fill: util.colors.values().at(i))
|
||||||
]
|
]
|
||||||
)
|
)
|
||||||
},
|
}),
|
||||||
footer: context {
|
footer: locate(loc => {
|
||||||
let cnt = counter(heading)
|
let cnt = counter(heading)
|
||||||
let cnt-val = cnt.get()
|
let cnt-val = cnt.get()
|
||||||
if cnt-val.len() < 2 { return }
|
if cnt-val.len() < 2 { return }
|
||||||
@ -80,12 +80,12 @@
|
|||||||
],
|
],
|
||||||
counter(page).display("1/1", both: true)
|
counter(page).display("1/1", both: true)
|
||||||
)
|
)
|
||||||
}
|
})
|
||||||
)
|
)
|
||||||
|
|
||||||
#let doc-ref(target, full: false, var: false) = {
|
#let doc-ref(target, full: false, var: false) = {
|
||||||
let (module, func) = target.split(".")
|
let (module, func) = target.split(".")
|
||||||
let label-name = module + "-" + func
|
let label-name = module + func
|
||||||
let display-name = func
|
let display-name = func
|
||||||
if full {
|
if full {
|
||||||
display-name = target
|
display-name = target
|
||||||
@ -94,7 +94,7 @@
|
|||||||
label-name += "()"
|
label-name += "()"
|
||||||
display-name += "()"
|
display-name += "()"
|
||||||
}
|
}
|
||||||
link(label(label-name), raw(display-name))
|
link(label(label-name))[#display-name]
|
||||||
}
|
}
|
||||||
|
|
||||||
= Introduction
|
= Introduction
|
||||||
@ -103,21 +103,11 @@ This package provides a way to make beautiful block circuit diagrams using the C
|
|||||||
|
|
||||||
= Usage
|
= Usage
|
||||||
|
|
||||||
Simply import Circuiteria and call the `circuit` function:
|
Simply import #link("src/lib.typ") and call the `circuit` function:
|
||||||
#pad(left: 1em)[```typ
|
#pad(left: 1em)[```typ
|
||||||
#import "@preview/circuiteria:0.2.0"
|
#import "src/lib.typ"
|
||||||
#circuiteria.circuit({
|
#lib.circuit({
|
||||||
import circuiteria: *
|
import lib: *
|
||||||
...
|
|
||||||
})
|
|
||||||
```]
|
|
||||||
|
|
||||||
== Project installation
|
|
||||||
If you have installed Circuiteria directly in your project, import #link("src/lib.typ") and call the `circuit` function:
|
|
||||||
#pad(left: 1em)[```typ
|
|
||||||
#import "src/lib.typ" as circuiteria
|
|
||||||
#circuiteria.circuit({
|
|
||||||
import circuiteria: *
|
|
||||||
...
|
...
|
||||||
})
|
})
|
||||||
```]
|
```]
|
||||||
@ -127,7 +117,6 @@ If you have installed Circuiteria directly in your project, import #link("src/li
|
|||||||
#let circuit-docs = tidy.parse-module(
|
#let circuit-docs = tidy.parse-module(
|
||||||
read("src/circuit.typ"),
|
read("src/circuit.typ"),
|
||||||
name: "circuit",
|
name: "circuit",
|
||||||
old-syntax: true,
|
|
||||||
require-all-parameters: true
|
require-all-parameters: true
|
||||||
)
|
)
|
||||||
#tidy.show-module(circuit-docs)
|
#tidy.show-module(circuit-docs)
|
||||||
@ -137,7 +126,6 @@ If you have installed Circuiteria directly in your project, import #link("src/li
|
|||||||
#let util-docs = tidy.parse-module(
|
#let util-docs = tidy.parse-module(
|
||||||
read("src/util.typ"),
|
read("src/util.typ"),
|
||||||
name: "util",
|
name: "util",
|
||||||
old-syntax: true,
|
|
||||||
require-all-parameters: true,
|
require-all-parameters: true,
|
||||||
scope: (
|
scope: (
|
||||||
util: util,
|
util: util,
|
||||||
@ -152,7 +140,6 @@ If you have installed Circuiteria directly in your project, import #link("src/li
|
|||||||
#let wire-docs = tidy.parse-module(
|
#let wire-docs = tidy.parse-module(
|
||||||
read("src/wire.typ"),
|
read("src/wire.typ"),
|
||||||
name: "wire",
|
name: "wire",
|
||||||
old-syntax: true,
|
|
||||||
require-all-parameters: true,
|
require-all-parameters: true,
|
||||||
scope: (
|
scope: (
|
||||||
wire: wire,
|
wire: wire,
|
||||||
@ -174,7 +161,6 @@ If you have installed Circuiteria directly in your project, import #link("src/li
|
|||||||
read("src/elements/multiplexer.typ") + "\n" +
|
read("src/elements/multiplexer.typ") + "\n" +
|
||||||
read("src/elements/group.typ"),
|
read("src/elements/group.typ"),
|
||||||
name: "element",
|
name: "element",
|
||||||
old-syntax: true,
|
|
||||||
scope: (
|
scope: (
|
||||||
element: element,
|
element: element,
|
||||||
circuit: circuit,
|
circuit: circuit,
|
||||||
@ -197,7 +183,6 @@ If you have installed Circuiteria directly in your project, import #link("src/li
|
|||||||
read("src/elements/logic/or.typ") + "\n" +
|
read("src/elements/logic/or.typ") + "\n" +
|
||||||
read("src/elements/logic/xor.typ"),
|
read("src/elements/logic/xor.typ"),
|
||||||
name: "gates",
|
name: "gates",
|
||||||
old-syntax: true,
|
|
||||||
scope: (
|
scope: (
|
||||||
element: element,
|
element: element,
|
||||||
circuit: circuit,
|
circuit: circuit,
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
#import "@preview/cetz:0.3.2": canvas
|
#import "@preview/cetz:0.2.2": canvas
|
||||||
#import "@preview/tidy:0.3.0"
|
#import "@preview/tidy:0.3.0"
|
||||||
|
|
||||||
/// Draws a block circuit diagram
|
/// Draws a block circuit diagram
|
||||||
@ -9,6 +9,6 @@
|
|||||||
/// - length (length, ratio): Optional base unit
|
/// - length (length, ratio): Optional base unit
|
||||||
/// -> none
|
/// -> none
|
||||||
#let circuit(body, length: 2em) = {
|
#let circuit(body, length: 2em) = {
|
||||||
set text(font: "Source Sans 3")
|
// set text(font: "Source Sans 3")
|
||||||
canvas(length: length, body)
|
canvas(length: length, body)
|
||||||
}
|
}
|
@ -1,4 +1,4 @@
|
|||||||
#import "@preview/cetz:0.3.2": draw
|
#import "@preview/cetz:0.2.2": draw
|
||||||
#import "element.typ"
|
#import "element.typ"
|
||||||
#import "ports.typ": add-port
|
#import "ports.typ": add-port
|
||||||
|
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
#import "@preview/cetz:0.3.2": draw
|
#import "@preview/cetz:0.2.2": draw
|
||||||
#import "element.typ"
|
#import "element.typ"
|
||||||
|
|
||||||
#let draw-shape(id, tl, tr, br, bl, fill, stroke) = {
|
#let draw-shape(id, tl, tr, br, bl, fill, stroke) = {
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
#import "@preview/cetz:0.3.2": draw, coordinate
|
#import "@preview/cetz:0.2.2": draw, coordinate
|
||||||
#import "ports.typ": add-ports, add-port
|
#import "ports.typ": add-ports, add-port
|
||||||
#import "../util.typ"
|
#import "../util.typ"
|
||||||
|
|
||||||
@ -88,26 +88,15 @@
|
|||||||
if to-side in ports-margins {
|
if to-side in ports-margins {
|
||||||
margins = ports-margins.at(to-side)
|
margins = ports-margins.at(to-side)
|
||||||
}
|
}
|
||||||
|
let used-pct = 100% - margins.at(0) - margins.at(1)
|
||||||
|
let used-height = height * used-pct / 100%
|
||||||
|
let top-margin = height * margins.at(0) / 100%
|
||||||
|
|
||||||
|
let dy = used-height * (i + 1) / (ports.at(to-side).len() + 1)
|
||||||
|
|
||||||
let dy
|
if not auto-ports {
|
||||||
let top-margin
|
|
||||||
if to-side in ("east", "west") {
|
|
||||||
let used-pct = 100% - margins.at(0) - margins.at(1)
|
|
||||||
let used-height = height * used-pct / 100%
|
|
||||||
top-margin = height * margins.at(0) / 100%
|
|
||||||
|
|
||||||
dy = used-height * (i + 1) / (ports.at(to-side).len() + 1)
|
|
||||||
|
|
||||||
if not auto-ports {
|
|
||||||
top-margin = 0
|
|
||||||
dy = ports-y.at(to)(height)
|
|
||||||
}
|
|
||||||
} else if to-side == "north" {
|
|
||||||
dy = 0
|
|
||||||
top-margin = 0
|
|
||||||
} else if to-side == "south" {
|
|
||||||
dy = height
|
|
||||||
top-margin = 0
|
top-margin = 0
|
||||||
|
dy = ports-y.at(to)(height)
|
||||||
}
|
}
|
||||||
|
|
||||||
let (ctx, from-pos) = coordinate.resolve(ctx, from)
|
let (ctx, from-pos) = coordinate.resolve(ctx, from)
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
#import "@preview/cetz:0.3.2": draw
|
#import "@preview/cetz:0.2.2": draw
|
||||||
#import "element.typ"
|
#import "element.typ"
|
||||||
#import "ports.typ": add-port
|
#import "ports.typ": add-port
|
||||||
|
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
#import "@preview/cetz:0.3.2": draw, coordinate
|
#import "@preview/cetz:0.2.2": draw, coordinate
|
||||||
#import "../util.typ"
|
#import "../util.typ"
|
||||||
|
|
||||||
/// Draws a group of elements
|
/// Draws a group of elements
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
#import "@preview/cetz:0.3.2": draw
|
#import "@preview/cetz:0.2.2": draw
|
||||||
#import "gate.typ"
|
#import "gate.typ"
|
||||||
|
|
||||||
#let draw-shape(id, tl, tr, br, bl, fill, stroke) = {
|
#let draw-shape(id, tl, tr, br, bl, fill, stroke) = {
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
#import "@preview/cetz:0.3.2": draw
|
#import "@preview/cetz:0.2.2": draw
|
||||||
#import "gate.typ"
|
#import "gate.typ"
|
||||||
|
|
||||||
#let draw-shape(id, tl, tr, br, bl, fill, stroke) = {
|
#let draw-shape(id, tl, tr, br, bl, fill, stroke) = {
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
#import "@preview/cetz:0.3.2": draw, coordinate
|
#import "@preview/cetz:0.2.2": draw, coordinate
|
||||||
#import "../ports.typ": add-ports, add-port
|
#import "../ports.typ": add-ports, add-port
|
||||||
#import "../element.typ"
|
#import "../element.typ"
|
||||||
|
|
||||||
@ -54,20 +54,24 @@
|
|||||||
let (ctx, to-pos) = coordinate.resolve(ctx, (rel: (offset, 0), to: to))
|
let (ctx, to-pos) = coordinate.resolve(ctx, (rel: (offset, 0), to: to))
|
||||||
x = to-pos.at(0)
|
x = to-pos.at(0)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (type(y) == dictionary) {
|
if (type(y) == dictionary) {
|
||||||
let from = y.from
|
let offset = y.rel
|
||||||
let to = y.to
|
let to = y.to
|
||||||
|
let (ctx, to-pos) = coordinate.resolve(ctx, (rel: (0, offset), to: to))
|
||||||
let dy
|
y = to-pos.at(1)
|
||||||
if to == "out" {
|
// let from = y.from
|
||||||
dy = height / 2
|
// let to = y.to
|
||||||
} else {
|
|
||||||
dy = height * (i + 0.5) / inputs
|
// let dy
|
||||||
}
|
// if to == "out" {
|
||||||
|
// dy = height / 2
|
||||||
let (ctx, from-pos) = coordinate.resolve(ctx, from)
|
// } else {
|
||||||
y = from-pos.at(1) + dy - height
|
// dy = height * (i + 0.5) / inputs
|
||||||
|
// }
|
||||||
|
|
||||||
|
// let (ctx, from-pos) = coordinate.resolve(ctx, from)
|
||||||
|
// y = from-pos.at(1) + dy - height
|
||||||
}
|
}
|
||||||
|
|
||||||
let tl = (x, y + height)
|
let tl = (x, y + height)
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
#import "@preview/cetz:0.3.2": draw
|
#import "@preview/cetz:0.2.2": draw
|
||||||
#import "gate.typ"
|
#import "gate.typ"
|
||||||
|
|
||||||
#let draw-shape(id, tl, tr, br, bl, fill, stroke) = {
|
#let draw-shape(id, tl, tr, br, bl, fill, stroke) = {
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
#import "@preview/cetz:0.3.2": draw
|
#import "@preview/cetz:0.2.2": draw
|
||||||
#import "gate.typ"
|
#import "gate.typ"
|
||||||
|
|
||||||
#let space = 10%
|
#let space = 10%
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
#import "@preview/cetz:0.3.2": draw
|
#import "@preview/cetz:0.2.2": draw
|
||||||
#import "../util.typ"
|
#import "../util.typ"
|
||||||
#import "element.typ"
|
#import "element.typ"
|
||||||
#import "ports.typ": add-port
|
#import "ports.typ": add-port
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
#import "@preview/cetz:0.3.2": draw
|
#import "@preview/cetz:0.2.2": draw
|
||||||
#import "../util.typ": rotate-anchor
|
#import "../util.typ": rotate-anchor
|
||||||
|
|
||||||
#let add-port(
|
#let add-port(
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
#let version = version(0, 2, 0)
|
#let version = version(0, 1, 0)
|
||||||
|
|
||||||
#import "circuit.typ": circuit
|
#import "circuit.typ": circuit
|
||||||
#import "element.typ"
|
#import "element.typ"
|
||||||
|
110
src/wire.typ
@ -1,4 +1,4 @@
|
|||||||
#import "@preview/cetz:0.3.2": draw, coordinate
|
#import "@preview/cetz:0.2.2": draw, coordinate
|
||||||
#import "util.typ": opposite-anchor
|
#import "util.typ": opposite-anchor
|
||||||
|
|
||||||
/// List of valid wire styles
|
/// List of valid wire styles
|
||||||
@ -19,7 +19,7 @@
|
|||||||
#let get-direct-wire(pts) = {
|
#let get-direct-wire(pts) = {
|
||||||
let anchors = (
|
let anchors = (
|
||||||
"start": pts.first(),
|
"start": pts.first(),
|
||||||
"end": pts.last()
|
"end": pts.last(),
|
||||||
)
|
)
|
||||||
return (pts, anchors)
|
return (pts, anchors)
|
||||||
}
|
}
|
||||||
@ -38,21 +38,21 @@
|
|||||||
start,
|
start,
|
||||||
(horizontal: mid, vertical: ()),
|
(horizontal: mid, vertical: ()),
|
||||||
(horizontal: (), vertical: end),
|
(horizontal: (), vertical: end),
|
||||||
end
|
end,
|
||||||
)
|
)
|
||||||
} else {
|
} else {
|
||||||
(
|
(
|
||||||
start,
|
start,
|
||||||
(horizontal: (), vertical: mid),
|
(horizontal: (), vertical: mid),
|
||||||
(horizontal: end, vertical: ()),
|
(horizontal: end, vertical: ()),
|
||||||
end
|
end,
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
let anchors = (
|
let anchors = (
|
||||||
"start": start,
|
"start": start,
|
||||||
"zig": points.at(1),
|
"zig": points.at(1),
|
||||||
"zag": points.at(2),
|
"zag": points.at(2),
|
||||||
"end": end
|
"end": end,
|
||||||
)
|
)
|
||||||
return (points, anchors)
|
return (points, anchors)
|
||||||
}
|
}
|
||||||
@ -65,7 +65,7 @@
|
|||||||
|
|
||||||
let p1 = (start, margin-start, end)
|
let p1 = (start, margin-start, end)
|
||||||
let p2 = (end, margin-end, start)
|
let p2 = (end, margin-end, start)
|
||||||
|
|
||||||
let (ctx, p0) = coordinate.resolve(ctx, start)
|
let (ctx, p0) = coordinate.resolve(ctx, start)
|
||||||
let (ctx, p3) = coordinate.resolve(ctx, end)
|
let (ctx, p3) = coordinate.resolve(ctx, end)
|
||||||
p0 = (x: p0.first(), y: p0.last())
|
p0 = (x: p0.first(), y: p0.last())
|
||||||
@ -73,7 +73,7 @@
|
|||||||
|
|
||||||
let dx1 = margin-start
|
let dx1 = margin-start
|
||||||
let dx2 = margin-end
|
let dx2 = margin-end
|
||||||
|
|
||||||
if type(margin-start) == ratio {
|
if type(margin-start) == ratio {
|
||||||
dx1 = calc.abs(p3.x - p0.x) * margin-start / 100%
|
dx1 = calc.abs(p3.x - p0.x) * margin-start / 100%
|
||||||
}
|
}
|
||||||
@ -95,7 +95,7 @@
|
|||||||
(horizontal: (), vertical: (0, dodge-y)),
|
(horizontal: (), vertical: (0, dodge-y)),
|
||||||
(horizontal: p2, vertical: ()),
|
(horizontal: p2, vertical: ()),
|
||||||
(horizontal: (), vertical: end),
|
(horizontal: (), vertical: end),
|
||||||
end
|
end,
|
||||||
)
|
)
|
||||||
let anchors = (
|
let anchors = (
|
||||||
"start": start,
|
"start": start,
|
||||||
@ -103,7 +103,7 @@
|
|||||||
"dodge-start": points.at(2),
|
"dodge-start": points.at(2),
|
||||||
"dodge-end": points.at(3),
|
"dodge-end": points.at(3),
|
||||||
"end2": points.at(4),
|
"end2": points.at(4),
|
||||||
"end": end
|
"end": end,
|
||||||
)
|
)
|
||||||
|
|
||||||
return (points, anchors)
|
return (points, anchors)
|
||||||
@ -128,7 +128,8 @@
|
|||||||
/// - dodge-sides (array): The start and end sides (going out of the connected element) of the wire (only with style "dodge")
|
/// - dodge-sides (array): The start and end sides (going out of the connected element) of the wire (only with style "dodge")
|
||||||
/// - dodge-margins (array): The start and end margins (i.e. space before dodging) of the wire (only with style "dodge")
|
/// - dodge-margins (array): The start and end margins (i.e. space before dodging) of the wire (only with style "dodge")
|
||||||
#let wire(
|
#let wire(
|
||||||
id, pts,
|
id,
|
||||||
|
pts,
|
||||||
bus: false,
|
bus: false,
|
||||||
name: none,
|
name: none,
|
||||||
name-pos: "middle",
|
name-pos: "middle",
|
||||||
@ -143,7 +144,7 @@
|
|||||||
zigzag-dir: "vertical",
|
zigzag-dir: "vertical",
|
||||||
dodge-y: 0,
|
dodge-y: 0,
|
||||||
dodge-sides: ("east", "west"),
|
dodge-sides: ("east", "west"),
|
||||||
dodge-margins: (5%, 5%)
|
dodge-margins: (5%, 5%),
|
||||||
) = draw.get-ctx(ctx => {
|
) = draw.get-ctx(ctx => {
|
||||||
if not style in wire-styles {
|
if not style in wire-styles {
|
||||||
panic("Invalid wire style '" + style + "'")
|
panic("Invalid wire style '" + style + "'")
|
||||||
@ -152,10 +153,14 @@
|
|||||||
if pts.len() != 2 {
|
if pts.len() != 2 {
|
||||||
panic("Wrong number of points (got " + str(pts.len()) + " instead of 2)")
|
panic("Wrong number of points (got " + str(pts.len()) + " instead of 2)")
|
||||||
}
|
}
|
||||||
|
|
||||||
let stroke = (
|
let stroke = (
|
||||||
paint: color,
|
paint: color,
|
||||||
thickness: if bus {bus-width} else {signal-width}
|
thickness: if bus {
|
||||||
|
bus-width
|
||||||
|
} else {
|
||||||
|
signal-width
|
||||||
|
},
|
||||||
)
|
)
|
||||||
if dashed {
|
if dashed {
|
||||||
stroke.insert("dash", "dashed")
|
stroke.insert("dash", "dashed")
|
||||||
@ -166,17 +171,17 @@
|
|||||||
|
|
||||||
if style == "direct" {
|
if style == "direct" {
|
||||||
(points, anchors) = get-direct-wire(pts)
|
(points, anchors) = get-direct-wire(pts)
|
||||||
|
|
||||||
} else if style == "zigzag" {
|
} else if style == "zigzag" {
|
||||||
(points, anchors) = get-zigzag-wire(pts, zigzag-ratio, zigzag-dir)
|
(points, anchors) = get-zigzag-wire(pts, zigzag-ratio, zigzag-dir)
|
||||||
|
|
||||||
} else if style == "dodge" {
|
} else if style == "dodge" {
|
||||||
(points, anchors) = get-dodge-wire(
|
(points, anchors) = get-dodge-wire(
|
||||||
pts,
|
pts,
|
||||||
dodge-y,
|
dodge-y,
|
||||||
dodge-margins,
|
dodge-margins,
|
||||||
dodge-sides,
|
dodge-sides,
|
||||||
ctx
|
ctx,
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -184,12 +189,15 @@
|
|||||||
if directed {
|
if directed {
|
||||||
mark = (end: ">", fill: color)
|
mark = (end: ">", fill: color)
|
||||||
}
|
}
|
||||||
draw.group(name: id, {
|
draw.group(
|
||||||
draw.line(..points, stroke: stroke, mark: mark)
|
name: id,
|
||||||
for (anchor-name, anchor-pos) in anchors {
|
{
|
||||||
draw.anchor(anchor-name, anchor-pos)
|
draw.line(..points, stroke: stroke, mark: mark)
|
||||||
}
|
for (anchor-name, anchor-pos) in anchors {
|
||||||
})
|
draw.anchor(anchor-name, anchor-pos)
|
||||||
|
}
|
||||||
|
},
|
||||||
|
)
|
||||||
|
|
||||||
let first-pt = id + ".start"
|
let first-pt = id + ".start"
|
||||||
let last-pt = id + ".end"
|
let last-pt = id + ".end"
|
||||||
@ -198,12 +206,12 @@
|
|||||||
if reverse {
|
if reverse {
|
||||||
(first-pt, last-pt) = (last-pt, first-pt)
|
(first-pt, last-pt) = (last-pt, first-pt)
|
||||||
}
|
}
|
||||||
|
|
||||||
let angle = 0deg
|
let angle = 0deg
|
||||||
if rotate-name {
|
if rotate-name {
|
||||||
(ctx, first-pos) = coordinate.resolve(ctx, first-pos)
|
(ctx, first-pos) = coordinate.resolve(ctx, first-pos)
|
||||||
(ctx, second-pos) = coordinate.resolve(ctx, second-pos)
|
(ctx, second-pos) = coordinate.resolve(ctx, second-pos)
|
||||||
|
|
||||||
if reverse {
|
if reverse {
|
||||||
(first-pos, second-pos) = (second-pos, first-pos)
|
(first-pos, second-pos) = (second-pos, first-pos)
|
||||||
}
|
}
|
||||||
@ -211,24 +219,24 @@
|
|||||||
let (x2, y2, ..) = second-pos
|
let (x2, y2, ..) = second-pos
|
||||||
angle = calc.atan2(x2 - x1, y2 - y1)
|
angle = calc.atan2(x2 - x1, y2 - y1)
|
||||||
}
|
}
|
||||||
|
|
||||||
if name != none {
|
if name != none {
|
||||||
let names = ()
|
let names = ()
|
||||||
|
|
||||||
if type(name) == str {
|
if type(name) == str or type(name) == content {
|
||||||
names = ((name, name-pos),)
|
names = ((name, name-pos),)
|
||||||
|
|
||||||
} else if type(name) == array {
|
} else if type(name) == array {
|
||||||
names = (
|
names = (
|
||||||
(name.at(0), "start"),
|
(name.at(0), "start"),
|
||||||
(name.at(1), "end")
|
(name.at(1), "end"),
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
for (name, pos) in names {
|
for (name, pos) in names {
|
||||||
let point
|
let point
|
||||||
let anchor
|
let anchor
|
||||||
|
|
||||||
if pos == "middle" {
|
if pos == "middle" {
|
||||||
point = (first-pt, 50%, last-pt)
|
point = (first-pt, 50%, last-pt)
|
||||||
anchor = "south"
|
anchor = "south"
|
||||||
@ -248,12 +256,12 @@
|
|||||||
|
|
||||||
if slice != none {
|
if slice != none {
|
||||||
let slice-txt = "[" + slice.map(b => str(b)).join(":") + "]"
|
let slice-txt = "[" + slice.map(b => str(b)).join(":") + "]"
|
||||||
|
|
||||||
draw.content(
|
draw.content(
|
||||||
first-pt,
|
first-pt,
|
||||||
anchor: "south-west",
|
anchor: "south-west",
|
||||||
padding: 3pt,
|
padding: 3pt,
|
||||||
text(slice-txt, size: 0.75em)
|
text(slice-txt, size: 0.75em),
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
@ -267,24 +275,38 @@
|
|||||||
/// - vertical (bool): Whether the name should be displayed vertically
|
/// - vertical (bool): Whether the name should be displayed vertically
|
||||||
/// - length (number): The length of the stub
|
/// - length (number): The length of the stub
|
||||||
/// - name-offset (number): The name offset, perpendicular to the stub
|
/// - name-offset (number): The name offset, perpendicular to the stub
|
||||||
#let stub(port-id, side, name: none, vertical: false, length: 1em, name-offset: 0) = {
|
#let stub(
|
||||||
|
port-id,
|
||||||
|
side,
|
||||||
|
name: none,
|
||||||
|
vertical: false,
|
||||||
|
length: 1em,
|
||||||
|
name-offset: 0,
|
||||||
|
color: black,
|
||||||
|
directed: none,
|
||||||
|
) = {
|
||||||
let end-offset = (
|
let end-offset = (
|
||||||
north: (0, length),
|
north: (0, length),
|
||||||
east: (length, 0),
|
east: (length, 0),
|
||||||
south: (0, -length),
|
south: (0, -length),
|
||||||
west: (-length, 0)
|
west: (-length, 0),
|
||||||
).at(side)
|
).at(side)
|
||||||
|
|
||||||
let name-offset = (
|
let name-offset = (
|
||||||
north: (name-offset, length),
|
north: (name-offset, length),
|
||||||
east: (length, name-offset),
|
east: (length, name-offset),
|
||||||
south: (name-offset, -length),
|
south: (name-offset, -length),
|
||||||
west: (-length, name-offset)
|
west: (-length, name-offset),
|
||||||
).at(side)
|
).at(side)
|
||||||
|
|
||||||
|
let mark = (fill: color)
|
||||||
|
if directed != none {
|
||||||
|
mark = ((directed): ">", fill: color)
|
||||||
|
}
|
||||||
draw.line(
|
draw.line(
|
||||||
port-id,
|
port-id,
|
||||||
(rel: end-offset, to: port-id)
|
(rel: end-offset, to: port-id),
|
||||||
|
mark: mark,
|
||||||
)
|
)
|
||||||
if name != none {
|
if name != none {
|
||||||
let text-anchor = if vertical {
|
let text-anchor = if vertical {
|
||||||
@ -292,15 +314,21 @@
|
|||||||
"north": "west",
|
"north": "west",
|
||||||
"south": "east",
|
"south": "east",
|
||||||
"west": "south",
|
"west": "south",
|
||||||
"east": "north"
|
"east": "north",
|
||||||
).at(side)
|
).at(side)
|
||||||
} else { opposite-anchor(side) }
|
} else {
|
||||||
|
opposite-anchor(side)
|
||||||
|
}
|
||||||
draw.content(
|
draw.content(
|
||||||
anchor: text-anchor,
|
anchor: text-anchor,
|
||||||
padding: 0.2em,
|
padding: 0.2em,
|
||||||
angle: if vertical {90deg} else {0deg},
|
angle: if vertical {
|
||||||
|
90deg
|
||||||
|
} else {
|
||||||
|
0deg
|
||||||
|
},
|
||||||
(rel: name-offset, to: port-id),
|
(rel: name-offset, to: port-id),
|
||||||
name
|
name,
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -1,7 +1,7 @@
|
|||||||
[package]
|
[package]
|
||||||
name = "circuiteria"
|
name = "circuiteria"
|
||||||
version = "0.2.0"
|
version = "0.1.0"
|
||||||
compiler = "0.13.0"
|
compiler = "0.11.0"
|
||||||
repository = "https://git.kb28.ch/HEL/circuiteria"
|
repository = "https://git.kb28.ch/HEL/circuiteria"
|
||||||
entrypoint = "src/lib.typ"
|
entrypoint = "src/lib.typ"
|
||||||
authors = [
|
authors = [
|
||||||
@ -11,4 +11,4 @@ categories = [ "visualization" ]
|
|||||||
license = "Apache-2.0"
|
license = "Apache-2.0"
|
||||||
description = "Drawing block circuits with Typst made easy, using CeTZ"
|
description = "Drawing block circuits with Typst made easy, using CeTZ"
|
||||||
keywords = [ "circuit", "block", "draw" ]
|
keywords = [ "circuit", "block", "draw" ]
|
||||||
exclude = [ "gallery", "justfile", "doc" ]
|
exclude = [ "gallery", "gallery.bash", "doc" ]
|