业务需求:

业务工作中经常需要对表格中的数据进行处理,包括过滤、复合计算等。过滤需要有过滤条件,复合计算需要计算公式。这两种场景都需要一个表达式编辑器。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. virturalenv 虚拟环境

    一.window系统 1.virtualenv的使用 2.pycharm使用 环境变量,path的作用:命令行中执行的命令,他们的路径,必须在path路径中,如果命令行找不到该命令,就是说path没写 ...

  2. Vue-Router路由Vue-CLI脚手架和模块化开发 之 路由的动态跳转

    在上一篇的博文中,实现的跳转是在页面中进行实现的 利用vue-router实例方法,使用js对路由进行动态跳转: 1.router.push:参数为路由对象,跳转到指定路由,跳转后会产生历史记录: & ...

  3. 富文本编辑器...quill 的使用放...

    移动端 quill 时候用的 是 div 而不是 textarea.... 引入 dom <link href="//cdn.quilljs.com/1.3.6/quill.snow. ...

  4. CPU和微架构的概念

    CPU是什么: 中央处理器(CPU,Central Processing Unit)是一块超大规模的集成电路,是一台计算机的运算核心(Core)和控制核心( Control Unit). 它的功能主要 ...

  5. ORA-14517: Subpartition of index "string.string" is in unusable state

    今天碰到个ORA-03113, 原因不明. 猜测因为某些table DDL操作过后导致index unuable的case, 然后进行analyze table, 再碰到ORA-14517.  最后通 ...

  6. JDK Throwable

    Throwable 1. 使用大量数组和List常量: private static final StackTraceElement[] UNASSIGNED_STACK = new StackTra ...

  7. 在开发系统时候运行程序突然报出“WebDev.WebServer40.exe已停止工作”的错误的解决办法

    问题描述:在开发系统时候运行程序突然报出“WebDev.WebServer40.exe已停止工作”的错误,程序调试运行,发现程序在打开数据库时候报错,也就是Connection.Open()处. 但是 ...

  8. CSS文件的三种引入方式

    CSS的引入方式共有三种:行内样式.内部样式表.外部样式表. 一.行内样式 使用style属性引入CSS样式. 示例:<h1 style="color:red;">st ...

  9. php和c++自带的排序算法

    PHP的 sort() 排序算法与 C++的 sort() 排序算法均为不稳定的排序算法,也就是说,两个值相同的数经过排序后,两者比较过程中还进行了交换位置,后期开发应主要这个问题

  10. 使用EventBus实现兄弟组件之间的通信

    使用EventBus实现兄弟组件之间的通信 需求:为了实现菜单折叠的效果,例如http://blog.gdfengshuo.com/example/work/#/dashboard header组件和 ...