业务需求:

业务工作中经常需要对表格中的数据进行处理,包括过滤、复合计算等。过滤需要有过滤条件,复合计算需要计算公式。这两种场景都需要一个表达式编辑器。GridControl自带过滤条件的表达式编辑器,我们要做的就是把这个编辑器拿出来,独立于GridControl,进而可以绑定到其它控件上。

实现原理:

找到表达式编辑器内部类UnboundColumnExpressionEditorForm,这是一个窗口类。我们将其边框设置为None,Dock属性设置为Fill,拖放到控件上,使其看上去像个控件,并公布出获取表达式字符串的方法。

代码片段:

public class UnboundExpressionPanel : PanelControl {

      public UnboundExpressionPanel() : base() {

          BorderStyle = DevExpress.XtraEditors.Controls.BorderStyles.NoBorder;

          StartEdit(new GridColumn()); 

      }

 

      object[] arguments;

      protected object[] Arguments { get { return arguments; } }

 

      MyUnboundColumnExpressionEditorForm form = null;

      protected MyUnboundColumnExpressionEditorForm Form { get { return form; } }

 

      private GridColumn fUnboundColumn;

      public GridColumn UnboundColumn {

          get { return fUnboundColumn; }

          set {

              if (fUnboundColumn == value) return;

              StartEdit(value);

          }

      }

 

      protected MyUnboundColumnExpressionEditorForm CreateForm(params object[] arguments)

      {

          return new MyUnboundColumnExpressionEditorForm(arguments[0], null);

      }

 

      protected void ApplyExpression(string expression) {

          if (Arguments == null) return;

          ((GridColumn)Arguments[0]).UnboundExpression = expression;

      }

 

      public void StartEdit(params object[] arguments) {

          if (arguments.Length < 1) return;

          GridColumn unboundColumn = arguments[0] as GridColumn;

          if (unboundColumn == null) return;

          fUnboundColumn = unboundColumn;

          DestroyForm();

          this.arguments = arguments;

          this.form = CreateForm(arguments);

          if (form == null) return;

          form.Dock = DockStyle.Fill;

          form.TopLevel = false;

          form.FormBorderStyle = FormBorderStyle.None;

          form.Closing += new CancelEventHandler(form_Closing);

          form.buttonCancel.Click += new EventHandler(buttonCancel_Click);

          form.buttonOK.Text = "Apply";

          Controls.Add(form);

          form.Visible = true;

      }

 

      void buttonCancel_Click(object sender, EventArgs e)

      {

          if (form != null) form.Close();

      }

 

      void form_Closing(object sender, CancelEventArgs e)

      {

          e.Cancel = true;

          if (this.arguments == null || this.form == null) return;

          if (form.DialogResult == DialogResult.OK)

          {

              ApplyExpression(form.Expression);

          }

          else

          {

              form.ResetMemoText();

          }

      }

 

      public void DestroyForm()

      {

          if (form != null) form.Dispose();

          form = null;

      }

  }

 

  public class MyUnboundColumnExpressionEditorForm : UnboundColumnExpressionEditorForm

  {

      public MyUnboundColumnExpressionEditorForm(object contextInstance, 

          IDesignerHost designerHost) 

          : base(contextInstance, designerHost) { }

 

      private string GetExpressionMemoEditText()

      {

          GridColumn column = ContextInstance as GridColumn;

          return null == column ? string.Empty : column.UnboundExpression;

      }

 

      public void ResetMemoText()

      {

          ExpressionMemoEdit.Text = GetExpressionMemoEditText();

      }

  }

下载地址:

http://pan.baidu.com/s/1sjn24cH

DevExpress控件扩展之表达式编辑器的更多相关文章

  1. 扩展方法实现DevExpress控件校验

    DevExpress控件中,如果要控件的值进行校验,需要用到DXValidationProvider控件和DXErrorProvider控件,按照正常思路,无论使用哪个控件要实现校验效果时都需要对每个 ...

  2. 在Winform开发框架中,利用DevExpress控件实现数据的快速录入和选择

    在实际的项目开发过程中,有好的控件或者功能模块,我都是想办法尽可能集成到我的WInform开发框架中,这样后面开发项目起来,就可以节省很多研究时间,并能重复使用,非常高效方便.在我很早之前的一篇博客& ...

  3. DevExpress控件开发常用要点(项目总结版)

    使用DevExpress控件来做项目开发已经有很长一段时间了,在摸索开发到客户苛刻要求的过程中,其中碰到过很多问题需要解决的,随着一个个问题的解决,也留下很多对DevExpress控件的使用经验及教训 ...

  4. DevExpress控件使用之RichEditControl的使用

    原文:DevExpress控件使用之RichEditControl的使用 做Winform的,我们一般都知道,传统.NET界面有一个RichTextBox控件,这个是一个富文本控件,可以存储图片文字等 ...

  5. DevExpress控件学习总结(转)

    DevExpress控件学习总结   1.Navigation & Layout 1.1 Bar Manager 如果想在窗体或用户控件(user control)上添加工具条(bars)或弹 ...

  6. DevExpress控件的GridControl控件小结

    DevExpress控件的GridControl控件小结 (由于开始使用DevExpress控件了,所以要点滴的记录一下) 1.DevExpress控件组中的GridControl控件不能使横向滚动条 ...

  7. DevExpress控件安装、汉化使用教程

    前言 DevExpress是一个庞大的控件库,也很是好用(没用过,听说),但是要收费. 网上关于DevExpress的教程满天飞,我找了一下午也没找到正确的安装.简单实用教程,还是自己摸索吧. 自己动 ...

  8. DevExpress控件使用经验总结- GridView列表行号显示操作

    DevExpress是一个比较有名的界面控件套件,提供了一系列的界面控件套件的DotNet界面控件.本文主要介绍我在使用DevExpress控件过程中,遇到或者发现的一些问题解决方案,或者也可以所示一 ...

  9. DevExpress控件-- Gridcontrol合并表头

    写在前面的话: 在园子里逛了有一段时间了,一直想写点东西,但苦于自己的水平有限,生怕写出来的东西浪费了读者的时间.楼主有幸参加了公司DevExpress控件的培训,独乐乐不如众乐乐,特附上Demo以飨 ...

随机推荐

  1. 使用gifplayer操作gif的方法

    使用的工具--gifplayer 基本用法: 1.安装 git clone https://github.com/rubentd/gifplayer.git 2.添加一张gif预览的图片 <im ...

  2. 【模板】割点(割顶) Tarjan

    题目背景 割点 题目描述 给出一个nnn个点,mmm条边的无向图,求图的割点. 输入输出格式 输入格式: 第一行输入n,mn,mn,m 下面mmm行每行输入x,yx,yx,y表示xxx到yyy有一条边 ...

  3. phpSpreadSheet 中 使用的 一些坑

    如果是upupw,它 做了 安全限制...将 上传目录 写成 uploadfiles 等 才能 写进去.. 文件路径 也不要有 中文..很有可以能 下载时 找不到路径....这个太坑...

  4. [TJOI2017]DNA (FFT)

    [Luogu3763] FFT做字符串匹配即可,详见代码 // luogu-judger-enable-o2 #include<cstdio> #include<cstring> ...

  5. H - 逆序数(树状数组)

    在一个排列中,如果一对数的前后位置与大小顺序相反,即前面的数大于后面的数,那么它们就称为一个逆序.一个排列中逆序的总数就称为这个排列的逆序数. 如2 4 3 1中,2 1,4 3,4 1,3 1是逆序 ...

  6. Android viewpager + fragment取消预加载

    1,在fragment中重写setUserVisibleHint方法private boolean isVisibleToUser;@Overridepublic void setUserVisibl ...

  7. redis实现SSO单点登录,集群,分布式锁

    https://blog.csdn.net/aussme/article/details/80660443

  8. 服务器报nginx: [warn] conflicting server name "blog.xueyi.com" on 0.0.0.0:80, ignored

    nginx: [warn] conflicting server name "blog.xueyi.com" on 0.0.0.0:80, ignored 修改nginx配置参数后 ...

  9. css连续的纯数字或字母强制换行

    white-space:normal; word-break:break-all; white-space: normal|pre|nowrap|pre-wrap|pre-line|inherit;w ...

  10. Python import搜索路径相关

    import搜索路径 在当前目录下搜索该模块 在环境变量 PYTHONPATH 中指定的路径列表中依次搜索 在 Python 安装路径的 lib 库中搜索 查看当前的搜索路径 import sys p ...