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
- UTF32Encoding.cs
- MailAddress.cs
- RequestQueue.cs
- _ListenerResponseStream.cs
- ToolboxComponentsCreatedEventArgs.cs
- EntityReference.cs
- DataShape.cs
- Message.cs
- Rect.cs
- HashCodeCombiner.cs
- ColumnCollectionEditor.cs
- ColorContext.cs
- CommonXSendMessage.cs
- XmlSequenceWriter.cs
- ComponentEditorForm.cs
- nulltextcontainer.cs
- TouchesOverProperty.cs
- Property.cs
- ProcessHostConfigUtils.cs
- TrimSurroundingWhitespaceAttribute.cs
- PrincipalPermission.cs
- OracleCommand.cs
- HttpPostedFileBase.cs
- NamespaceInfo.cs
- OutputCacheProfileCollection.cs
- QuaternionAnimation.cs
- OdbcConnectionFactory.cs
- StrokeSerializer.cs
- WindowsSysHeader.cs
- linebase.cs
- DataListItem.cs
- Point4DValueSerializer.cs
- AutoFocusStyle.xaml.cs
- EtwTrackingParticipant.cs
- LayoutEditorPart.cs
- TextSpanModifier.cs
- SqlServer2KCompatibilityCheck.cs
- JsonDataContract.cs
- XmlCodeExporter.cs
- HostingPreferredMapPath.cs
- SrgsElementFactoryCompiler.cs
- Property.cs
- StylusPointProperty.cs
- SqlUtils.cs
- HTMLTextWriter.cs
- Utils.cs
- TabRenderer.cs
- XmlSerializationWriter.cs
- XsltInput.cs
- RequestDescription.cs
- SystemWebCachingSectionGroup.cs
- LabelTarget.cs
- InplaceBitmapMetadataWriter.cs
- PageAdapter.cs
- XmlObjectSerializerReadContext.cs
- SimpleTableProvider.cs
- GlyphInfoList.cs
- ObjectItemCollectionAssemblyCacheEntry.cs
- ConstraintStruct.cs
- DispatcherEventArgs.cs
- RoutedEventValueSerializer.cs
- CharUnicodeInfo.cs
- OTFRasterizer.cs
- XamlReader.cs
- QuestionEventArgs.cs
- EntityKeyElement.cs
- ServiceObjectContainer.cs
- DataGridTableCollection.cs
- TextAction.cs
- PeerApplication.cs
- TableCellAutomationPeer.cs
- Screen.cs
- WebBrowserUriTypeConverter.cs
- ProgressBarRenderer.cs
- MarkupCompiler.cs
- AnnotationResource.cs
- BuildProvidersCompiler.cs
- ContentPosition.cs
- AttachedPropertyBrowsableForTypeAttribute.cs
- NetStream.cs
- ServiceBuildProvider.cs
- SqlNode.cs
- ClientTarget.cs
- DataTableExtensions.cs
- SqlDataSourceFilteringEventArgs.cs
- Control.cs
- UriTemplatePathPartiallyEquivalentSet.cs
- ToolStripGripRenderEventArgs.cs
- BulletChrome.cs
- XmlUrlResolver.cs
- AsyncStreamReader.cs
- Queue.cs
- NameTable.cs
- BindUriHelper.cs
- EventSinkHelperWriter.cs
- ObjectDataSourceStatusEventArgs.cs
- ExceptionCollection.cs
- TransformCryptoHandle.cs
- SerTrace.cs
- FrameDimension.cs