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
- SharedUtils.cs
- EventSchemaTraceListener.cs
- _ChunkParse.cs
- HostingEnvironmentWrapper.cs
- MarginsConverter.cs
- ServiceTimeoutsElement.cs
- XmlLanguageConverter.cs
- Visual3D.cs
- WindowsTitleBar.cs
- ImageClickEventArgs.cs
- HtmlTableRowCollection.cs
- SwitchAttribute.cs
- WebContext.cs
- LogExtentCollection.cs
- EditCommandColumn.cs
- webclient.cs
- DocumentApplicationDocumentViewer.cs
- JsonServiceDocumentSerializer.cs
- SqlLiftIndependentRowExpressions.cs
- SplitterPanel.cs
- Util.cs
- TemplateEditingService.cs
- FontNamesConverter.cs
- FilteredReadOnlyMetadataCollection.cs
- Rect.cs
- ClientSettingsSection.cs
- ListChangedEventArgs.cs
- AdornerHitTestResult.cs
- FileDialog_Vista.cs
- DbQueryCommandTree.cs
- TrustVersion.cs
- SessionParameter.cs
- XmlSchemaImporter.cs
- XsltInput.cs
- LogicalMethodInfo.cs
- StdValidatorsAndConverters.cs
- X509CertificateCollection.cs
- HtmlEncodedRawTextWriter.cs
- NullableDecimalSumAggregationOperator.cs
- EntitySetDataBindingList.cs
- ServiceModelEnumValidatorAttribute.cs
- Border.cs
- BaseTemplateBuildProvider.cs
- Debug.cs
- CompiledRegexRunnerFactory.cs
- wgx_exports.cs
- CroppedBitmap.cs
- CircleHotSpot.cs
- WCFBuildProvider.cs
- IdentityNotMappedException.cs
- SizeF.cs
- CounterCreationData.cs
- StreamGeometryContext.cs
- HttpInputStream.cs
- XmlTextReaderImplHelpers.cs
- ButtonChrome.cs
- SetMemberBinder.cs
- HitTestResult.cs
- TypeDescriptor.cs
- GroupPartitionExpr.cs
- TokenBasedSetEnumerator.cs
- StrokeNodeData.cs
- OdbcParameterCollection.cs
- HandlerWithFactory.cs
- SmtpReplyReaderFactory.cs
- CommandBindingCollection.cs
- NavigationCommands.cs
- ProfessionalColorTable.cs
- SqlUnionizer.cs
- MailMessage.cs
- SQlBooleanStorage.cs
- TimeoutException.cs
- WindowsRichEdit.cs
- ValidationErrorCollection.cs
- PropertyOverridesDialog.cs
- UseLicense.cs
- FtpCachePolicyElement.cs
- Light.cs
- PersonalizableAttribute.cs
- SqlConnectionPoolGroupProviderInfo.cs
- GraphicsPath.cs
- entityreference_tresulttype.cs
- IncrementalHitTester.cs
- Column.cs
- WebPartEventArgs.cs
- SecureStringHasher.cs
- KeysConverter.cs
- PerformanceCountersElement.cs
- EntitySqlQueryState.cs
- ClientBuildManager.cs
- FlowDocumentReaderAutomationPeer.cs
- IndexOutOfRangeException.cs
- CompilationUtil.cs
- Variable.cs
- WriteTimeStream.cs
- XPathDocumentBuilder.cs
- SqlDataSourceQueryConverter.cs
- WeakReferenceList.cs
- SkipStoryboardToFill.cs
- ReferencedAssembly.cs