Code:
/ Dotnetfx_Win7_3.5.1 / Dotnetfx_Win7_3.5.1 / 3.5.1 / DEVDIV / depot / DevDiv / releases / Orcas / NetFXw7 / wpf / src / Framework / System / Windows / Documents / FixedSOMLineRanges.cs / 1 / FixedSOMLineRanges.cs
/*++ File: FixedSOMLineRanges.cs Copyright (C) 2005 Microsoft Corporation. All rights reserved. Description: Internal helper class that can store a set of sorted lines by their start and end indices History: 05/17/2005: eleese - Created --*/ namespace System.Windows.Documents { using System.Collections; using System.Collections.Generic; using System.Windows.Shapes; using System.Windows.Controls; using System.Diagnostics; using System.Windows.Media; internal class FixedSOMLineRanges { public void AddRange(double start, double end) { for (int i = 0; i < Start.Count; ) { if (start > End[i] + _minLineSeparation) { i++; } else if (end + _minLineSeparation < Start[i]) { Start.Insert(i, start); End.Insert(i, end); return; } else { // overlap !! if (Start[i] < start) { start = Start[i]; } if (End[i] > end) { end = End[i]; } Start.RemoveAt(i); End.RemoveAt(i); } } Start.Add(start); End.Add(end); } public int GetLineAt(double line) { //use binary search int startIndex = 0; int endIndex = Start.Count - 1; while (endIndex > startIndex) { int i = (startIndex + endIndex) >> 1; // Invariant: i < endIndex if (line > End[i]) { startIndex = i + 1; } else { endIndex = i; } } if (startIndex == endIndex && line <= End[startIndex] && line >= Start[startIndex]) { return startIndex; } else { return -1; } } public double Line { set { _line = value; } get { return _line; } } public ListStart { get { if (_start == null) { _start = new List (); } return _start; } } public List End { get { if (_end == null) { _end = new List (); } return _end; } } public int Count { get { return Start.Count; } } static public double MinLineSeparation { get { return _minLineSeparation; } } private double _line; // X or Y value for set of lines private List _start; // where lines start. Invariant: _start[i] < _end[i] private List _end; // where lines end. Invariant: _end[i] < _start[i+1] private const double _minLineSeparation = 3; // lines closer than this are considered one line } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved. /*++ File: FixedSOMLineRanges.cs Copyright (C) 2005 Microsoft Corporation. All rights reserved. Description: Internal helper class that can store a set of sorted lines by their start and end indices History: 05/17/2005: eleese - Created --*/ namespace System.Windows.Documents { using System.Collections; using System.Collections.Generic; using System.Windows.Shapes; using System.Windows.Controls; using System.Diagnostics; using System.Windows.Media; internal class FixedSOMLineRanges { public void AddRange(double start, double end) { for (int i = 0; i < Start.Count; ) { if (start > End[i] + _minLineSeparation) { i++; } else if (end + _minLineSeparation < Start[i]) { Start.Insert(i, start); End.Insert(i, end); return; } else { // overlap !! if (Start[i] < start) { start = Start[i]; } if (End[i] > end) { end = End[i]; } Start.RemoveAt(i); End.RemoveAt(i); } } Start.Add(start); End.Add(end); } public int GetLineAt(double line) { //use binary search int startIndex = 0; int endIndex = Start.Count - 1; while (endIndex > startIndex) { int i = (startIndex + endIndex) >> 1; // Invariant: i < endIndex if (line > End[i]) { startIndex = i + 1; } else { endIndex = i; } } if (startIndex == endIndex && line <= End[startIndex] && line >= Start[startIndex]) { return startIndex; } else { return -1; } } public double Line { set { _line = value; } get { return _line; } } public List Start { get { if (_start == null) { _start = new List (); } return _start; } } public List End { get { if (_end == null) { _end = new List (); } return _end; } } public int Count { get { return Start.Count; } } static public double MinLineSeparation { get { return _minLineSeparation; } } private double _line; // X or Y value for set of lines private List _start; // where lines start. Invariant: _start[i] < _end[i] private List _end; // where lines end. Invariant: _end[i] < _start[i+1] private const double _minLineSeparation = 3; // lines closer than this are considered one line } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved.
Link Menu

This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- GenericIdentity.cs
- DependencyObject.cs
- ActionFrame.cs
- DrawToolTipEventArgs.cs
- ReadOnlyHierarchicalDataSource.cs
- SspiNegotiationTokenAuthenticatorState.cs
- DbConvert.cs
- SortKey.cs
- ArglessEventHandlerProxy.cs
- HwndTarget.cs
- AnnotationStore.cs
- DataFormats.cs
- PhysicalFontFamily.cs
- NextPreviousPagerField.cs
- XmlSchemaElement.cs
- XmlNamespaceDeclarationsAttribute.cs
- ModelPropertyCollectionImpl.cs
- PageThemeCodeDomTreeGenerator.cs
- ToggleButtonAutomationPeer.cs
- EdmProviderManifest.cs
- QilBinary.cs
- CollectionBuilder.cs
- XmlNamedNodeMap.cs
- DataGridViewCellPaintingEventArgs.cs
- SecureStringHasher.cs
- CachingHintValidation.cs
- DataProtection.cs
- TdsParameterSetter.cs
- ToolStripStatusLabel.cs
- MappingMetadataHelper.cs
- Point3DConverter.cs
- FormatVersion.cs
- DescendantOverDescendantQuery.cs
- MessagePropertyVariants.cs
- StringToken.cs
- StateManagedCollection.cs
- CompositeActivityDesigner.cs
- autovalidator.cs
- XPSSignatureDefinition.cs
- StringAnimationUsingKeyFrames.cs
- Package.cs
- selecteditemcollection.cs
- IgnoreDataMemberAttribute.cs
- OdbcInfoMessageEvent.cs
- UidManager.cs
- DisplayMemberTemplateSelector.cs
- MimePart.cs
- ObfuscationAttribute.cs
- DataKeyArray.cs
- WebPartsPersonalization.cs
- GridViewColumnHeader.cs
- HierarchicalDataBoundControlAdapter.cs
- RegionIterator.cs
- SamlSecurityTokenAuthenticator.cs
- TextBox.cs
- CodeMethodReturnStatement.cs
- PermissionListSet.cs
- BatchWriter.cs
- StreamingContext.cs
- ToolStripSettings.cs
- FontNameEditor.cs
- XomlCompilerParameters.cs
- NodeInfo.cs
- TdsEnums.cs
- BitmapDecoder.cs
- FlowThrottle.cs
- ProcessHost.cs
- SqlDataAdapter.cs
- EdmComplexPropertyAttribute.cs
- GridViewColumnHeader.cs
- ConstraintEnumerator.cs
- VirtualDirectoryMappingCollection.cs
- DependencySource.cs
- DocumentSequence.cs
- _HTTPDateParse.cs
- TreeViewDesigner.cs
- DataContractJsonSerializer.cs
- NamedPipeProcessProtocolHandler.cs
- UrlAuthFailedErrorFormatter.cs
- ThumbAutomationPeer.cs
- XPathNodeList.cs
- WindowClosedEventArgs.cs
- GridViewDesigner.cs
- HierarchicalDataBoundControl.cs
- QilStrConcat.cs
- CompilerCollection.cs
- TargetFrameworkAttribute.cs
- SqlSelectStatement.cs
- SoapRpcMethodAttribute.cs
- MembershipPasswordException.cs
- SafeTimerHandle.cs
- _ListenerAsyncResult.cs
- Transform3DCollection.cs
- ReflectionHelper.cs
- DynamicPropertyHolder.cs
- WindowsTreeView.cs
- ellipse.cs
- DefaultHttpHandler.cs
- PointHitTestParameters.cs
- GrammarBuilder.cs