当前位置:   article > 正文

DevExpress WinForms中文教程 - HTML & CSS支持的实战应用(二)

DevExpress WinForms中文教程 - HTML & CSS支持的实战应用(二)

DevExpress WinForms拥有180+组件和UI库,能为Windows Forms平台创建具有影响力的业务解决方案。DevExpress WinForms能完美构建流畅、美观且易于使用的应用程序,无论是Office风格的界面,还是分析处理大批量的业务数据,它都能轻松胜任!

在这篇文章中,我们将概述使用DevExpress WinForms HTML/CSS引擎/模板时重要的注意事项。如果您是DevExpress的新手或正在考虑使用我们的WinForms UI库来开发即将到来的项目,并且尚未了解DevExpress WinForms HTML/CSS功能的潜力,请先花点时间查看以下在线内容:HTML & CSS Markup for WinForms UI | DevExpress

在上文中(点击这里回顾>>)我们主要为大家介绍了如何使用HTML/CSS,本文将继续介绍使用HTML/CSS的一些场景,请继续关注我们哦~

获取DevExpress WinForms最新正式版下载(Q技术交流:532598169)

高级场景

以下使用场景需要具备DevExpress WinForms UI控件和HTML/CSS的高级知识。

创建复杂的数据输入表单(高级)

HTML/CSS模板允许您创建完全自定义的数据表单,如果DevExpress WinForms LayoutControl不能达到您的预期效果,那么我们建议使用HTML/CSS模板。使用HTML/CSS从头开始构建布局可能很耗时,特别是对于具有多个字段的复杂表单。DevExpress的LayoutControl在构建时考虑了可访问性,这包括适当的标签、键盘导航支持以及与屏幕阅读器的兼容性等特性。

DevExpress WinForms中文教程

使用CustomDraw显示交互式元素~(高级)

并非所有的DevExpress WinForms UI控件都支持鼠标事件(出于性能原因),这个限制并不妨碍交互UI元素在DevExpress控件中显示。尽管如此,它确实需要编写更复杂的代码:

  1. DxHtmlPainterContext ctx = new DxHtmlPainterContext();
  2. HtmlTemplate htmlTemplate = new HtmlTemplate(
  3. Loader.Load("ListBoxEmptyForeground.html"),
  4. Loader.Load("ListBoxEmptyForeground.css"));
  5. listControl.CustomDrawEmptyForeground += (s, e) => {
  6. e.DrawHtml(htmlTemplate, ctx);
  7. };
  8. // Handles UI feedback (hover/cursor).
  9. listControl.MouseMove += (s, e) => {
  10. if(listControl.ItemCount == 0) {
  11. ctx.OnMouseMove(e);
  12. listControl.Cursor = ctx.GetCursor(e.Location);
  13. listControl.Invalidate();
  14. }
  15. else listControl.Cursor = Cursors.Default;
  16. };
  17. // Handles Click within the btnAdd element.
  18. var items = Enumerable.Range(1, 10)
  19. .Select(n => string.Format("Item #{0:d2}", n))
  20. .ToArray();
  21. listControl.MouseDown += (s, e) => {
  22. if(listControl.ItemCount == 0 && e.Button == MouseButtons.Left) {
  23. var clickInfo = ctx.CalcHitInfo(e.Location);
  24. if(clickInfo != null && clickInfo.HasId("btnAdd"))
  25. listControl.Items.AddRange(items);
  26. }
  27. };

DevExpress WinForms中文教程

使用CustomDraw显示UI元素并绑定关联状态到数据~(高级)

与静态模板不同,数据感知模板呈现需要编写更多代码(特别是需要从不同的源检索数据时)。下面的示例在Grid单元格中绘制销售徽章,折扣大小是从不同的数据源获得的。

DevExpress WinForms中文教程

  1. using DevExpress.XtraEditors;
  2. using DevExpress.XtraGrid.Views.Grid;
  3. using DevExpress.XtraGrid.Views.Base;
  4. using System.Collections.Generic;
  5. namespace DXApplication {
  6. public partial class Form1 : XtraForm {
  7. Dictionary<string, double> discounts = new Dictionary<string, double>() {
  8. { "A", 0.3 },
  9. { "B", 0.45 },
  10. { "C", 0.2 }
  11. };
  12. public Form1() {
  13. InitializeComponent();
  14. gridControl1.DataSource = new List<Product>() {
  15. new Product(){ Category = "A", Name = "AA", Price = 159.99},
  16. new Product(){ Category = "A", Name = "AB", Price = 159.99},
  17. new Product(){ Category = "B", Name = "BA", Price = 49.99},
  18. new Product(){ Category = "B", Name = "BB", Price = 89.99},
  19. new Product(){ Category = "C", Name = "CA", Price = 799.99},
  20. };
  21. gridView1.CustomDrawCell += GridView1_CustomDrawCell;
  22. }
  23. void GridView1_CustomDrawCell(object sender, RowCellCustomDrawEventArgs e) {
  24. e.DefaultDraw();
  25. e.Handled = true;
  26. GridView view = sender as GridView;
  27. string category = view.GetRowCellValue(e.RowHandle, view.Columns["Category"]) as string;
  28. if (e.Column.FieldName == "Price" && discounts.ContainsKey(category)){
  29. e.DrawHtml(htmlTemplateSaleBadge, args => {
  30. args.SetFieldValue("Discount", discounts[category].ToString("p0"));
  31. });
  32. }
  33. }
  34. }
  35. public class Product {
  36. public string Name { get; set; }
  37. public string Category { get; set; }
  38. public double Price { get; set; }
  39. }
  40. }
使用HTML/CSS创建完全自定义UI控件(高级)

DevExpress WinForms HtmlContentControl是使用HTML-CSS标记构建WinForms UI的“表面”,WinForms HtmlContentPopup是它的弹出菜单版本。这些组件从HTML/CSS代码生成一个WinForms界面,并允许您设计定制的WinForms UI控件。使用DevExpress组件和HTML/CSS创建自定义UI控件是一项高级技术,需要深入了解UI开发的两种技术/细微差别。

DevExpress WinForms中文教程

可视化集合(高级)

数据源可能包括存储项目集合的数据字段:列表、数组、数据集等。<dx-collection>标签是一个唯一的DevExpress元素,它允许您为需要可视化的项指定集合属性(以及必须应用于这些项的模板)。使用自定义标记(如<dx-collection>)会对HTML模板施加特定的要求,以实现适当的功能。

DevExpress WinForms中文教程

使用DevExpress WinForms HTML & CSS引擎时不要做的事
  • 不要创建复杂的嵌套flex布局
    (例如,3个或更多嵌套的flex面板)
  • 不要创建CSS动画
  • 在处理UI控件事件时不要修改HTML元素
  • 不要在基于HTML元素的HTML模板中实现逻辑
    最好在模型中创建一个单独的属性,并在模型中计算逻辑。
  • 不要按原样使用外部资源中预先编写的HTML/CSS代码
    这样的代码可能无法工作,因为不支持所有的HTML标签/属性。

更多DevExpress线上公开课、中文教程资讯请上中文网获取

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/小小林熬夜学编程/article/detail/616910
推荐阅读
相关标签
  

闽ICP备14008679号