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
- FontStyles.cs
- SocketPermission.cs
- ConfigurationProviderException.cs
- ParseChildrenAsPropertiesAttribute.cs
- Operator.cs
- SelectionRange.cs
- DayRenderEvent.cs
- DocumentReference.cs
- ErrorWebPart.cs
- RemotingServices.cs
- BaseParagraph.cs
- DropDownButton.cs
- TemplateBindingExpressionConverter.cs
- FormsAuthenticationUser.cs
- IgnoreFileBuildProvider.cs
- MatrixConverter.cs
- HMACSHA384.cs
- TypedDataSetSchemaImporterExtensionFx35.cs
- SqlNotificationEventArgs.cs
- OleDbInfoMessageEvent.cs
- ConsoleKeyInfo.cs
- IteratorFilter.cs
- UpnEndpointIdentityExtension.cs
- HwndSource.cs
- __Filters.cs
- UdpContractFilterBehavior.cs
- LogStore.cs
- DataProtectionSecurityStateEncoder.cs
- DiagnosticSection.cs
- ValueExpressions.cs
- DrawTreeNodeEventArgs.cs
- Int64AnimationBase.cs
- EntityCollectionChangedParams.cs
- TableItemPatternIdentifiers.cs
- TableLayoutStyleCollection.cs
- XmlMembersMapping.cs
- InteropTrackingRecord.cs
- WebServiceMethodData.cs
- ScriptingJsonSerializationSection.cs
- ListViewItemSelectionChangedEvent.cs
- XMLSchema.cs
- TextFormatter.cs
- SqlDataSourceTableQuery.cs
- SiteMapNodeCollection.cs
- TransformGroup.cs
- QueryStringConverter.cs
- DataServiceRequest.cs
- PointAnimationClockResource.cs
- HitTestWithPointDrawingContextWalker.cs
- ContractHandle.cs
- TextViewSelectionProcessor.cs
- MaterialGroup.cs
- QilPatternVisitor.cs
- SqlColumnizer.cs
- OperationAbortedException.cs
- SerializerDescriptor.cs
- SmiEventSink.cs
- SimpleApplicationHost.cs
- ProxyElement.cs
- SynchronizedDispatch.cs
- RegexTree.cs
- SettingsPropertyCollection.cs
- Point3DAnimationBase.cs
- BookmarkNameHelper.cs
- BaseCAMarshaler.cs
- QueryOptionExpression.cs
- PerfService.cs
- BlobPersonalizationState.cs
- RuntimeVariablesExpression.cs
- DataGridViewComboBoxColumn.cs
- QuotedStringWriteStateInfo.cs
- GeneralTransformCollection.cs
- WSSecurityTokenSerializer.cs
- PageParser.cs
- AxisAngleRotation3D.cs
- RewritingProcessor.cs
- DefaultBindingPropertyAttribute.cs
- HMACRIPEMD160.cs
- BuildManager.cs
- RankException.cs
- WindowsTooltip.cs
- SqlMethodCallConverter.cs
- SoapServerMethod.cs
- InstanceCreationEditor.cs
- DataRow.cs
- ItemChangedEventArgs.cs
- SqlStatistics.cs
- TraceHandler.cs
- InvalidOperationException.cs
- EqualityComparer.cs
- NavigationPropertyAccessor.cs
- CalendarButton.cs
- HwndProxyElementProvider.cs
- FileDataSourceCache.cs
- AutomationPeer.cs
- RequestNavigateEventArgs.cs
- Ref.cs
- CodeStatementCollection.cs
- RotationValidation.cs
- StackSpiller.Generated.cs