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
- TextRunProperties.cs
- QualificationDataAttribute.cs
- _ShellExpression.cs
- HtmlInputCheckBox.cs
- DeferredSelectedIndexReference.cs
- BitmapEffectOutputConnector.cs
- QuaternionAnimationBase.cs
- NamespaceDecl.cs
- XmlIgnoreAttribute.cs
- PageCodeDomTreeGenerator.cs
- ClientSideQueueItem.cs
- NameValuePair.cs
- WebPartUtil.cs
- IgnoreFlushAndCloseStream.cs
- DataContext.cs
- RefreshEventArgs.cs
- CodeCastExpression.cs
- IntSecurity.cs
- TextEditorMouse.cs
- HtmlInputButton.cs
- PolicyException.cs
- SQLMoneyStorage.cs
- Timer.cs
- FactoryGenerator.cs
- TrimSurroundingWhitespaceAttribute.cs
- PhonemeEventArgs.cs
- FormatterServices.cs
- DataSourceXmlSubItemAttribute.cs
- ResourceExpressionBuilder.cs
- AspNetRouteServiceHttpHandler.cs
- TextElementAutomationPeer.cs
- SqlDataReaderSmi.cs
- ProtectedConfigurationSection.cs
- HGlobalSafeHandle.cs
- XamlInt32CollectionSerializer.cs
- XmlResolver.cs
- HostedHttpTransportManager.cs
- ScrollContentPresenter.cs
- SqlReferenceCollection.cs
- HitTestWithPointDrawingContextWalker.cs
- EnumCodeDomSerializer.cs
- RandomDelaySendsAsyncResult.cs
- KeyGesture.cs
- DependencyPropertyKey.cs
- PenCursorManager.cs
- AxDesigner.cs
- ScriptControl.cs
- Vector.cs
- TrackingServices.cs
- WebResourceAttribute.cs
- ProcessHostFactoryHelper.cs
- MenuAdapter.cs
- Statements.cs
- ListViewContainer.cs
- ActivityExecutorOperation.cs
- AsymmetricAlgorithm.cs
- GeneralTransformGroup.cs
- FrameworkContextData.cs
- COM2IProvidePropertyBuilderHandler.cs
- WebFormDesignerActionService.cs
- UpdateExpressionVisitor.cs
- Cursors.cs
- Compiler.cs
- Zone.cs
- UInt64Converter.cs
- Menu.cs
- XmlEventCache.cs
- OleDbCommand.cs
- SqlClientFactory.cs
- ResourceIDHelper.cs
- SecurityManager.cs
- CommandBindingCollection.cs
- OutputCacheProfileCollection.cs
- GridViewSelectEventArgs.cs
- SqlDataSourceCommandEventArgs.cs
- SerializerDescriptor.cs
- PerfCounters.cs
- DataGridAddNewRow.cs
- EdmError.cs
- EtwTrace.cs
- Focus.cs
- KerberosReceiverSecurityToken.cs
- BindingMemberInfo.cs
- CustomWebEventKey.cs
- IntPtr.cs
- ExpanderAutomationPeer.cs
- SecurityUniqueId.cs
- PrintPreviewDialog.cs
- BuildProviderCollection.cs
- DocumentScope.cs
- counter.cs
- MultipleViewPattern.cs
- ThreadExceptionEvent.cs
- CompositeCollectionView.cs
- DecimalStorage.cs
- CommandCollectionEditor.cs
- EntityDataSourceWrapperPropertyDescriptor.cs
- ConfigurationSectionCollection.cs
- BasicCommandTreeVisitor.cs
- FormParameter.cs