Code:
/ Dotnetfx_Win7_3.5.1 / Dotnetfx_Win7_3.5.1 / 3.5.1 / DEVDIV / depot / DevDiv / releases / whidbey / NetFXspW7 / ndp / fx / src / WinForms / Managed / System / WinForms / PropertyGridInternal / DocComment.cs / 1 / DocComment.cs
//------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- /* */ namespace System.Windows.Forms.PropertyGridInternal { using System.Diagnostics; using System.Diagnostics.CodeAnalysis; using System; using System.Windows.Forms; using System.ComponentModel; using System.ComponentModel.Design; using System.Drawing; using Microsoft.Win32; using System.Windows.Forms.Layout; internal class DocComment : PropertyGrid.SnappableControl { private Label m_labelTitle; private Label m_labelDesc; private string fullDesc; protected int lineHeight; private bool needUpdateUIWithFont = true; protected const int CBORDER = 3; protected const int CXDEF = 0; protected const int CYDEF = 59; protected const int MIN_LINES = 2; internal Rectangle rect = Rectangle.Empty; internal DocComment(PropertyGrid owner) : base(owner) { SuspendLayout(); m_labelTitle = new Label(); m_labelTitle.UseMnemonic = false; m_labelTitle.Cursor = Cursors.Default; m_labelDesc = new Label(); m_labelDesc.AutoEllipsis = true; m_labelDesc.Cursor = Cursors.Default; UpdateTextRenderingEngine(); Controls.Add(m_labelTitle); Controls.Add(m_labelDesc); Size = new Size(CXDEF,CYDEF); this.Text = SR.GetString(SR.PBRSDocCommentPaneTitle); SetStyle(ControlStyles.Selectable, false); ResumeLayout(false); } public virtual int Lines { get { UpdateUIWithFont(); return Height/lineHeight; } set { UpdateUIWithFont(); Size = new Size(Width, 1 + value * lineHeight); } } public override int GetOptimalHeight(int width) { UpdateUIWithFont(); // compute optimal label height as one line only. int height = m_labelTitle.Size.Height; // do this to avoid getting parented to the Parking window. // if (this.ownerGrid.IsHandleCreated && !IsHandleCreated) { CreateControl(); } // compute optimal text height Graphics g = m_labelDesc.CreateGraphicsInternal(); SizeF sizef = PropertyGrid.MeasureTextHelper.MeasureText( this.ownerGrid, g, m_labelTitle.Text, Font, width); Size sz = Size.Ceiling(sizef); g.Dispose(); height += (sz.Height * 2) + 2; return Math.Max(height + 4, CYDEF); } internal virtual void LayoutWindow() { } protected override void OnFontChanged(EventArgs e) { needUpdateUIWithFont = true; PerformLayout(); base.OnFontChanged(e); } protected override void OnLayout(LayoutEventArgs e) { UpdateUIWithFont(); Size size = ClientSize; // if the client size is 0, setting this to a negative number // will force an extra layout. size.Width = Math.Max(0, size.Width - 2*CBORDER); size.Height = Math.Max(0, size.Height - 2*CBORDER); // calling SetBounds is slightly more efficient than allocating // a size struct and setting it into Size prop. m_labelTitle.SetBounds(m_labelTitle.Top, m_labelTitle.Left, size.Width, Math.Min(lineHeight, size.Height), BoundsSpecified.Size); m_labelDesc.SetBounds(m_labelDesc.Top, m_labelDesc.Left, size.Width, Math.Max(0,size.Height-lineHeight-1), BoundsSpecified.Size); m_labelDesc.Text = this.fullDesc; m_labelDesc.AccessibleName = this.fullDesc; // Don't crop the description for accessibility clients base.OnLayout(e); } protected override void OnResize(EventArgs e) { Rectangle newRect = ClientRectangle; if (!rect.IsEmpty && newRect.Width > rect.Width) { Rectangle rectInvalidate = new Rectangle(rect.Width-1,0,newRect.Width-rect.Width+1,rect.Height); Invalidate(rectInvalidate); } rect = newRect; base.OnResize(e); } protected override void OnHandleCreated(EventArgs e) { base.OnHandleCreated(e); UpdateUIWithFont(); } public virtual void SetComment(string title, string desc) { if (m_labelDesc.Text != title) { m_labelTitle.Text = title; } if (desc != fullDesc) { this.fullDesc = desc; m_labelDesc.Text = fullDesc; m_labelDesc.AccessibleName = this.fullDesc; // Don't crop the description for accessibility clients } } public override int SnapHeightRequest(int cyNew) { UpdateUIWithFont(); int lines = Math.Max(MIN_LINES, cyNew/lineHeight); return 1 + lines*lineHeight; } internal void UpdateTextRenderingEngine() { m_labelTitle.UseCompatibleTextRendering = this.ownerGrid.UseCompatibleTextRendering; m_labelDesc.UseCompatibleTextRendering = this.ownerGrid.UseCompatibleTextRendering; } private void UpdateUIWithFont() { if (IsHandleCreated && needUpdateUIWithFont) { // Some fonts throw because Bold is not a valid option // for them. Fail gracefully. try { m_labelTitle.Font = new Font(Font, FontStyle.Bold); } catch { } lineHeight = (int)Font.Height + 2; m_labelTitle.Location = new Point(CBORDER, CBORDER); m_labelDesc.Location = new Point(CBORDER, CBORDER + lineHeight); needUpdateUIWithFont = false; PerformLayout(); } } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- /* */ namespace System.Windows.Forms.PropertyGridInternal { using System.Diagnostics; using System.Diagnostics.CodeAnalysis; using System; using System.Windows.Forms; using System.ComponentModel; using System.ComponentModel.Design; using System.Drawing; using Microsoft.Win32; using System.Windows.Forms.Layout; internal class DocComment : PropertyGrid.SnappableControl { private Label m_labelTitle; private Label m_labelDesc; private string fullDesc; protected int lineHeight; private bool needUpdateUIWithFont = true; protected const int CBORDER = 3; protected const int CXDEF = 0; protected const int CYDEF = 59; protected const int MIN_LINES = 2; internal Rectangle rect = Rectangle.Empty; internal DocComment(PropertyGrid owner) : base(owner) { SuspendLayout(); m_labelTitle = new Label(); m_labelTitle.UseMnemonic = false; m_labelTitle.Cursor = Cursors.Default; m_labelDesc = new Label(); m_labelDesc.AutoEllipsis = true; m_labelDesc.Cursor = Cursors.Default; UpdateTextRenderingEngine(); Controls.Add(m_labelTitle); Controls.Add(m_labelDesc); Size = new Size(CXDEF,CYDEF); this.Text = SR.GetString(SR.PBRSDocCommentPaneTitle); SetStyle(ControlStyles.Selectable, false); ResumeLayout(false); } public virtual int Lines { get { UpdateUIWithFont(); return Height/lineHeight; } set { UpdateUIWithFont(); Size = new Size(Width, 1 + value * lineHeight); } } public override int GetOptimalHeight(int width) { UpdateUIWithFont(); // compute optimal label height as one line only. int height = m_labelTitle.Size.Height; // do this to avoid getting parented to the Parking window. // if (this.ownerGrid.IsHandleCreated && !IsHandleCreated) { CreateControl(); } // compute optimal text height Graphics g = m_labelDesc.CreateGraphicsInternal(); SizeF sizef = PropertyGrid.MeasureTextHelper.MeasureText( this.ownerGrid, g, m_labelTitle.Text, Font, width); Size sz = Size.Ceiling(sizef); g.Dispose(); height += (sz.Height * 2) + 2; return Math.Max(height + 4, CYDEF); } internal virtual void LayoutWindow() { } protected override void OnFontChanged(EventArgs e) { needUpdateUIWithFont = true; PerformLayout(); base.OnFontChanged(e); } protected override void OnLayout(LayoutEventArgs e) { UpdateUIWithFont(); Size size = ClientSize; // if the client size is 0, setting this to a negative number // will force an extra layout. size.Width = Math.Max(0, size.Width - 2*CBORDER); size.Height = Math.Max(0, size.Height - 2*CBORDER); // calling SetBounds is slightly more efficient than allocating // a size struct and setting it into Size prop. m_labelTitle.SetBounds(m_labelTitle.Top, m_labelTitle.Left, size.Width, Math.Min(lineHeight, size.Height), BoundsSpecified.Size); m_labelDesc.SetBounds(m_labelDesc.Top, m_labelDesc.Left, size.Width, Math.Max(0,size.Height-lineHeight-1), BoundsSpecified.Size); m_labelDesc.Text = this.fullDesc; m_labelDesc.AccessibleName = this.fullDesc; // Don't crop the description for accessibility clients base.OnLayout(e); } protected override void OnResize(EventArgs e) { Rectangle newRect = ClientRectangle; if (!rect.IsEmpty && newRect.Width > rect.Width) { Rectangle rectInvalidate = new Rectangle(rect.Width-1,0,newRect.Width-rect.Width+1,rect.Height); Invalidate(rectInvalidate); } rect = newRect; base.OnResize(e); } protected override void OnHandleCreated(EventArgs e) { base.OnHandleCreated(e); UpdateUIWithFont(); } public virtual void SetComment(string title, string desc) { if (m_labelDesc.Text != title) { m_labelTitle.Text = title; } if (desc != fullDesc) { this.fullDesc = desc; m_labelDesc.Text = fullDesc; m_labelDesc.AccessibleName = this.fullDesc; // Don't crop the description for accessibility clients } } public override int SnapHeightRequest(int cyNew) { UpdateUIWithFont(); int lines = Math.Max(MIN_LINES, cyNew/lineHeight); return 1 + lines*lineHeight; } internal void UpdateTextRenderingEngine() { m_labelTitle.UseCompatibleTextRendering = this.ownerGrid.UseCompatibleTextRendering; m_labelDesc.UseCompatibleTextRendering = this.ownerGrid.UseCompatibleTextRendering; } private void UpdateUIWithFont() { if (IsHandleCreated && needUpdateUIWithFont) { // Some fonts throw because Bold is not a valid option // for them. Fail gracefully. try { m_labelTitle.Font = new Font(Font, FontStyle.Bold); } catch { } lineHeight = (int)Font.Height + 2; m_labelTitle.Location = new Point(CBORDER, CBORDER); m_labelDesc.Location = new Point(CBORDER, CBORDER + lineHeight); needUpdateUIWithFont = false; PerformLayout(); } } } } // 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
- FixedSOMTableRow.cs
- NativeMethods.cs
- HttpServerVarsCollection.cs
- Tablet.cs
- RemoteX509Token.cs
- CapabilitiesRule.cs
- SystemResourceKey.cs
- EndpointDiscoveryMetadataCD1.cs
- ComAdminInterfaces.cs
- CryptoConfig.cs
- Line.cs
- MetadataArtifactLoaderFile.cs
- ToolStripSeparatorRenderEventArgs.cs
- CaseInsensitiveHashCodeProvider.cs
- FramingChannels.cs
- CheckBox.cs
- RequestQueue.cs
- XmlQualifiedName.cs
- MouseCaptureWithinProperty.cs
- PageBuildProvider.cs
- TriggerCollection.cs
- SerializationInfoEnumerator.cs
- XmlSchemaIdentityConstraint.cs
- AsymmetricAlgorithm.cs
- OptimalBreakSession.cs
- LiteralControl.cs
- _NtlmClient.cs
- AutomationEvent.cs
- PerformanceCounterManager.cs
- SoapIgnoreAttribute.cs
- SurrogateChar.cs
- WsatTransactionInfo.cs
- DataGridViewCellMouseEventArgs.cs
- BindingExpressionUncommonField.cs
- ObjectDataSourceSelectingEventArgs.cs
- Dynamic.cs
- Form.cs
- AsymmetricKeyExchangeDeformatter.cs
- HostUtils.cs
- Facet.cs
- _FtpDataStream.cs
- AuthenticodeSignatureInformation.cs
- StandardCommandToolStripMenuItem.cs
- ReferentialConstraint.cs
- System.Data.OracleClient_BID.cs
- XmlHierarchicalDataSourceView.cs
- Model3D.cs
- DataViewSettingCollection.cs
- JournalEntryListConverter.cs
- _IPv6Address.cs
- TableLayoutRowStyleCollection.cs
- StorageEntityContainerMapping.cs
- Misc.cs
- FrameworkElement.cs
- sqlstateclientmanager.cs
- Utilities.cs
- SecurityManager.cs
- FormViewUpdateEventArgs.cs
- TypefaceMap.cs
- InsufficientMemoryException.cs
- DeadLetterQueue.cs
- BStrWrapper.cs
- TableParaClient.cs
- AsnEncodedData.cs
- DefaultTextStoreTextComposition.cs
- Error.cs
- PointLight.cs
- WindowsSolidBrush.cs
- HwndAppCommandInputProvider.cs
- ObjectDataSourceFilteringEventArgs.cs
- AuthenticationSection.cs
- UseAttributeSetsAction.cs
- List.cs
- ConsoleEntryPoint.cs
- PeerContact.cs
- LayoutUtils.cs
- GZipStream.cs
- XmlSerializerNamespaces.cs
- HwndSource.cs
- Model3D.cs
- CallTemplateAction.cs
- MemberPath.cs
- JoinCqlBlock.cs
- UriTemplateMatch.cs
- StylusPointCollection.cs
- DoWorkEventArgs.cs
- Margins.cs
- RuleRefElement.cs
- MethodToken.cs
- HandlerFactoryWrapper.cs
- PhysicalFontFamily.cs
- SyndicationDeserializer.cs
- GlyphInfoList.cs
- X509Certificate2Collection.cs
- ProfileSection.cs
- RotateTransform.cs
- StrokeIntersection.cs
- DetailsViewPagerRow.cs
- FormViewPagerRow.cs
- ImmutableObjectAttribute.cs