Code:
                         / Dotnetfx_Vista_SP2 / Dotnetfx_Vista_SP2 / 8.0.50727.4016 / DEVDIV / depot / DevDiv / releases / whidbey / NetFxQFE / ndp / fx / src / WinForms / Managed / System / WinForms / PropertyGridInternal / CategoryGridEntry.cs / 1 / CategoryGridEntry.cs
                        
                        
                            //------------------------------------------------------------------------------ 
// 
//     Copyright (c) Microsoft Corporation.  All rights reserved.
//  
//----------------------------------------------------------------------------- 
//#define PAINT_CATEGORY_TRIANGLE 
/* 
 */
namespace System.Windows.Forms.PropertyGridInternal { 
    using System.Diagnostics;
    using System.Diagnostics.CodeAnalysis;
 
     using System;
     using System.Collections; 
     using System.Reflection; 
     using System.ComponentModel; 
     using System.ComponentModel.Design;
     using System.Windows.Forms;
     using System.Drawing;
     using Microsoft.Win32; 
     internal class CategoryGridEntry : GridEntry { 
 
        internal string name;
        private Brush backBrush = null; 
        private static Hashtable categoryStates = null;
        [
            SuppressMessage("Microsoft.Usage", "CA2214:DoNotCallOverridableMethodsInConstructors")  // GridEntry classes are internal so we have complete 
                                                                                                    // control over who does what in the constructor.
        ] 
        public CategoryGridEntry(PropertyGrid ownerGrid, GridEntry peParent,string name, GridEntry[] childGridEntries) 
        : base(ownerGrid, peParent) {
            this.name = name; 
#if DEBUG
            for (int n = 0;n < childGridEntries.Length; n++) {
                Debug.Assert(childGridEntries[n] != null, "Null item in category subproperty list"); 
            }
#endif 
            if (categoryStates == null) { 
                categoryStates = new Hashtable();
            } 
            lock (categoryStates) {
                if (!categoryStates.ContainsKey(name)) {
                    categoryStates.Add(name, true); 
                }
            } 
 
            this.IsExpandable = true;
 
            for (int i = 0; i < childGridEntries.Length; i++) {
                childGridEntries[i].ParentGridEntry = this;
            }
 
            this.ChildCollection = new GridEntryCollection(this, childGridEntries);
 
            lock (categoryStates) { 
                this.InternalExpanded = (bool)categoryStates[name];
            } 
            this.SetFlag(GridEntry.FLAG_LABEL_BOLD,true);
        }
 
        ///  
        /// Returns true if this GridEntry has a value field in the right hand column.
        ///   
        internal override bool HasValue {
            get {
               return false;
            } 
        }
 
        protected override void Dispose(bool disposing) { 
            if (disposing) {
                if (backBrush != null) { 
                    backBrush.Dispose();
                    backBrush = null;
                }
 
                if (ChildCollection != null) {
                    ChildCollection = null; 
                } 
            }
            base.Dispose(disposing); 
        }
        public override void DisposeChildren() {
 
            // categories should never dispose
            // 
            return; 
        }
 
        // we don't want this guy participating in property depth.
        public override int PropertyDepth {
            get { 
                return base.PropertyDepth - 1;
            } 
        } 
        protected override Brush GetBackgroundBrush(Graphics g) { 
            return this.GridEntryHost.GetLineBrush(g);
        }
        protected override Color LabelTextColor { 
            get {
                return ownerGrid.CategoryForeColor; 
            } 
        }
 
        public override bool Expandable {
            get {
                return !GetFlagSet(FL_EXPANDABLE_FAILED);
            } 
        }
 
        internal override bool InternalExpanded { 
            set {
                base.InternalExpanded = value; 
                lock (categoryStates) {
                    categoryStates[this.name] = value;
                }
            } 
        }
 
        public override GridItemType GridItemType { 
            get {
                return GridItemType.Category; 
            }
        }
        public override string HelpKeyword {
            get { 
               return null;
            } 
        } 
        public override string PropertyLabel { 
            get {
                return name;
            }
        } 
        internal override int PropertyLabelIndent { 
            get { 
                // we give an extra pixel for breathing room
                // we want to make sure that we return 0 for property depth here instead of 
                PropertyGridView gridHost = this.GridEntryHost;
                // we call base.PropertyDepth here because we don't want the subratction to happen.
                return 1+gridHost.GetOutlineIconSize()+OUTLINE_ICON_PADDING + (base.PropertyDepth * gridHost.GetDefaultOutlineIndent()); 
            }
        } 
 
        public override string GetPropertyTextValue(object o) {
            return ""; 
        }
        public override Type PropertyType {
            get { 
                return typeof(void);
            } 
        } 
        /// 
        /// Gets the owner of the current value.  This is usually the value of the
        /// root entry, which is the object being browsed
        ///   
        public override object GetChildValueOwner(GridEntry childEntry) {
            return ParentGridEntry.GetChildValueOwner(childEntry); 
        } 
        protected override bool CreateChildren(bool diffOldChildren) { 
            return true;
        }
        public override string GetTestingInfo() { 
            string str = "object = (";
            str += FullLabel; 
            str += "), Category = (" + this.PropertyLabel + ")"; 
            return str;
        } 
        public override void PaintLabel(System.Drawing.Graphics g, Rectangle rect, Rectangle clipRect, bool selected, bool paintFullLabel) {
            base.PaintLabel(g, rect, clipRect, false, true); 
            // now draw the focus rect 
            if (selected && hasFocus) { 
                bool bold = ((this.Flags & GridEntry.FLAG_LABEL_BOLD) != 0);
                Font font = GetFont(bold); 
                int labelWidth = GetLabelTextWidth(this.PropertyLabel, g, font);
                int indent = PropertyLabelIndent-2;
                Rectangle focusRect = new Rectangle(indent, rect.Y, labelWidth+3, rect.Height-1); 
                ControlPaint.DrawFocusRectangle(g, focusRect);
            } 
 
            // draw the line along the top
            if (parentPE.GetChildIndex(this) > 0) { 
                g.DrawLine(SystemPens.Control, rect.X-1, rect.Y-1, rect.Width+2, rect.Y - 1);
            }
        }
 
#if PAINT_CATEGORY_TRIANGLE
        private const double TRI_HEIGHT_RATIO = 2.5; 
        private static readonly double TRI_WIDTH_RATIO = .8; 
#endif
 
        public override void PaintOutline(System.Drawing.Graphics g, Rectangle r) {
 
            // draw outline pointer triangle.
            if (Expandable) { 
                bool fExpanded = Expanded; 
                Rectangle outline = OutlineRect;
 
                // make sure we're in our bounds
                outline = Rectangle.Intersect(r, outline);
                if (outline.IsEmpty) { 
                    return;
                } 
 
#if PAINT_CATEGORY_TRIANGLE
 
                // bump it over a pixel
                //outline.Offset(1, 0);
                //outline.Inflate(-1,-1);
 
                // build the triangle, an equalaterial centered around the midpoint of the rect.
 
                Point[] points = new Point[3]; 
                int borderWidth = 2;
 
                // width is always the length of the sides of the triangle.
                // Height = (width /2 * (Cos60)) ; Cos60 ~ .86
                int triWidth, triHeight;
                int xOffset, yOffset; 
                if (!fExpanded) { 
                    // draw arrow pointing right, remember height is pointing right 
                    //      0
                    //      |\ 
                    //      | \2
                    //      | /
                    //      |/
                    //      1 
                    triWidth = (int)((outline.Height * TRI_WIDTH_RATIO) - (2*borderWidth)); 
                    // make sure it's an odd width so our lines will match up 
                    if (!(triWidth % 2 == 0)) {
                        triWidth++; 
                    }
                    triHeight = (int)Math.Ceil((triWidth/2) * TRI_HEIGHT_RATIO);
 
                    yOffset = outline.Y + (outline.Height-triWidth)/2;
                    xOffset = outline.X + (outline.Width-triHeight)/2; 
 
                    points[0] = new Point(xOffset, yOffset);
                    points[1] = new Point(xOffset, yOffset + triWidth); 
                    points[2] = new Point(xOffset+triHeight, yOffset + (triWidth / 2));
                }
                else { 
                    // draw arrow pointing down
 
                    //  0 -------- 1 
                    //    \      /
                    //     \    / 
                    //      \  /
                    //       \/
                    //       2
 
                    triWidth = (int)((outline.Width * TRI_WIDTH_RATIO) - (2*borderWidth));
                    // make sure it's an odd width so our lines will match up 
                    if (!(triWidth % 2 == 0)) { 
                        triWidth++;
                    } 
                    triHeight = (int)Math.Ceil((triWidth/2) * TRI_HEIGHT_RATIO);
                    xOffset = outline.X + (outline.Width-triWidth)/2; 
                    yOffset = outline.Y + (outline.Height-triHeight)/2;
 
                    points[0] = new Point(xOffset, yOffset); 
                    points[1] = new Point(xOffset + triWidth, yOffset);
                    points[2] = new Point(xOffset + (triWidth/ 2),yOffset + triHeight); 
                }
                g.FillPolygon(SystemPens.WindowText, points);
#else 
 
                // draw border area box 
                Brush b;
                Pen p; 
                bool disposeBrush = false;
                bool disposePen = false;
                Color color = GridEntryHost.GetLineColor(); 
                b = new SolidBrush(g.GetNearestColor(color));
                disposeBrush = true; 
 
                color = GridEntryHost.GetTextColor();
 
                p = new Pen(g.GetNearestColor(color));
                disposePen = true;
                g.FillRectangle(b, outline); 
                g.DrawRectangle(p, outline.X, outline.Y, outline.Width - 1, outline.Height - 1);
 
                // draw horizontal line for +/- 
                int indent = 2;
                g.DrawLine(SystemPens.WindowText, outline.X + indent,outline.Y + outline.Height / 2, 
                           outline.X + outline.Width - indent - 1,outline.Y + outline.Height/2);
                // draw vertical line to make a +
                if (!fExpanded) 
                    g.DrawLine(SystemPens.WindowText, outline.X + outline.Width/2, outline.Y + indent,
                               outline.X + outline.Width/2, outline.Y + outline.Height - indent - 1); 
 
                if (disposePen) p.Dispose();
                if (disposeBrush) b.Dispose(); 
#endif
 
            }
        } 
 
        public override void PaintValue(object val, System.Drawing.Graphics g, Rectangle rect, Rectangle clipRect, PaintValueFlags paintFlags) {
            base.PaintValue(val, g, rect, clipRect, paintFlags & ~PaintValueFlags.DrawSelected); 
            // draw the line along the top
            if (parentPE.GetChildIndex(this) > 0) {
                g.DrawLine(SystemPens.Control, rect.X-2, rect.Y-1,rect.Width+1, rect.Y-1); 
            }
        } 
 
        internal override bool NotifyChildValue(GridEntry pe, int type) {
            return parentPE.NotifyChildValue(pe, type); 
        }
    }
} 
// File provided for Reference Use Only by Microsoft Corporation (c) 2007.
//------------------------------------------------------------------------------ 
// 
//     Copyright (c) Microsoft Corporation.  All rights reserved.
//  
//----------------------------------------------------------------------------- 
//#define PAINT_CATEGORY_TRIANGLE 
/* 
 */
namespace System.Windows.Forms.PropertyGridInternal { 
    using System.Diagnostics;
    using System.Diagnostics.CodeAnalysis;
 
     using System;
     using System.Collections; 
     using System.Reflection; 
     using System.ComponentModel; 
     using System.ComponentModel.Design;
     using System.Windows.Forms;
     using System.Drawing;
     using Microsoft.Win32; 
     internal class CategoryGridEntry : GridEntry { 
 
        internal string name;
        private Brush backBrush = null; 
        private static Hashtable categoryStates = null;
        [
            SuppressMessage("Microsoft.Usage", "CA2214:DoNotCallOverridableMethodsInConstructors")  // GridEntry classes are internal so we have complete 
                                                                                                    // control over who does what in the constructor.
        ] 
        public CategoryGridEntry(PropertyGrid ownerGrid, GridEntry peParent,string name, GridEntry[] childGridEntries) 
        : base(ownerGrid, peParent) {
            this.name = name; 
#if DEBUG
            for (int n = 0;n < childGridEntries.Length; n++) {
                Debug.Assert(childGridEntries[n] != null, "Null item in category subproperty list"); 
            }
#endif 
            if (categoryStates == null) { 
                categoryStates = new Hashtable();
            } 
            lock (categoryStates) {
                if (!categoryStates.ContainsKey(name)) {
                    categoryStates.Add(name, true); 
                }
            } 
 
            this.IsExpandable = true;
 
            for (int i = 0; i < childGridEntries.Length; i++) {
                childGridEntries[i].ParentGridEntry = this;
            }
 
            this.ChildCollection = new GridEntryCollection(this, childGridEntries);
 
            lock (categoryStates) { 
                this.InternalExpanded = (bool)categoryStates[name];
            } 
            this.SetFlag(GridEntry.FLAG_LABEL_BOLD,true);
        }
 
        ///  
        /// Returns true if this GridEntry has a value field in the right hand column.
        ///   
        internal override bool HasValue {
            get {
               return false;
            } 
        }
 
        protected override void Dispose(bool disposing) { 
            if (disposing) {
                if (backBrush != null) { 
                    backBrush.Dispose();
                    backBrush = null;
                }
 
                if (ChildCollection != null) {
                    ChildCollection = null; 
                } 
            }
            base.Dispose(disposing); 
        }
        public override void DisposeChildren() {
 
            // categories should never dispose
            // 
            return; 
        }
 
        // we don't want this guy participating in property depth.
        public override int PropertyDepth {
            get { 
                return base.PropertyDepth - 1;
            } 
        } 
        protected override Brush GetBackgroundBrush(Graphics g) { 
            return this.GridEntryHost.GetLineBrush(g);
        }
        protected override Color LabelTextColor { 
            get {
                return ownerGrid.CategoryForeColor; 
            } 
        }
 
        public override bool Expandable {
            get {
                return !GetFlagSet(FL_EXPANDABLE_FAILED);
            } 
        }
 
        internal override bool InternalExpanded { 
            set {
                base.InternalExpanded = value; 
                lock (categoryStates) {
                    categoryStates[this.name] = value;
                }
            } 
        }
 
        public override GridItemType GridItemType { 
            get {
                return GridItemType.Category; 
            }
        }
        public override string HelpKeyword {
            get { 
               return null;
            } 
        } 
        public override string PropertyLabel { 
            get {
                return name;
            }
        } 
        internal override int PropertyLabelIndent { 
            get { 
                // we give an extra pixel for breathing room
                // we want to make sure that we return 0 for property depth here instead of 
                PropertyGridView gridHost = this.GridEntryHost;
                // we call base.PropertyDepth here because we don't want the subratction to happen.
                return 1+gridHost.GetOutlineIconSize()+OUTLINE_ICON_PADDING + (base.PropertyDepth * gridHost.GetDefaultOutlineIndent()); 
            }
        } 
 
        public override string GetPropertyTextValue(object o) {
            return ""; 
        }
        public override Type PropertyType {
            get { 
                return typeof(void);
            } 
        } 
        /// 
        /// Gets the owner of the current value.  This is usually the value of the
        /// root entry, which is the object being browsed
        ///   
        public override object GetChildValueOwner(GridEntry childEntry) {
            return ParentGridEntry.GetChildValueOwner(childEntry); 
        } 
        protected override bool CreateChildren(bool diffOldChildren) { 
            return true;
        }
        public override string GetTestingInfo() { 
            string str = "object = (";
            str += FullLabel; 
            str += "), Category = (" + this.PropertyLabel + ")"; 
            return str;
        } 
        public override void PaintLabel(System.Drawing.Graphics g, Rectangle rect, Rectangle clipRect, bool selected, bool paintFullLabel) {
            base.PaintLabel(g, rect, clipRect, false, true); 
            // now draw the focus rect 
            if (selected && hasFocus) { 
                bool bold = ((this.Flags & GridEntry.FLAG_LABEL_BOLD) != 0);
                Font font = GetFont(bold); 
                int labelWidth = GetLabelTextWidth(this.PropertyLabel, g, font);
                int indent = PropertyLabelIndent-2;
                Rectangle focusRect = new Rectangle(indent, rect.Y, labelWidth+3, rect.Height-1); 
                ControlPaint.DrawFocusRectangle(g, focusRect);
            } 
 
            // draw the line along the top
            if (parentPE.GetChildIndex(this) > 0) { 
                g.DrawLine(SystemPens.Control, rect.X-1, rect.Y-1, rect.Width+2, rect.Y - 1);
            }
        }
 
#if PAINT_CATEGORY_TRIANGLE
        private const double TRI_HEIGHT_RATIO = 2.5; 
        private static readonly double TRI_WIDTH_RATIO = .8; 
#endif
 
        public override void PaintOutline(System.Drawing.Graphics g, Rectangle r) {
 
            // draw outline pointer triangle.
            if (Expandable) { 
                bool fExpanded = Expanded; 
                Rectangle outline = OutlineRect;
 
                // make sure we're in our bounds
                outline = Rectangle.Intersect(r, outline);
                if (outline.IsEmpty) { 
                    return;
                } 
 
#if PAINT_CATEGORY_TRIANGLE
 
                // bump it over a pixel
                //outline.Offset(1, 0);
                //outline.Inflate(-1,-1);
 
                // build the triangle, an equalaterial centered around the midpoint of the rect.
 
                Point[] points = new Point[3]; 
                int borderWidth = 2;
 
                // width is always the length of the sides of the triangle.
                // Height = (width /2 * (Cos60)) ; Cos60 ~ .86
                int triWidth, triHeight;
                int xOffset, yOffset; 
                if (!fExpanded) { 
                    // draw arrow pointing right, remember height is pointing right 
                    //      0
                    //      |\ 
                    //      | \2
                    //      | /
                    //      |/
                    //      1 
                    triWidth = (int)((outline.Height * TRI_WIDTH_RATIO) - (2*borderWidth)); 
                    // make sure it's an odd width so our lines will match up 
                    if (!(triWidth % 2 == 0)) {
                        triWidth++; 
                    }
                    triHeight = (int)Math.Ceil((triWidth/2) * TRI_HEIGHT_RATIO);
 
                    yOffset = outline.Y + (outline.Height-triWidth)/2;
                    xOffset = outline.X + (outline.Width-triHeight)/2; 
 
                    points[0] = new Point(xOffset, yOffset);
                    points[1] = new Point(xOffset, yOffset + triWidth); 
                    points[2] = new Point(xOffset+triHeight, yOffset + (triWidth / 2));
                }
                else { 
                    // draw arrow pointing down
 
                    //  0 -------- 1 
                    //    \      /
                    //     \    / 
                    //      \  /
                    //       \/
                    //       2
 
                    triWidth = (int)((outline.Width * TRI_WIDTH_RATIO) - (2*borderWidth));
                    // make sure it's an odd width so our lines will match up 
                    if (!(triWidth % 2 == 0)) { 
                        triWidth++;
                    } 
                    triHeight = (int)Math.Ceil((triWidth/2) * TRI_HEIGHT_RATIO);
                    xOffset = outline.X + (outline.Width-triWidth)/2; 
                    yOffset = outline.Y + (outline.Height-triHeight)/2;
 
                    points[0] = new Point(xOffset, yOffset); 
                    points[1] = new Point(xOffset + triWidth, yOffset);
                    points[2] = new Point(xOffset + (triWidth/ 2),yOffset + triHeight); 
                }
                g.FillPolygon(SystemPens.WindowText, points);
#else 
 
                // draw border area box 
                Brush b;
                Pen p; 
                bool disposeBrush = false;
                bool disposePen = false;
                Color color = GridEntryHost.GetLineColor(); 
                b = new SolidBrush(g.GetNearestColor(color));
                disposeBrush = true; 
 
                color = GridEntryHost.GetTextColor();
 
                p = new Pen(g.GetNearestColor(color));
                disposePen = true;
                g.FillRectangle(b, outline); 
                g.DrawRectangle(p, outline.X, outline.Y, outline.Width - 1, outline.Height - 1);
 
                // draw horizontal line for +/- 
                int indent = 2;
                g.DrawLine(SystemPens.WindowText, outline.X + indent,outline.Y + outline.Height / 2, 
                           outline.X + outline.Width - indent - 1,outline.Y + outline.Height/2);
                // draw vertical line to make a +
                if (!fExpanded) 
                    g.DrawLine(SystemPens.WindowText, outline.X + outline.Width/2, outline.Y + indent,
                               outline.X + outline.Width/2, outline.Y + outline.Height - indent - 1); 
 
                if (disposePen) p.Dispose();
                if (disposeBrush) b.Dispose(); 
#endif
 
            }
        } 
 
        public override void PaintValue(object val, System.Drawing.Graphics g, Rectangle rect, Rectangle clipRect, PaintValueFlags paintFlags) {
            base.PaintValue(val, g, rect, clipRect, paintFlags & ~PaintValueFlags.DrawSelected); 
            // draw the line along the top
            if (parentPE.GetChildIndex(this) > 0) {
                g.DrawLine(SystemPens.Control, rect.X-2, rect.Y-1,rect.Width+1, rect.Y-1); 
            }
        } 
 
        internal override bool NotifyChildValue(GridEntry pe, int type) {
            return parentPE.NotifyChildValue(pe, type); 
        }
    }
} 
// File provided for Reference Use Only by Microsoft Corporation (c) 2007.
                        
                        
                        
                        
                    Link Menu

This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- DbMetaDataColumnNames.cs
- PermissionAttributes.cs
- XmlChildNodes.cs
- WebRequestModuleElement.cs
- ConfigPathUtility.cs
- WsatAdminException.cs
- EventProvider.cs
- CompositeScriptReferenceEventArgs.cs
- MemberDomainMap.cs
- TextBreakpoint.cs
- Form.cs
- ToolZone.cs
- DynamicResourceExtension.cs
- EntityViewGenerationConstants.cs
- DataGridViewComboBoxColumn.cs
- UmAlQuraCalendar.cs
- XMLSyntaxException.cs
- TableCell.cs
- References.cs
- EventLogException.cs
- SQLInt64.cs
- SiteMembershipCondition.cs
- LinkLabel.cs
- DataTableNameHandler.cs
- WebControl.cs
- ChtmlTextWriter.cs
- Adorner.cs
- DateTimePicker.cs
- TraceHwndHost.cs
- Int32CollectionValueSerializer.cs
- FormViewDesigner.cs
- StylusCollection.cs
- HttpPostProtocolImporter.cs
- FactoryRecord.cs
- ObjectDataSourceEventArgs.cs
- TextBoxRenderer.cs
- PassportIdentity.cs
- SqlDataSourceSummaryPanel.cs
- UrlAuthFailureHandler.cs
- WorkflowRuntime.cs
- WebServiceEnumData.cs
- RadioButton.cs
- WebPartMenuStyle.cs
- BitmapImage.cs
- ExceptionValidationRule.cs
- TcpTransportManager.cs
- NameTable.cs
- WmpBitmapEncoder.cs
- WindowsMenu.cs
- HostedTransportConfigurationManager.cs
- WindowShowOrOpenTracker.cs
- PropertyIdentifier.cs
- X509AsymmetricSecurityKey.cs
- DefaultSettingsSection.cs
- HttpCachePolicy.cs
- GridSplitter.cs
- SerialPort.cs
- StringAnimationUsingKeyFrames.cs
- _CommandStream.cs
- Repeater.cs
- BamlMapTable.cs
- User.cs
- SQLByte.cs
- ItemsPresenter.cs
- ResXDataNode.cs
- RemotingAttributes.cs
- CellRelation.cs
- ReflectionHelper.cs
- DrawingContextDrawingContextWalker.cs
- NotificationContext.cs
- CheckBoxList.cs
- TextLineBreak.cs
- StrongTypingException.cs
- GridViewDeleteEventArgs.cs
- GregorianCalendarHelper.cs
- Cursors.cs
- Int32Rect.cs
- WebPartConnectionsEventArgs.cs
- ItemPager.cs
- XmlILConstructAnalyzer.cs
- _DigestClient.cs
- ReachDocumentReferenceCollectionSerializerAsync.cs
- ActivityExecutor.cs
- XmlQueryRuntime.cs
- InvokeProviderWrapper.cs
- ButtonChrome.cs
- TrustManager.cs
- SiteMapDataSourceView.cs
- Table.cs
- LinkArea.cs
- SafeSecurityHelper.cs
- EntityDataSourceViewSchema.cs
- CheckBox.cs
- HtmlEncodedRawTextWriter.cs
- AudioFormatConverter.cs
- Adorner.cs
- KeyFrames.cs
- TypeUtil.cs
- GregorianCalendar.cs
- XPathAncestorQuery.cs