|
@@ -0,0 +1,158 @@
|
|
|
+# DTui
|
|
|
+🚧 WIP 🚧 Terminal user interface library for D language
|
|
|
+
|
|
|
+# About
|
|
|
+DTui is a terminal user interface (TUI) library for D language that I am working on in my free time to help better understand D.
|
|
|
+
|
|
|
+_Keep in mind:_
|
|
|
+
|
|
|
+1. The library's first version has not been released yet.
|
|
|
+
|
|
|
+2. Note that I am new to D so this is not a professional project.
|
|
|
+
|
|
|
+3. Output images are in the IntelliJ IDEA 'Run' window.
|
|
|
+
|
|
|
+# Controls
|
|
|
+
|
|
|
+### Tree
|
|
|
+
|
|
|
+#### Construction:
|
|
|
+
|
|
|
+```D
|
|
|
+void main() {
|
|
|
+ Canvas canvas = new Canvas();
|
|
|
+
|
|
|
+ Tree tree = new Tree(Node("A", Node("B1", Node("C1"), Node("C2")), Node("B2", Node("D1"), Node("D2")), Node("B3", Node("E1"), Node("E2"))));
|
|
|
+
|
|
|
+ canvas.updateCache(tree, Coordinate(0, 0));
|
|
|
+ canvas.drawCache();
|
|
|
+}
|
|
|
+```
|
|
|
+
|
|
|
+#### Output:
|
|
|
+
|
|
|
+data:image/s3,"s3://crabby-images/2cebc/2cebcacc7376beff9411be317d9070251282b003" alt="image"
|
|
|
+
|
|
|
+### Chart
|
|
|
+
|
|
|
+#### Construction:
|
|
|
+
|
|
|
+```D
|
|
|
+void main() {
|
|
|
+ Canvas canvas = new Canvas();
|
|
|
+
|
|
|
+ Chart chart = new Chart(ChartType.column, [1, 4, 9, 2], 3, 1, Color.Red);
|
|
|
+
|
|
|
+ canvas.updateCache(chart, Coordinate(0, 0));
|
|
|
+ canvas.drawCache();
|
|
|
+}
|
|
|
+```
|
|
|
+
|
|
|
+#### Output:
|
|
|
+
|
|
|
+data:image/s3,"s3://crabby-images/70e02/70e025dd2a41fdf8b1a8e0b789234446e6797bfd" alt="image"
|
|
|
+
|
|
|
+### Rect (with fill)
|
|
|
+
|
|
|
+#### Construction
|
|
|
+
|
|
|
+```D
|
|
|
+void main() {
|
|
|
+ Canvas canvas = new Canvas();
|
|
|
+
|
|
|
+ Rect rect = Rect.withFill(Dimensions(20, 10), Color.Orange);
|
|
|
+
|
|
|
+ canvas.updateCache(rect, Coordinate(0, 0));
|
|
|
+ canvas.drawCache();
|
|
|
+}
|
|
|
+```
|
|
|
+
|
|
|
+#### Output:
|
|
|
+
|
|
|
+data:image/s3,"s3://crabby-images/b2ac4/b2ac45b96bb0a65ebb9f2fdc8d5d5e1c85518bfa" alt="image"
|
|
|
+
|
|
|
+### Rect (with frame)
|
|
|
+
|
|
|
+#### Construction
|
|
|
+
|
|
|
+```D
|
|
|
+void main() {
|
|
|
+ Canvas canvas = new Canvas();
|
|
|
+
|
|
|
+ Rect rect = Rect.withFrame(Dimensions(20, 10), Color.Blue);
|
|
|
+
|
|
|
+ canvas.updateCache(rect, Coordinate(0, 0));
|
|
|
+ canvas.drawCache();
|
|
|
+}
|
|
|
+```
|
|
|
+
|
|
|
+#### Output
|
|
|
+
|
|
|
+data:image/s3,"s3://crabby-images/9b60d/9b60dab4390ad2301e83d42738a70dbc7006059f" alt="image"
|
|
|
+
|
|
|
+### Table
|
|
|
+
|
|
|
+#### Construction
|
|
|
+
|
|
|
+```D
|
|
|
+void main() {
|
|
|
+ Canvas canvas = new Canvas();
|
|
|
+
|
|
|
+ Table table = new Table(10, 5);
|
|
|
+
|
|
|
+ canvas.updateCache(table, Coordinate(0, 0));
|
|
|
+ canvas.drawCache();
|
|
|
+}
|
|
|
+```
|
|
|
+
|
|
|
+#### Output
|
|
|
+
|
|
|
+data:image/s3,"s3://crabby-images/d03b4/d03b4373b0f1b9a9fe32e13c245b6b6f72efb3c6" alt="image"
|
|
|
+
|
|
|
+### Label
|
|
|
+
|
|
|
+#### Construction
|
|
|
+
|
|
|
+```D
|
|
|
+void main() {
|
|
|
+ Canvas canvas = new Canvas();
|
|
|
+
|
|
|
+ Label label = new Label(Rect.withFill(Dimension.block(30, 11), Color.Black), "Hello World!", Color.Orange);
|
|
|
+
|
|
|
+ canvas.updateCache(label, Coordinate(0, 0));
|
|
|
+ canvas.drawCache();
|
|
|
+}
|
|
|
+```
|
|
|
+
|
|
|
+#### Output
|
|
|
+
|
|
|
+data:image/s3,"s3://crabby-images/700f8/700f82ee873a1b8ad5a58a1fd30e129dcc6572e6" alt="image"
|
|
|
+
|
|
|
+### StackLayout
|
|
|
+
|
|
|
+#### Construction
|
|
|
+
|
|
|
+```D
|
|
|
+void main() {
|
|
|
+ Canvas canvas = new Canvas();
|
|
|
+
|
|
|
+ Rect rectr = Rect.withFill(Dimension(10, 10), Color.Blue);
|
|
|
+ Rect rectb = Rect.withFill(Dimension(10, 10), Color.Red);
|
|
|
+
|
|
|
+ StackLayout row = new StackLayout(StackLayoutType.row);
|
|
|
+
|
|
|
+ row.add(rectr, rectb, rectr, rectb, rectr);
|
|
|
+
|
|
|
+ canvas.updateCache(row, Coordinate(0, 0));
|
|
|
+ canvas.drawCache();
|
|
|
+}
|
|
|
+```
|
|
|
+
|
|
|
+#### Output
|
|
|
+
|
|
|
+data:image/s3,"s3://crabby-images/34560/345609b6ebfd1bab501b68cbb2e580777a0423ec" alt="image"
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|