ViewExperiments.cs 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475
  1. using System;
  2. using System.Linq;
  3. using Terminal.Gui;
  4. using Terminal.Gui.Configuration;
  5. namespace UICatalog.Scenarios {
  6. [ScenarioMetadata (Name: "_ View Experiments", Description: "v2 View Experiments")]
  7. [ScenarioCategory ("Controls")]
  8. public class ViewExperiments : Scenario {
  9. public class ThicknessEditor : View {
  10. private Thickness thickness;
  11. public Thickness Thickness {
  12. get => thickness;
  13. set {
  14. thickness = value;
  15. ThicknessChanged?.Invoke (this, new ThicknessEventArgs () { Thickness = Thickness });
  16. }
  17. }
  18. public event EventHandler<ThicknessEventArgs> ThicknessChanged;
  19. public ThicknessEditor ()
  20. {
  21. Margin.Thickness = new Thickness (0);
  22. BorderFrame.Thickness = new Thickness (1);
  23. }
  24. public override void BeginInit ()
  25. {
  26. base.BeginInit ();
  27. var topEdit = new TextField ("") {
  28. X = Pos.Center (),
  29. Y = 0,
  30. Width = 5
  31. };
  32. topEdit.TextChanging += (s, e) => {
  33. try {
  34. Thickness = new Thickness (Thickness.Left,
  35. int.Parse (e.NewText.ToString ()), Thickness.Right,
  36. Thickness.Bottom);
  37. } catch {
  38. if (!e.NewText.IsEmpty) {
  39. e.Cancel = true;
  40. }
  41. }
  42. };
  43. topEdit.Text = $"{Thickness.Top}";
  44. Add (topEdit);
  45. var leftEdit = new TextField ("") {
  46. X = 0,
  47. Y = Pos.Bottom (topEdit),
  48. Width = 5
  49. };
  50. leftEdit.TextChanging += (s, e) => {
  51. try {
  52. Thickness = new Thickness (int.Parse (e.NewText.ToString ()),
  53. Thickness.Top, Thickness.Right,
  54. Thickness.Bottom);
  55. } catch {
  56. if (!e.NewText.IsEmpty) {
  57. e.Cancel = true;
  58. }
  59. }
  60. };
  61. leftEdit.Text = $"{Thickness.Left}";
  62. Add (leftEdit);
  63. var rightEdit = new TextField ("") {
  64. X = Pos.Right (topEdit),
  65. Y = Pos.Bottom (topEdit),
  66. Width = 5
  67. };
  68. rightEdit.TextChanging += (s, e) => {
  69. try {
  70. Thickness = new Thickness (Thickness.Left,
  71. Thickness.Top, int.Parse (e.NewText.ToString ()),
  72. Thickness.Bottom);
  73. } catch {
  74. if (!e.NewText.IsEmpty) {
  75. e.Cancel = true;
  76. }
  77. }
  78. };
  79. rightEdit.Text = $"{Thickness.Right}";
  80. Add (rightEdit);
  81. var bottomEdit = new TextField ("") {
  82. X = Pos.Center (),
  83. Y = Pos.Bottom (leftEdit),
  84. Width = 5
  85. };
  86. bottomEdit.TextChanging += (s, e) => {
  87. try {
  88. Thickness = new Thickness (Thickness.Left,
  89. Thickness.Top, Thickness.Right,
  90. int.Parse (e.NewText.ToString ()));
  91. } catch {
  92. if (!e.NewText.IsEmpty) {
  93. e.Cancel = true;
  94. }
  95. }
  96. };
  97. bottomEdit.Text = $"{Thickness.Bottom}";
  98. Add (bottomEdit);
  99. var copyTop = new Button ("Copy Top") {
  100. X = Pos.Center (),
  101. Y = Pos.AnchorEnd (1)
  102. };
  103. copyTop.Clicked += (s, e) => {
  104. Thickness = new Thickness (Thickness.Top);
  105. if (topEdit.Text.IsEmpty) {
  106. topEdit.Text = "0";
  107. }
  108. bottomEdit.Text = leftEdit.Text = rightEdit.Text = topEdit.Text;
  109. };
  110. Add (copyTop);
  111. LayoutSubviews ();
  112. Height = Margin.Thickness.Vertical + BorderFrame.Thickness.Vertical + Padding.Thickness.Vertical + 4;
  113. Width = 20;
  114. }
  115. }
  116. public class FramesEditor : Window {
  117. public FramesEditor (NStack.ustring title, View viewToEdit)
  118. {
  119. viewToEdit.Margin.ColorScheme = Colors.ColorSchemes ["Toplevel"];
  120. var marginEditor = new ThicknessEditor () {
  121. X = 0,
  122. Y = 0,
  123. Title = "Margin",
  124. Thickness = viewToEdit.Margin.Thickness,
  125. };
  126. marginEditor.Margin.Thickness = new Thickness (0, 0, 1, 0);
  127. marginEditor.ThicknessChanged += (s, a) => {
  128. viewToEdit.Margin.Thickness = a.Thickness;
  129. };
  130. Add (marginEditor);
  131. viewToEdit.BorderFrame.ColorScheme = Colors.ColorSchemes ["Base"];
  132. var borderEditor = new ThicknessEditor () {
  133. X = Pos.Right (marginEditor),
  134. Y = 0,
  135. Title = "Border",
  136. Thickness = viewToEdit.BorderFrame.Thickness,
  137. };
  138. borderEditor.Margin.Thickness = new Thickness (0, 0, 1, 0);
  139. borderEditor.ThicknessChanged += (s, a) => {
  140. viewToEdit.BorderFrame.Thickness = a.Thickness;
  141. };
  142. Add (borderEditor);
  143. var styleLabel = new Label ("BorderStyle: ") {
  144. X = Pos.Right (borderEditor),
  145. Y = 0
  146. };
  147. Add (styleLabel);
  148. var borderStyleEnum = Enum.GetValues (typeof (BorderStyle)).Cast<BorderStyle> ().ToList ();
  149. var rbBorderStyle = new RadioGroup (borderStyleEnum.Select (
  150. e => NStack.ustring.Make (e.ToString ())).ToArray ()) {
  151. X = Pos.Left (styleLabel),
  152. Y = Pos.Bottom (styleLabel),
  153. SelectedItem = (int)viewToEdit.BorderFrame.BorderStyle
  154. };
  155. rbBorderStyle.SelectedItemChanged += (s, e) => {
  156. viewToEdit.BorderFrame.BorderStyle = (BorderStyle)e.SelectedItem;
  157. viewToEdit.SetNeedsDisplay ();
  158. };
  159. Add (rbBorderStyle);
  160. viewToEdit.Padding.ColorScheme = Colors.ColorSchemes ["Error"];
  161. var paddingEditor = new ThicknessEditor () {
  162. X = Pos.Right (styleLabel),
  163. Y = 0,
  164. Title = "Padding",
  165. Thickness = viewToEdit.Padding.Thickness,
  166. };
  167. paddingEditor.ThicknessChanged += (s, a) => {
  168. viewToEdit.Padding.Thickness = a.Thickness;
  169. };
  170. Add (paddingEditor);
  171. viewToEdit.Y = Pos.Center () + 4;
  172. //rbBorderStyle.SelectedItemChanged += (e) => {
  173. // viewToEdit.BorderFrame.BorderStyle = (BorderStyle)e.SelectedItem;
  174. // viewToEdit.SetNeedsDisplay ();
  175. //};
  176. //Add (new Label ("Background:") {
  177. // Y = 5
  178. //});
  179. //var colorEnum = Enum.GetValues (typeof (Color)).Cast<Color> ().ToList ();
  180. //var rbBackground = new RadioGroup (colorEnum.Select (
  181. // e => NStack.ustring.Make (e.ToString ())).ToArray ()) {
  182. // X = 2,
  183. // Y = 6,
  184. // SelectedItem = (int)viewToEdit.Border.BackgroundColor
  185. //};
  186. //rbBackground.SelectedItemChanged += (e) => {
  187. // if (viewToEdit.Border != null) {
  188. // viewToEdit.Border.BackgroundColor = (Color)e.SelectedItem;
  189. // }
  190. //};
  191. //Add (rbBackground);
  192. //Add (new Label ("BorderBrush:") {
  193. // X = Pos.AnchorEnd (20),
  194. // Y = 5
  195. //});
  196. //var rbBorderBrush = new RadioGroup (colorEnum.Select (
  197. // e => NStack.ustring.Make (e.ToString ())).ToArray ()) {
  198. // X = Pos.AnchorEnd (18),
  199. // Y = 6,
  200. // SelectedItem = (int)viewToEdit.Border.ForgroundColor
  201. //};
  202. //rbBorderBrush.SelectedItemChanged += (e) => {
  203. // if (viewToEdit.Border != null) {
  204. // viewToEdit.Border.ForgroundColor = (Color)e.SelectedItem;
  205. // }
  206. //};
  207. //Add (rbBorderBrush);
  208. Height = 8;
  209. Title = title;
  210. }
  211. }
  212. public override void Init ()
  213. {
  214. Application.Init ();
  215. //Application.Init ();
  216. ConfigurationManager.Themes.Theme = Theme;
  217. ConfigurationManager.Apply ();
  218. Application.Top.ColorScheme = Colors.ColorSchemes [TopLevelColorScheme];
  219. }
  220. public override void Setup ()
  221. {
  222. //ConsoleDriver.Diagnostics |= ConsoleDriver.DiagnosticFlags.FramePadding;
  223. var containerLabel = new Label () {
  224. X = 0,
  225. Y = 0,
  226. Width = Dim.Fill (),
  227. Height = 3,
  228. };
  229. Application.Top.Add (containerLabel);
  230. var view = new View () {
  231. X = 2,
  232. Y = Pos.Bottom (containerLabel),
  233. Height = Dim.Fill (2),
  234. Width = Dim.Fill (2),
  235. Title = "View with 2xMargin, 2xBorder, & 2xPadding",
  236. ColorScheme = Colors.ColorSchemes ["Base"],
  237. Id = "DaView"
  238. };
  239. //Application.Top.Add (view);
  240. //view.InitializeFrames ();
  241. view.Margin.Thickness = new Thickness (2, 2, 2, 2);
  242. view.Margin.ColorScheme = Colors.ColorSchemes ["Toplevel"];
  243. view.Margin.Data = "Margin";
  244. view.BorderFrame.Thickness = new Thickness (2);
  245. view.BorderFrame.BorderStyle = BorderStyle.Single;
  246. view.BorderFrame.ColorScheme = view.ColorScheme;
  247. view.BorderFrame.Data = "BorderFrame";
  248. view.Padding.Thickness = new Thickness (2);
  249. view.Padding.ColorScheme = Colors.ColorSchemes ["Error"];
  250. view.Padding.Data = "Padding";
  251. var view2 = new View () {
  252. X = 2,
  253. Y = 3,
  254. Height = 7,
  255. Width = 17,
  256. Title = "View2",
  257. Text = "View #2",
  258. TextAlignment = TextAlignment.Centered
  259. };
  260. //view2.InitializeFrames ();
  261. view2.Margin.Thickness = new Thickness (1);
  262. view2.Margin.ColorScheme = Colors.ColorSchemes ["Toplevel"];
  263. view2.Margin.Data = "Margin";
  264. view2.BorderFrame.Thickness = new Thickness (1);
  265. view2.BorderFrame.BorderStyle = BorderStyle.Single;
  266. view2.BorderFrame.ColorScheme = view.ColorScheme;
  267. view2.BorderFrame.Data = "BorderFrame";
  268. view2.Padding.Thickness = new Thickness (1);
  269. view2.Padding.ColorScheme = Colors.ColorSchemes ["Error"];
  270. view2.Padding.Data = "Padding";
  271. view.Add (view2);
  272. var view3 = new View () {
  273. X = Pos.Right (view2) + 1,
  274. Y = 3,
  275. Height = 5,
  276. Width = 37,
  277. Title = "View3",
  278. Text = "View #3 (Right(view2)+1",
  279. TextAlignment = TextAlignment.Centered
  280. };
  281. //view3.InitializeFrames ();
  282. view3.Margin.Thickness = new Thickness (1, 1, 0, 0);
  283. view3.Margin.ColorScheme = Colors.ColorSchemes ["Toplevel"];
  284. view3.Margin.Data = "Margin";
  285. view3.BorderFrame.Thickness = new Thickness (1, 1, 1, 1);
  286. view3.BorderFrame.BorderStyle = BorderStyle.Single;
  287. view3.BorderFrame.ColorScheme = view.ColorScheme;
  288. view3.BorderFrame.Data = "BorderFrame";
  289. view3.Padding.Thickness = new Thickness (1, 1, 0, 0);
  290. view3.Padding.ColorScheme = Colors.ColorSchemes ["Error"];
  291. view3.Padding.Data = "Padding";
  292. view.Add (view3);
  293. var view4 = new View () {
  294. X = Pos.Right (view3) + 1,
  295. Y = 3,
  296. Height = 5,
  297. Width = 37,
  298. Title = "View4",
  299. Text = "View #4 (Right(view3)+1",
  300. TextAlignment = TextAlignment.Centered
  301. };
  302. //view4.InitializeFrames ();
  303. view4.Margin.Thickness = new Thickness (0, 0, 1, 1);
  304. view4.Margin.ColorScheme = Colors.ColorSchemes ["Toplevel"];
  305. view4.Margin.Data = "Margin";
  306. view4.BorderFrame.Thickness = new Thickness (1, 1, 1, 1);
  307. view4.BorderFrame.BorderStyle = BorderStyle.Single;
  308. view4.BorderFrame.ColorScheme = view.ColorScheme;
  309. view4.BorderFrame.Data = "BorderFrame";
  310. view4.Padding.Thickness = new Thickness (0, 0, 1, 1);
  311. view4.Padding.ColorScheme = Colors.ColorSchemes ["Error"];
  312. view4.Padding.Data = "Padding";
  313. view.Add (view4);
  314. var view5 = new View () {
  315. X = Pos.Right (view4) + 1,
  316. Y = 3,
  317. Height = Dim.Fill (2),
  318. Width = Dim.Fill (),
  319. Title = "View5",
  320. Text = "View #5 (Right(view4)+1 Fill",
  321. TextAlignment = TextAlignment.Centered
  322. };
  323. //view5.InitializeFrames ();
  324. view5.Margin.Thickness = new Thickness (0, 0, 0, 0);
  325. view5.Margin.ColorScheme = Colors.ColorSchemes ["Toplevel"];
  326. view5.Margin.Data = "Margin";
  327. view5.BorderFrame.Thickness = new Thickness (1, 1, 1, 1);
  328. view5.BorderFrame.BorderStyle = BorderStyle.Single;
  329. view5.BorderFrame.ColorScheme = view.ColorScheme;
  330. view5.BorderFrame.Data = "BorderFrame";
  331. view5.Padding.Thickness = new Thickness (0, 0, 0, 0);
  332. view5.Padding.ColorScheme = Colors.ColorSchemes ["Error"];
  333. view5.Padding.Data = "Padding";
  334. view.Add (view5);
  335. var label = new Label () {
  336. Text = "AutoSize true; 1;1:",
  337. AutoSize = true,
  338. X = 1,
  339. Y = 1,
  340. };
  341. view.Add (label);
  342. var edit = new TextField () {
  343. Text = "Right (label)",
  344. X = Pos.Right (label),
  345. Y = 1,
  346. Width = 15,
  347. Height = 1
  348. };
  349. view.Add (edit);
  350. edit = new TextField () {
  351. Text = "Right (edit) + 1",
  352. X = Pos.Right (edit) + 1,
  353. Y = 1,
  354. Width = 20,
  355. Height = 1
  356. };
  357. view.Add (edit);
  358. edit = new TextField () {
  359. Text = "Center();50%",
  360. X = Pos.Center (),
  361. Y = Pos.Percent (50),
  362. Width = 30,
  363. Height = 1
  364. };
  365. view.Add (edit);
  366. edit = new TextField () {
  367. Text = "Center() - 1;60%",
  368. X = Pos.Center () - 1,
  369. Y = Pos.Percent (60),
  370. Width = 30,
  371. Height = 1
  372. };
  373. view.Add (edit);
  374. edit = new TextField () {
  375. Text = "0 + Percent(50);70%",
  376. X = 0 + Pos.Percent (50),
  377. Y = Pos.Percent (70),
  378. Width = 30,
  379. Height = 1
  380. };
  381. view.Add (edit);
  382. edit = new TextField () {
  383. Text = "AnchorEnd[Right];AnchorEnd (1)",
  384. Y = Pos.AnchorEnd (1),
  385. Width = 30,
  386. Height = 1
  387. };
  388. edit.X = Pos.AnchorEnd () - (Pos.Right (edit) - Pos.Left (edit));
  389. view.Add (edit);
  390. edit = new TextField () {
  391. Text = "Left;AnchorEnd (2)",
  392. X = 0,
  393. Y = Pos.AnchorEnd (2),
  394. Width = 30,
  395. Height = 1
  396. };
  397. view.Add (edit);
  398. view.LayoutComplete += (s, e) => {
  399. containerLabel.Text = $"Container.Frame: {Application.Top.Frame} .Bounds: {Application.Top.Bounds}\nView.Frame: {view.Frame} .Bounds: {view.Bounds} .BoundsOffset: {view.GetBoundsOffset ()}\n .Padding.Frame: {view.Padding.Frame} .Padding.Bounds: {view.Padding.Bounds}";
  400. };
  401. view.X = Pos.Center ();
  402. var editor = new FramesEditor ($"Frame Editor", view) {
  403. X = 0,
  404. Y = Pos.Bottom (containerLabel),
  405. Width = Dim.Fill (),
  406. };
  407. Application.Top.Add (editor);
  408. view.Y = Pos.Bottom (editor);
  409. view.Width = Dim.Fill ();
  410. view.Height = Dim.Fill ();
  411. Application.Top.Add (view);
  412. }
  413. }
  414. }