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
- NotificationContext.cs
- NetMsmqSecurityMode.cs
- BrowserCapabilitiesCompiler.cs
- Material.cs
- PropertyGeneratedEventArgs.cs
- EditingCoordinator.cs
- SqlAliaser.cs
- ServiceModelConfigurationSectionCollection.cs
- DataContractSerializerOperationFormatter.cs
- SerializationObjectManager.cs
- PerformanceCounterTraceRecord.cs
- NoneExcludedImageIndexConverter.cs
- MetadataImporter.cs
- MappableObjectManager.cs
- WindowsIPAddress.cs
- ErrorInfoXmlDocument.cs
- SafeNativeMethodsOther.cs
- StrongNameMembershipCondition.cs
- MetadataProperty.cs
- isolationinterop.cs
- WebDescriptionAttribute.cs
- X509CertificateCollection.cs
- KeyBinding.cs
- AutomationIdentifier.cs
- HtmlTableCellCollection.cs
- RandomNumberGenerator.cs
- CompressStream.cs
- BitmapEffectCollection.cs
- Deserializer.cs
- TextEncodedRawTextWriter.cs
- TextParaClient.cs
- AnimatedTypeHelpers.cs
- ViewManager.cs
- ParameterToken.cs
- DataPager.cs
- WebPartDeleteVerb.cs
- HtmlTableCellCollection.cs
- SymmetricCryptoHandle.cs
- DatatypeImplementation.cs
- _NetRes.cs
- InputMethodStateChangeEventArgs.cs
- NullReferenceException.cs
- Style.cs
- UpdateException.cs
- XmlSchemaSimpleType.cs
- OrderByQueryOptionExpression.cs
- DetailsViewDeletedEventArgs.cs
- XmlSerializerVersionAttribute.cs
- SqlBulkCopyColumnMappingCollection.cs
- CannotUnloadAppDomainException.cs
- SemanticResolver.cs
- DrawingContextDrawingContextWalker.cs
- SafeFileMappingHandle.cs
- FileDataSourceCache.cs
- QueryCacheEntry.cs
- VirtualDirectoryMappingCollection.cs
- XmlMemberMapping.cs
- Queue.cs
- SendActivityEventArgs.cs
- TracedNativeMethods.cs
- MessageLogTraceRecord.cs
- RuleRefElement.cs
- AppDomainShutdownMonitor.cs
- PropertyGridDesigner.cs
- DataGridViewColumnCollection.cs
- RequiredFieldValidator.cs
- BamlTreeMap.cs
- NullableDoubleMinMaxAggregationOperator.cs
- Version.cs
- Transform3DGroup.cs
- RuntimeConfigurationRecord.cs
- SubclassTypeValidator.cs
- SafeCoTaskMem.cs
- PtsPage.cs
- ExpressionLexer.cs
- Perspective.cs
- Shape.cs
- Vector3DKeyFrameCollection.cs
- ForceCopyBuildProvider.cs
- GridViewDeleteEventArgs.cs
- XmlSerializerVersionAttribute.cs
- X509RecipientCertificateServiceElement.cs
- ADConnectionHelper.cs
- ButtonField.cs
- ProfessionalColors.cs
- LazyTextWriterCreator.cs
- HelloOperationAsyncResult.cs
- Cursor.cs
- initElementDictionary.cs
- DeadCharTextComposition.cs
- CommentAction.cs
- COMException.cs
- ConfigurationHelpers.cs
- RequestResizeEvent.cs
- SharedStatics.cs
- ObjectDataSourceDesigner.cs
- ClosureBinding.cs
- GridViewHeaderRowPresenterAutomationPeer.cs
- StaticSiteMapProvider.cs
- MenuEventArgs.cs