Code:
/ Dotnetfx_Vista_SP2 / Dotnetfx_Vista_SP2 / 8.0.50727.4016 / DEVDIV / depot / DevDiv / releases / Orcas / QFE / 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
- GenericWebPart.cs
- SafeUserTokenHandle.cs
- SqlReorderer.cs
- SEHException.cs
- DeviceContexts.cs
- MetadataWorkspace.cs
- X509Certificate.cs
- SingleAnimationUsingKeyFrames.cs
- TrustExchangeException.cs
- FigureParaClient.cs
- ClientOptions.cs
- MeasureItemEvent.cs
- _BaseOverlappedAsyncResult.cs
- DisplayMemberTemplateSelector.cs
- RectConverter.cs
- SchemaTypeEmitter.cs
- StrokeNodeOperations2.cs
- NamedObject.cs
- ThreadSafeList.cs
- GridEntry.cs
- XmlStreamNodeWriter.cs
- ModelTreeManager.cs
- SessionConnectionReader.cs
- GridViewCancelEditEventArgs.cs
- AutomationEventArgs.cs
- ListViewItem.cs
- XmlBoundElement.cs
- TextOptions.cs
- PopupEventArgs.cs
- WebPartActionVerb.cs
- AccessedThroughPropertyAttribute.cs
- EditorZoneBase.cs
- SymLanguageType.cs
- LinkedResource.cs
- Type.cs
- PenThread.cs
- UIElement3DAutomationPeer.cs
- BitmapMetadataBlob.cs
- ConfigXmlCDataSection.cs
- OperationAbortedException.cs
- EraserBehavior.cs
- EventLevel.cs
- DateTimeFormat.cs
- SizeConverter.cs
- MultiView.cs
- LocalizeDesigner.cs
- RoutedUICommand.cs
- CustomValidator.cs
- FixedSOMFixedBlock.cs
- BindingSource.cs
- BamlCollectionHolder.cs
- DataColumnMapping.cs
- SafePEFileHandle.cs
- LinkedResourceCollection.cs
- Int32CollectionConverter.cs
- ColumnHeaderConverter.cs
- WindowsAltTab.cs
- Light.cs
- EventProviderWriter.cs
- AncillaryOps.cs
- EpmTargetTree.cs
- TextDecoration.cs
- FormParameter.cs
- KnownTypesProvider.cs
- MaskInputRejectedEventArgs.cs
- RIPEMD160.cs
- VariantWrapper.cs
- UrlSyndicationContent.cs
- SiteMapDataSourceDesigner.cs
- DiscreteKeyFrames.cs
- BuildProviderCollection.cs
- GenericUI.cs
- WebPartVerbsEventArgs.cs
- TreeNodeEventArgs.cs
- TimeoutException.cs
- BaseDataListActionList.cs
- UnsafeNativeMethods.cs
- TextTreeUndo.cs
- ItemDragEvent.cs
- EntityDataSource.cs
- MonitorWrapper.cs
- FixedTextBuilder.cs
- MemberPath.cs
- InfoCardCryptoHelper.cs
- SortedSetDebugView.cs
- XmlTypeAttribute.cs
- QilLiteral.cs
- KeysConverter.cs
- OperationCanceledException.cs
- TypeLoadException.cs
- AssemblyCollection.cs
- AmbientLight.cs
- GridItemCollection.cs
- QilInvokeEarlyBound.cs
- SerializationHelper.cs
- RequestReplyCorrelator.cs
- BaseServiceProvider.cs
- Figure.cs
- BaseCAMarshaler.cs
- GradientSpreadMethodValidation.cs