Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / wpf / src / Framework / System / Windows / Documents / FixedSOMLineRanges.cs / 1305600 / 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
- ManagementEventWatcher.cs
- PersonalizationProviderHelper.cs
- TextCompositionEventArgs.cs
- DetailsViewDeleteEventArgs.cs
- precedingquery.cs
- AxHost.cs
- InkCanvasSelection.cs
- UInt32Converter.cs
- PopOutPanel.cs
- IsolatedStorageFileStream.cs
- XsdDuration.cs
- InputElement.cs
- DurableInstance.cs
- GeometryDrawing.cs
- MSAAWinEventWrap.cs
- MsmqIntegrationAppDomainProtocolHandler.cs
- AssemblyCache.cs
- XmlSerializerNamespaces.cs
- Dump.cs
- XmlSchemaCompilationSettings.cs
- EdmItemCollection.OcAssemblyCache.cs
- HostProtectionPermission.cs
- UserNamePasswordServiceCredential.cs
- NativeMethods.cs
- OutgoingWebRequestContext.cs
- SimpleWebHandlerParser.cs
- FunctionGenerator.cs
- TextChange.cs
- AutomationPatternInfo.cs
- ErrorStyle.cs
- HtmlSelect.cs
- StrokeFIndices.cs
- WebRequestModulesSection.cs
- EditorAttribute.cs
- ListChangedEventArgs.cs
- DeflateStreamAsyncResult.cs
- GridEntry.cs
- PropertySegmentSerializationProvider.cs
- EntityModelSchemaGenerator.cs
- MSHTMLHostUtil.cs
- WSFederationHttpBinding.cs
- TypeSystem.cs
- ReachDocumentReferenceSerializerAsync.cs
- XPathNodeHelper.cs
- ConstraintManager.cs
- QuerySubExprEliminator.cs
- SolidColorBrush.cs
- FieldTemplateFactory.cs
- XmlAttributeProperties.cs
- DictionaryBase.cs
- DebugHandleTracker.cs
- ReadOnlyDictionary.cs
- ColorKeyFrameCollection.cs
- SafeArrayTypeMismatchException.cs
- XhtmlTextWriter.cs
- HeaderedContentControl.cs
- AsyncStreamReader.cs
- SortedList.cs
- StateBag.cs
- DocumentGridContextMenu.cs
- TextMessageEncoder.cs
- DummyDataSource.cs
- Aggregates.cs
- HtmlLiteralTextAdapter.cs
- AdjustableArrowCap.cs
- MultiSelectRootGridEntry.cs
- HttpServerVarsCollection.cs
- SrgsElementFactory.cs
- InstancePersistence.cs
- TakeOrSkipQueryOperator.cs
- ScaleTransform.cs
- SqlAliaser.cs
- NGCSerializationManagerAsync.cs
- XmlRootAttribute.cs
- CodeArgumentReferenceExpression.cs
- WebPartMovingEventArgs.cs
- BufferModeSettings.cs
- _FtpDataStream.cs
- ListViewSelectEventArgs.cs
- validationstate.cs
- MetadataFile.cs
- AliasedSlot.cs
- GeneralTransform3DCollection.cs
- HandlerMappingMemo.cs
- ConstraintCollection.cs
- TextElementEditingBehaviorAttribute.cs
- ReversePositionQuery.cs
- TimeoutException.cs
- EUCJPEncoding.cs
- CommentEmitter.cs
- HttpApplicationStateWrapper.cs
- XmlSerializationReader.cs
- ContentDefinition.cs
- DatagridviewDisplayedBandsData.cs
- ReturnValue.cs
- ZipFileInfoCollection.cs
- InstallerTypeAttribute.cs
- InOutArgumentConverter.cs
- CollectionViewGroupRoot.cs
- ComponentEditorPage.cs