业务需求:

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

    heap堆分配在用户层面:malloc函数用于heap内存分配 void* malloc(size_t size); 进程的虚拟内存地址布局: 对用户来说,主要关注的空间是User Space.将Us ...

  2. linode出现以下报错

    Linode Manager 报错 系统重新安装后 解决办法执行  rm -rf ~/.ssh/known_hosts 再继续执行:ssh root@72.14.189.163

  3. elasticsearch 相关命令

    ubuntu server 启动命令:$ ./bin/elasticsearch 后台运行:$ ./bin/elasticsearch -d 查看当前进程:$ jps 启动后检查是否成功命令:$ cu ...

  4. POJ 3252 区间内一个数的二进制中0的数量要不能少于1的数量(数位DP)

    题意:求区间内二进制中0的数量要不能少于1的数量 分析:很明显的是数位DP: 菜鸟me : 整体上是和数位dp模板差不多的 , 需要注意的是这里有前导零的影响 , 所以需要在dfs()里面增加zor ...

  5. jQuery 全屏滚动插件 fullPage.js 参数说明

    fullPage.js 是一个基于 jQuery 的插件,它能够很方便.很轻松的制作出全屏网站,主要功能有: 支持鼠标滚动 支持前进后退和键盘控制 多个回调函数 支持手机.平板触摸事件 支持 CSS3 ...

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

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

  7. array.map

    定义和用法 map() 方法返回一个新数组,数组中的元素为原始数组元素调用函数处理后的值. map() 方法按照原始数组元素顺序依次处理元素. 注意: map() 不会对空数组进行检测. 注意: ma ...

  8. Mybatis学习笔记11 - 动态sql之trim标签

    trim标签体中是整个字符串拼串后的结果.prefix="" 前缀: prefix给拼串后的整个字符串加一个前缀prefixOverrides="" 前缀覆盖: ...

  9. django中的Ajax文件上传

    主要介绍两个 1.ajax文件上传 2.写路由器 3.创建对应的函数 4.file_put.html代码 <!DOCTYPE html> <html lang="en&qu ...

  10. Java基础16-类与对象

    1.如何创建一个类 public class Person{ //属性 String name; String genter; int age; //方法 public void eat(){ Sys ...