ViewExperiments.cs 12 KB

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