forked from HEL/circuiteria
		
	adapted extender + improved bound anchors
This commit is contained in:
		
										
											Binary file not shown.
										
									
								
							| @@ -77,7 +77,6 @@ | |||||||
|   wire.stub("InstDataMgr.IRWrite") |   wire.stub("InstDataMgr.IRWrite") | ||||||
|   wire.stub("InstDataMgr.WD") |   wire.stub("InstDataMgr.WD") | ||||||
|  |  | ||||||
|   /* |  | ||||||
|   element.block( |   element.block( | ||||||
|     pos: ( |     pos: ( | ||||||
|       15, (align: "WD3", with: "InstDataMgr.RD") |       15, (align: "WD3", with: "InstDataMgr.RD") | ||||||
| @@ -114,7 +113,8 @@ | |||||||
|     pos: (15, -3.5), |     pos: (15, -3.5), | ||||||
|     size: (3, 1), |     size: (3, 1), | ||||||
|     id: "Extender", |     id: "Extender", | ||||||
|     fill: util.colors.green |     fill: util.colors.green, | ||||||
|  |     debug: (bounds: true, ports: true) | ||||||
|   ) |   ) | ||||||
|   wire.wire( |   wire.wire( | ||||||
|     "Extender.north", |     "Extender.north", | ||||||
| @@ -126,6 +126,7 @@ | |||||||
|     bus: true |     bus: true | ||||||
|   ) |   ) | ||||||
|  |  | ||||||
|  |   /* | ||||||
|   let mid = ("InstDataMgr.east", 50%, "RegFile.west") |   let mid = ("InstDataMgr.east", 50%, "RegFile.west") | ||||||
|   wire.wire( |   wire.wire( | ||||||
|     "InstDataMgr.Instr", |     "InstDataMgr.Instr", | ||||||
|   | |||||||
| @@ -209,6 +209,15 @@ | |||||||
|   ) |   ) | ||||||
|   func |   func | ||||||
|  |  | ||||||
|  |   draw.anchor("north", bounds.t) | ||||||
|  |   draw.anchor("south", bounds.b) | ||||||
|  |   draw.anchor("west", bounds.l) | ||||||
|  |   draw.anchor("east", bounds.r) | ||||||
|  |   draw.anchor("north-west", bounds.tl) | ||||||
|  |   draw.anchor("north-east", bounds.tr) | ||||||
|  |   draw.anchor("south-east", bounds.br) | ||||||
|  |   draw.anchor("south-west", bounds.bl) | ||||||
|  |  | ||||||
|   if elmt.name != none { |   if elmt.name != none { | ||||||
|     draw.content( |     draw.content( | ||||||
|       (name: elmt.id, anchor: elmt.name-anchor), |       (name: elmt.id, anchor: elmt.name-anchor), | ||||||
| @@ -219,6 +228,14 @@ | |||||||
|   } |   } | ||||||
|  |  | ||||||
|   add-ports(elmt, bounds) |   add-ports(elmt, bounds) | ||||||
|  |  | ||||||
|  |   if elmt.debug.bounds { | ||||||
|  |     draw.line( | ||||||
|  |       bounds.tl, bounds.tr, bounds.br, bounds.bl, | ||||||
|  |       stroke: red, | ||||||
|  |       close: true | ||||||
|  |     ) | ||||||
|  |   } | ||||||
| }) | }) | ||||||
|  |  | ||||||
| /// Draws an element | /// Draws an element | ||||||
| @@ -263,6 +280,7 @@ | |||||||
|   id: auto, |   id: auto, | ||||||
|   ports-pos: auto, |   ports-pos: auto, | ||||||
|   debug: ( |   debug: ( | ||||||
|  |     bounds: false, | ||||||
|     ports: false |     ports: false | ||||||
|   ), |   ), | ||||||
|   extra: (:) |   extra: (:) | ||||||
| @@ -287,7 +305,6 @@ | |||||||
|     ports.at(key) = side-ports |     ports.at(key) = side-ports | ||||||
|   } |   } | ||||||
|  |  | ||||||
|  |  | ||||||
|   return (( |   return (( | ||||||
|     cls: cls, |     cls: cls, | ||||||
|     id: id, |     id: id, | ||||||
|   | |||||||
| @@ -1,41 +1,25 @@ | |||||||
| #import "@preview/cetz:0.3.2": draw | #import "@preview/cetz:0.3.2": draw | ||||||
| #import "element.typ" | #import "element.typ" | ||||||
| #import "ports.typ": add-port | #import "ports.typ": add-port | ||||||
|  | #import "../util.typ" | ||||||
|  |  | ||||||
| #let draw-shape(id, tl, tr, br, bl, fill, stroke, h-ratio: 75%, align-out: true) = { | #let draw-shape(elmt, bounds) = { | ||||||
|   let (x, y) = bl |   let ratio = elmt.l-ratio / 100% | ||||||
|   let (width, height) = (tr.at(0) - x, tr.at(1) - y) |   let tl2 = util.lerp(bounds.bl, elmt.l-ratio, bounds.tl) | ||||||
|  |   let bounds2 = element.complete-bounds(elmt, ( | ||||||
|  |     tl: tl2, | ||||||
|  |     tr: bounds.tr, | ||||||
|  |     br: bounds.br, | ||||||
|  |     bl: bounds.bl, | ||||||
|  |   )) | ||||||
|  |  | ||||||
|   let ratio = h-ratio / 100% |   let f = draw.line( | ||||||
|  |     bounds2.tl, bounds2.tr, bounds2.br, bounds2.bl, | ||||||
|   tl = (x, y + height * ratio) |     fill: elmt.fill, | ||||||
|   let tr2 = (x + width, y + height * ratio) |     stroke: elmt.stroke, | ||||||
|   let br = (x + width, y) |     close: true | ||||||
|    |   ) | ||||||
|   if align-out { |   return (f, bounds2) | ||||||
|     (tr, tr2) = (tr2, tr) |  | ||||||
|   } else { |  | ||||||
|     (tr, tr2) = (tr, tr) |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   let f = draw.group(name: id, { |  | ||||||
|     draw.merge-path( |  | ||||||
|       inset: 0.5em, |  | ||||||
|       fill: fill, |  | ||||||
|       stroke: stroke, |  | ||||||
|       close: true, |  | ||||||
|       draw.line(tl, tr2, br, bl) |  | ||||||
|     ) |  | ||||||
|     draw.anchor("north", (tl, 50%, tr2)) |  | ||||||
|     draw.anchor("south", (bl, 50%, br)) |  | ||||||
|     draw.anchor("west", (tl, 50%, bl)) |  | ||||||
|     draw.anchor("east", (tr2, 50%, br)) |  | ||||||
|     draw.anchor("north-west", tl) |  | ||||||
|     draw.anchor("north-east", tr2) |  | ||||||
|     draw.anchor("south-east", br) |  | ||||||
|     draw.anchor("south-west", bl) |  | ||||||
|   }) |  | ||||||
|   return (f, tl, tr, br, bl) |  | ||||||
| } | } | ||||||
|  |  | ||||||
| /// Draws a bit extender | /// Draws a bit extender | ||||||
| @@ -45,54 +29,28 @@ | |||||||
| /// - h-ratio (ratio): The height ratio of the left side relative to the full height | /// - h-ratio (ratio): The height ratio of the left side relative to the full height | ||||||
| /// - align-out (bool): If true, the output and input ports are aligned, otherwise, the output port is centered on the right side | /// - align-out (bool): If true, the output and input ports are aligned, otherwise, the output port is centered on the right side | ||||||
| #let extender( | #let extender( | ||||||
|   x: none, |   l-ratio: 75%, | ||||||
|   y: none, |  | ||||||
|   w: none, |  | ||||||
|   h: none, |  | ||||||
|   name: none, |  | ||||||
|   name-anchor: "center", |  | ||||||
|   fill: none, |  | ||||||
|   stroke: black + 1pt, |  | ||||||
|   id: "", |  | ||||||
|   h-ratio: 75%, |  | ||||||
|   align-out: true, |   align-out: true, | ||||||
|   debug: ( |   ..args | ||||||
|     ports: false |  | ||||||
|   ) |  | ||||||
| ) = { | ) = { | ||||||
|   let ports = ( |   let ports = ( | ||||||
|     west: ( |     west: ((id: "in"),), | ||||||
|       (id: "in"), |     east: ((id: "out"),) | ||||||
|     ), |  | ||||||
|     east: ( |  | ||||||
|       (id: "out"), |  | ||||||
|     ) |  | ||||||
|   ) |   ) | ||||||
|   let out-pct = if align-out {h-ratio / 2} else {50%} |   let out-pct = if align-out {l-ratio / 2} else {50%} | ||||||
|   let ports-y = ( |   let ports-pos = ( | ||||||
|     "in": (h) => {h - h * (h-ratio / 200%)}, |     "east": (l, i) => {l - l * (out-pct / 100%)} | ||||||
|     "out": (h) => {h - h * (out-pct / 100%)} |  | ||||||
|   ) |   ) | ||||||
|    |    | ||||||
|   element.elmt( |   return element.elmt( | ||||||
|     draw-shape: draw-shape.with(h-ratio: h-ratio, align-out: align-out), |     cls: "extender", | ||||||
|     x: x, |     draw-shape: draw-shape, | ||||||
|     y: y, |  | ||||||
|     w: w, |  | ||||||
|     h: h, |  | ||||||
|     name: name, |  | ||||||
|     name-anchor: name-anchor, |  | ||||||
|     ports: ports, |     ports: ports, | ||||||
|     auto-ports: false, |     ports-pos: ports-pos, | ||||||
|     ports-y: ports-y, |     extra: ( | ||||||
|     fill: fill, |       l-ratio: l-ratio, | ||||||
|     stroke: stroke, |       align-out: align-out | ||||||
|     id: id, |     ), | ||||||
|     debug: debug |     ..args | ||||||
|   ) |   ) | ||||||
|  |  | ||||||
|   let in-pos = (rel: (0, h * (h-ratio / 200%)), to: id+".south-west") |  | ||||||
|   let out-pos = (id+".south-east", out-pct, id+".north-east") |  | ||||||
|   add-port(id, "west", ports.west.first(), in-pos) |  | ||||||
|   add-port(id, "east", ports.east.first(), out-pos) |  | ||||||
| } | } | ||||||
| @@ -13,23 +13,12 @@ | |||||||
|     tr: tr2, |     tr: tr2, | ||||||
|     br: br2, |     br: br2, | ||||||
|   )) |   )) | ||||||
|   let f = { |   let f = draw.line( | ||||||
|     draw.merge-path( |     bounds2.tl, bounds2.tr, bounds2.br, bounds2.bl, | ||||||
|       inset: 0.5em, |     close: true, | ||||||
|       fill: elmt.fill, |     fill: elmt.fill, | ||||||
|       stroke: elmt.stroke, |     stroke: elmt.stroke | ||||||
|       close: true, |   ) | ||||||
|       draw.line(bounds2.tl, bounds2.tr, bounds2.br, bounds2.bl) |  | ||||||
|     ) |  | ||||||
|     draw.anchor("north", bounds2.t) |  | ||||||
|     draw.anchor("south", bounds2.b) |  | ||||||
|     draw.anchor("west", bounds2.l) |  | ||||||
|     draw.anchor("east", bounds2.r) |  | ||||||
|     draw.anchor("north-west", bounds2.tl) |  | ||||||
|     draw.anchor("north-east", bounds2.tr) |  | ||||||
|     draw.anchor("south-east", bounds2.br) |  | ||||||
|     draw.anchor("south-west", bounds2.bl) |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   return (f, bounds2) |   return (f, bounds2) | ||||||
| } | } | ||||||
|   | |||||||
| @@ -125,7 +125,7 @@ | |||||||
|   elmt, |   elmt, | ||||||
|   bounds |   bounds | ||||||
| ) = { | ) = { | ||||||
|   let debug = elmt.debug.ports |   let debug = elmt.debug.at("ports", default: false) | ||||||
|  |  | ||||||
|   if type(elmt.ports) != dictionary { |   if type(elmt.ports) != dictionary { | ||||||
|     return |     return | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user