A flag editor

개발 관련 글 2009. 4. 21. 11:44

Sample Image - FlagsEditor.gif

Introduction

This editor displays a dropdown control holding a CheckedListBox with all the values of an enumeration.

Using the FlagsEditor

You just have to put the Editor attributes on an enumeration to link it with the FlagsEditor. A Description attribute can also be added to each value. It will be shown as a tooltip on the CheckedListBox items.

Here is a sample.

Collapse Copy Code
[Flags,  Editor(typeof(STUP.ComponentModel.Design.FlagsEditor),   typeof(System.Drawing.Design.UITypeEditor))]public enum EnumerationTest{    [Description("Description for the first tested value.")]    firstValue = 1,    [Description("Description for the second tested value.")]    secondValue = 2,    [Description("Description for the third tested value.")]    thirdValue = 4}

How does it work ?

The Editor is just one class that inherits UITypeEditor. The behavior of Editor is controlled by two functions.

GetEditStyle

This function is used for controlling the appearance of the small button in the property grid. In this sample a dropdown arrow will be shown.

Collapse Copy Code
public override UITypeEditorEditStyle        GetEditStyle(ITypeDescriptorContext context) {    return UITypeEditorEditStyle.DropDown;}

EditValue

This function is called when the user clicks on the small button.

Collapse Copy Code
public override object EditValue(ITypeDescriptorContext context,         IServiceProvider provider, object value) {    if (context != null        && context.Instance != null        && provider != null)     {        // Get an instance of the IWindowsFormsEditorService.         edSvc = (IWindowsFormsEditorService)provider.GetService                            (typeof(IWindowsFormsEditorService));        if (edSvc != null)         {            // Create a CheckedListBox            clb = new CheckedListBox();            ...            // Show our CheckedListbox as a DropDownControl.             // This methods returns only when            // the dropdowncontrol is closed            edSvc.DropDownControl(clb);            // return the right enum value            // corresponding to the result            return ...        }    }    return value;}

The DropDownControl can be closed by calling the edSvc.CloseDropDown() function.

For a complete example, just download the source file.

License

This article has no explicit license attached to it but may contain usage terms in the article text or the download files themselves. If in doubt please contact the author via the discussion board below.

A list of licenses authors might use can be found here

Posted by 퓨전마법사
,