自定义设计器和类型编辑器

这次一起来看下设计时中如何自定义设计器和类型编辑器

 .设计器 

 1.什么是设计器,看下图 

 ch18.jpg

 

 所以无需解释其概念,设计器自然是帮助你能够快速的完成控件基本的编辑,节省时间.
设计器是一个Form页面,所以如果想制作设计器的话,需要一些Form的基础知识.
2.实现原理 

 (1)设计器可以说是属性面板的扩展版,一般情况下设计器会把控件常用的属性都列出来,供方便的设置

 (2)原理还是跟第3篇一样,打开设计器时,Form通过继承自ControlDesigner的类(假设为SampleControlDesigner)获取属性值,返回的时候通过设置SampleControlDesigner属性,然后通过UpdateDesignTimeHtml方法更新控件页面标记,这个方法很重要. 

3.实现

 还以第3篇的例子说明

 (1)在SampleControlDesigner类中定义相关属性

 

public string BoxText
        {
            get
            {
                return SampleControl.BoxText;
            }
            set
            {
                if (value != BoxText)
                {
                    SampleControl.BoxText = value;
                    UpdateDesignTimeHtml();
                }
            }
        }

        public string LabelText
        {
            get
            {

                return SampleControl.LabelText;
            }
            set
            {
                if (value != BoxText)
                {
                    SampleControl.LabelText= value;
                    UpdateDesignTimeHtml();
                }
            }
        }

 

 

(2)在CustomControlActionList中添加一个项任务面板,并定义相关方法
public void show()
        {
            SampleControl ctrl = (SampleControl)_parent.Component;

            TransactedChangeCallback toCall = new TransactedChangeCallback(ConfigureChangeCallback);
         
            System.Web.UI.Design.ControlDesigner.InvokeTransactedChange(ctrl, toCall, "show", "show");
        }


        public override DesignerActionItemCollection GetSortedActionItems()
        {
            if (items == null)
            {

                items = new DesignerActionItemCollection();

                items.Add(new DesignerActionMethodItem(this, "show", "测试弹出框", true));
            }
            return items;
        }
TransactedChangeCallback委托和ControlDesigner.InvokeTransactedChange方法搭配使用,可以查看MSDN的解释
自定义对象将由  InvokeTransactedChange  方法调用以实现与设计器相关联的控件中的属性更改。

看下 ConfigureChangeCallback方法
private bool ConfigureChangeCallback(object context)
        {
            try
            {

                IUIService uiService = GetService<IUIService>((IServiceProvider)_parent.Component.Site);
                if (uiService == null)
                    return false;
                StringInputForm form = new StringInputForm(_parent);
                DialogResult result = uiService.ShowDialog(form);
                if (result == DialogResult.OK)
                {

                    return true;
                }
            }
            finally
            {

            }
            return false;
        }
方法中出现了一些接口,大家还是查MSDN吧.这里就不说了

 

StringInputForm当然便是自定义Form了

(3)在Form中设置SampleControlDesigner属性

 

private void button1_Click(object sender, EventArgs e)
        {
            _DataSourceControlDesigner.BoxText = tbox.Text;
            _DataSourceControlDesigner.LabelText = tbox2.Text;
        }

 

好了,基本完成了,看下效果.

 

ch19.jpg

二.类型编辑器 

1.什么是类型编辑器.看下图

ch20.jpg
图一

此为TextBox控件的Text属性的类型编辑器,当点击下拉框时,会出现一个较大的区域供文本编辑

ch21.jpg

此为Image控件的ImageUrl,点击属性右侧按钮会弹出一个设计器来选择图片.

类型编辑器分两种即编辑器样式.上面2张图片已经说明了 一种是弹出框,另一种则是下拉式

可以这么说类型编辑器是针对某一类型的编辑而设计,是单一编辑.所以叫类型编辑器也很好理解.

类型编辑器在纶巾客的博客中都已经详细的介绍过了,大家可以看看.所以这里简单的介绍.

2.实现方法

 

1.继承UITypeEditor类

重写EditValue和GetEditStyle方法

GetEditStyle方法为选择编辑器样式(即选择弹出框还是下拉的形式)

EditValue方法则是编辑指定的值(即编辑指定的控件属性)

(2)设置Form页面.
大家下示例代码看吧.这里不列了

(3)将类型编辑器与属性关联

方法类似

[Editor(typeof(TestDialogEditor), typeof(System.Drawing.Design.UITypeEditor))]

看效果图吧

 

图一
ch22.jpg

图二
ch23.jpg

好了,结束了.这里的示例代码都来自MSDN的例子.好控件离不开设计器的支持.

转载于:https://www.cnblogs.com/storage/archive/2010/06/22/1762938.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值