ViewExperiments.cs 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462
  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 (1);
  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 += (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 += (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) + 1,
  65. Y = Pos.Bottom (topEdit),
  66. Width = 5
  67. };
  68. rightEdit.TextChanging += (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 += (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 += () => {
  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 = 20,
  122. Y = 0,
  123. Title = "Margin",
  124. Thickness = viewToEdit.Margin.Thickness,
  125. };
  126. marginEditor.ThicknessChanged += (s, a) => {
  127. viewToEdit.Margin.Thickness = a.Thickness;
  128. };
  129. Add (marginEditor);
  130. viewToEdit.BorderFrame.ColorScheme = Colors.ColorSchemes ["Base"];
  131. var borderEditor = new ThicknessEditor () {
  132. X = Pos.Right (marginEditor),
  133. Y = 0,
  134. Title = "Border",
  135. Thickness = viewToEdit.BorderFrame.Thickness,
  136. };
  137. borderEditor.ThicknessChanged += (s, a) => {
  138. viewToEdit.BorderFrame.Thickness = a.Thickness;
  139. };
  140. Add (borderEditor);
  141. viewToEdit.Padding.ColorScheme = Colors.ColorSchemes ["Error"];
  142. var paddingEditor = new ThicknessEditor () {
  143. X = Pos.Right (borderEditor),
  144. Y = 0,
  145. Title = "Padding",
  146. Thickness = viewToEdit.Padding.Thickness,
  147. };
  148. paddingEditor.ThicknessChanged += (s, a) => {
  149. viewToEdit.Padding.Thickness = a.Thickness;
  150. };
  151. Add (paddingEditor);
  152. viewToEdit.Y = Pos.Center () + 4;
  153. Add (new Label ("BorderStyle:"));
  154. var borderStyleEnum = Enum.GetValues (typeof (BorderStyle)).Cast<BorderStyle> ().ToList ();
  155. var rbBorderStyle = new RadioGroup (borderStyleEnum.Select (
  156. e => NStack.ustring.Make (e.ToString ())).ToArray ()) {
  157. X = 2,
  158. Y = 1,
  159. SelectedItem = (int)viewToEdit.BorderFrame.BorderStyle
  160. };
  161. Add (rbBorderStyle);
  162. //rbBorderStyle.SelectedItemChanged += (e) => {
  163. // viewToEdit.BorderFrame.BorderStyle = (BorderStyle)e.SelectedItem;
  164. // viewToEdit.SetNeedsDisplay ();
  165. //};
  166. //Add (new Label ("Background:") {
  167. // Y = 5
  168. //});
  169. //var colorEnum = Enum.GetValues (typeof (Color)).Cast<Color> ().ToList ();
  170. //var rbBackground = new RadioGroup (colorEnum.Select (
  171. // e => NStack.ustring.Make (e.ToString ())).ToArray ()) {
  172. // X = 2,
  173. // Y = 6,
  174. // SelectedItem = (int)viewToEdit.Border.BackgroundColor
  175. //};
  176. //rbBackground.SelectedItemChanged += (e) => {
  177. // if (viewToEdit.Border != null) {
  178. // viewToEdit.Border.BackgroundColor = (Color)e.SelectedItem;
  179. // }
  180. //};
  181. //Add (rbBackground);
  182. //Add (new Label ("BorderBrush:") {
  183. // X = Pos.AnchorEnd (20),
  184. // Y = 5
  185. //});
  186. //var rbBorderBrush = new RadioGroup (colorEnum.Select (
  187. // e => NStack.ustring.Make (e.ToString ())).ToArray ()) {
  188. // X = Pos.AnchorEnd (18),
  189. // Y = 6,
  190. // SelectedItem = (int)viewToEdit.Border.ForgroundColor
  191. //};
  192. //rbBorderBrush.SelectedItemChanged += (e) => {
  193. // if (viewToEdit.Border != null) {
  194. // viewToEdit.Border.ForgroundColor = (Color)e.SelectedItem;
  195. // }
  196. //};
  197. //Add (rbBorderBrush);
  198. Height = 9;
  199. Title = title;
  200. }
  201. }
  202. public override void Init ()
  203. {
  204. Application.Init ();
  205. //Application.Init ();
  206. ConfigurationManager.Themes.Theme = Theme;
  207. ConfigurationManager.Apply ();
  208. Application.Top.ColorScheme = Colors.ColorSchemes [TopLevelColorScheme];
  209. }
  210. public override void Setup ()
  211. {
  212. //ConsoleDriver.Diagnostics |= ConsoleDriver.DiagnosticFlags.FramePadding;
  213. var containerLabel = new Label () {
  214. X = 0,
  215. Y = 0,
  216. Width = Dim.Fill (),
  217. Height = 3,
  218. };
  219. Application.Top.Add (containerLabel);
  220. var view = new View () {
  221. X = 2,
  222. Y = Pos.Bottom (containerLabel),
  223. Height = Dim.Fill (2),
  224. Width = Dim.Fill (2),
  225. Title = "View with 2xMargin, 2xBorder, & 2xPadding",
  226. ColorScheme = Colors.ColorSchemes ["Base"],
  227. };
  228. //Application.Top.Add (view);
  229. //view.InitializeFrames ();
  230. view.Margin.Thickness = new Thickness (2, 2, 2, 2);
  231. view.Margin.ColorScheme = Colors.ColorSchemes ["Toplevel"];
  232. view.Margin.Data = "Margin";
  233. view.BorderFrame.Thickness = new Thickness (2);
  234. view.BorderFrame.BorderStyle = BorderStyle.Single;
  235. view.BorderFrame.ColorScheme = view.ColorScheme;
  236. view.BorderFrame.Data = "BorderFrame";
  237. view.Padding.Thickness = new Thickness (2);
  238. view.Padding.ColorScheme = Colors.ColorSchemes ["Error"];
  239. view.Padding.Data = "Padding";
  240. var view2 = new View () {
  241. X = 2,
  242. Y = 3,
  243. Height = 7,
  244. Width = 17,
  245. Title = "View2",
  246. Text = "View #2",
  247. TextAlignment = TextAlignment.Centered
  248. };
  249. //view2.InitializeFrames ();
  250. view2.Margin.Thickness = new Thickness (1);
  251. view2.Margin.ColorScheme = Colors.ColorSchemes ["Toplevel"];
  252. view2.Margin.Data = "Margin";
  253. view2.BorderFrame.Thickness = new Thickness (1);
  254. view2.BorderFrame.BorderStyle = BorderStyle.Single;
  255. view2.BorderFrame.ColorScheme = view.ColorScheme;
  256. view2.BorderFrame.Data = "BorderFrame";
  257. view2.Padding.Thickness = new Thickness (1);
  258. view2.Padding.ColorScheme = Colors.ColorSchemes ["Error"];
  259. view2.Padding.Data = "Padding";
  260. view.Add (view2);
  261. var view3 = new View () {
  262. X = Pos.Right (view2) + 1,
  263. Y = 3,
  264. Height = 5,
  265. Width = 37,
  266. Title = "View3",
  267. Text = "View #3 (Right(view2)+1",
  268. TextAlignment = TextAlignment.Centered
  269. };
  270. //view3.InitializeFrames ();
  271. view3.Margin.Thickness = new Thickness (1, 1, 0, 0);
  272. view3.Margin.ColorScheme = Colors.ColorSchemes ["Toplevel"];
  273. view3.Margin.Data = "Margin";
  274. view3.BorderFrame.Thickness = new Thickness (1, 1, 1, 1);
  275. view3.BorderFrame.BorderStyle = BorderStyle.Single;
  276. view3.BorderFrame.ColorScheme = view.ColorScheme;
  277. view3.BorderFrame.Data = "BorderFrame";
  278. view3.Padding.Thickness = new Thickness (1, 1, 0, 0);
  279. view3.Padding.ColorScheme = Colors.ColorSchemes ["Error"];
  280. view3.Padding.Data = "Padding";
  281. view.Add (view3);
  282. var view4 = new View () {
  283. X = Pos.Right (view3) + 1,
  284. Y = 3,
  285. Height = 5,
  286. Width = 37,
  287. Title = "View4",
  288. Text = "View #4 (Right(view3)+1",
  289. TextAlignment = TextAlignment.Centered
  290. };
  291. //view4.InitializeFrames ();
  292. view4.Margin.Thickness = new Thickness (0, 0, 1, 1);
  293. view4.Margin.ColorScheme = Colors.ColorSchemes ["Toplevel"];
  294. view4.Margin.Data = "Margin";
  295. view4.BorderFrame.Thickness = new Thickness (1, 1, 1, 1);
  296. view4.BorderFrame.BorderStyle = BorderStyle.Single;
  297. view4.BorderFrame.ColorScheme = view.ColorScheme;
  298. view4.BorderFrame.Data = "BorderFrame";
  299. view4.Padding.Thickness = new Thickness (0, 0, 1, 1);
  300. view4.Padding.ColorScheme = Colors.ColorSchemes ["Error"];
  301. view4.Padding.Data = "Padding";
  302. view.Add (view4);
  303. var view5 = new View () {
  304. X = Pos.Right (view4) + 1,
  305. Y = 3,
  306. Height = Dim.Fill (2),
  307. Width = Dim.Fill (),
  308. Title = "View5",
  309. Text = "View #5 (Right(view4)+1 Fill",
  310. TextAlignment = TextAlignment.Centered
  311. };
  312. //view5.InitializeFrames ();
  313. view5.Margin.Thickness = new Thickness (0, 0, 0, 0);
  314. view5.Margin.ColorScheme = Colors.ColorSchemes ["Toplevel"];
  315. view5.Margin.Data = "Margin";
  316. view5.BorderFrame.Thickness = new Thickness (1, 1, 1, 1);
  317. view5.BorderFrame.BorderStyle = BorderStyle.Single;
  318. view5.BorderFrame.ColorScheme = view.ColorScheme;
  319. view5.BorderFrame.Data = "BorderFrame";
  320. view5.Padding.Thickness = new Thickness (0, 0, 0, 0);
  321. view5.Padding.ColorScheme = Colors.ColorSchemes ["Error"];
  322. view5.Padding.Data = "Padding";
  323. view.Add (view5);
  324. var label = new Label () {
  325. Text = "AutoSize true; 1;1:",
  326. AutoSize = true,
  327. X = 1,
  328. Y = 1,
  329. };
  330. view.Add (label);
  331. var edit = new TextField () {
  332. Text = "Right (label)",
  333. X = Pos.Right (label),
  334. Y = 1,
  335. Width = 15,
  336. Height = 1
  337. };
  338. view.Add (edit);
  339. edit = new TextField () {
  340. Text = "Right (edit) + 1",
  341. X = Pos.Right (edit) + 1,
  342. Y = 1,
  343. Width = 20,
  344. Height = 1
  345. };
  346. view.Add (edit);
  347. edit = new TextField () {
  348. Text = "Center();50%",
  349. X = Pos.Center (),
  350. Y = Pos.Percent (50),
  351. Width = 30,
  352. Height = 1
  353. };
  354. view.Add (edit);
  355. edit = new TextField () {
  356. Text = "Center() - 1;60%",
  357. X = Pos.Center () - 1,
  358. Y = Pos.Percent (60),
  359. Width = 30,
  360. Height = 1
  361. };
  362. view.Add (edit);
  363. edit = new TextField () {
  364. Text = "0 + Percent(50);70%",
  365. X = 0 + Pos.Percent (50),
  366. Y = Pos.Percent (70),
  367. Width = 30,
  368. Height = 1
  369. };
  370. view.Add (edit);
  371. edit = new TextField () {
  372. Text = "AnchorEnd[Right];AnchorEnd (1)",
  373. Y = Pos.AnchorEnd (1),
  374. Width = 30,
  375. Height = 1
  376. };
  377. edit.X = Pos.AnchorEnd () - (Pos.Right (edit) - Pos.Left (edit));
  378. view.Add (edit);
  379. edit = new TextField () {
  380. Text = "Left;AnchorEnd (2)",
  381. X = 0,
  382. Y = Pos.AnchorEnd (2),
  383. Width = 30,
  384. Height = 1
  385. };
  386. view.Add (edit);
  387. containerLabel.LayoutComplete += (a) => {
  388. containerLabel.Text = $"Container.Frame: {Application.Top.Frame} .Bounds: {Application.Top.Bounds}\nView.Frame: {view.Frame} .Bounds: {view.Bounds}\nView.ContentArea: {view.ContentArea}";
  389. };
  390. view.X = Pos.Center ();
  391. var editor = new FramesEditor ($"Frame Editor", view) {
  392. X = 0,
  393. Y = Pos.Bottom (containerLabel),
  394. Width = Dim.Fill (),
  395. };
  396. Application.Top.Add (editor);
  397. view.Y = Pos.Bottom (editor);
  398. view.Width = Dim.Fill ();
  399. view.Height = Dim.Fill ();
  400. Application.Top.Add (view);
  401. }
  402. }
  403. }