Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / wpf / src / Framework / System / Windows / Documents / FixedSOMLineCollection.cs / 1305600 / FixedSOMLineCollection.cs
/*++
File: FixedSOMLineCollection.cs
Copyright (C) 2005 Microsoft Corporation. All rights reserved.
Description:
Internal helper class that can store a set of sorted horizontal and vertical FixedSOMLineRanges.
These ranges are used in construction of FixedBlocks and Tables
History:
05/17/2005: agurcan - Created
--*/
namespace System.Windows.Documents
{
using System.Collections.Generic;
using System.Windows.Shapes;
using System.Windows.Media;
using System.Diagnostics;
using System.Windows;
//Stores a collection of horizontal and vertical lines sorted by y and x axis respectively
//
internal sealed class FixedSOMLineCollection
{
//--------------------------------------------------------------------
//
// Constructors
//
//---------------------------------------------------------------------
#region Constructors
public FixedSOMLineCollection()
{
_verticals = new List();
_horizontals = new List();
}
#endregion Constructors
//-------------------------------------------------------------------
//
// Internal Methods
//
//---------------------------------------------------------------------
#region Public Methods
public bool IsVerticallySeparated(double left, double top, double right, double bottom)
{
return _IsSeparated(_verticals, left, top, right, bottom);
}
public bool IsHorizontallySeparated(double left, double top, double right, double bottom)
{
return _IsSeparated(_horizontals, top, left, bottom, right);
}
public void AddVertical(Point point1, Point point2)
{
Debug.Assert(point1.X == point2.X);
_AddLineToRanges(_verticals, point1.X, point1.Y, point2.Y);
}
public void AddHorizontal(Point point1, Point point2)
{
Debug.Assert(point1.Y == point2.Y);
_AddLineToRanges(_horizontals, point1.Y, point1.X, point2.X);
}
#endregion Public Methods
#region Private Methods
//Merge line 2 into line 1
private void _AddLineToRanges(List ranges, double line, double start, double end)
{
if (start > end)
{
double temp = start;
start = end;
end = temp;
}
FixedSOMLineRanges range;
double maxSeparation = .5 * FixedSOMLineRanges.MinLineSeparation;
for (int i=0; i < ranges.Count; i++)
{
if (line < ranges[i].Line - maxSeparation)
{
range = new FixedSOMLineRanges();
range.Line = line;
range.AddRange(start, end);
ranges.Insert(i, range);
return;
}
else if (line < ranges[i].Line + maxSeparation)
{
ranges[i].AddRange(start, end);
return;
}
}
// add to end
range = new FixedSOMLineRanges();
range.Line = line;
range.AddRange(start, end);
ranges.Add(range);
return;
}
//Generic function that decides whether or not a rectangle as spefied by the points is
//divided by any of the lines in the line ranges in the passed in list
private bool _IsSeparated(List lines, double parallelLowEnd, double perpLowEnd, double parallelHighEnd, double perpHighEnd)
{
int startIndex = 0;
int endIndex = lines.Count;
if (endIndex == 0)
{
return false;
}
int i = 0;
while (endIndex > startIndex)
{
i = (startIndex + endIndex) >> 1;
if (lines[i].Line < parallelLowEnd)
{
startIndex = i + 1;
}
else
{
if (lines[i].Line <= parallelHighEnd)
{
break;
}
endIndex = i;
}
}
if (lines[i].Line >= parallelLowEnd && lines[i].Line <= parallelHighEnd)
{
do
{
i--;
} while (i>=0 && lines[i].Line >= parallelLowEnd);
i++;
while (i=0)
{
double end = lines[i].End[rangeIndex];
if (end >= perpHighEnd - allowedMargin)
{
return true;
}
}
i++;
};
}
return false;
}
#endregion Private Methods
#region Public Properties
public List HorizontalLines
{
get
{
return _horizontals;
}
}
public List VerticalLines
{
get
{
return _verticals;
}
}
#endregion Public Properties
//--------------------------------------------------------------------
//
// Private Fields
//
//---------------------------------------------------------------------
#region Private Fields
private List _horizontals;
private List _verticals;
private const double _fudgeFactor = 0.1; // We allow 10% margin at each end
#endregion Private Fields
}
}
// File provided for Reference Use Only by Microsoft Corporation (c) 2007.
// Copyright (c) Microsoft Corporation. All rights reserved.
/*++
File: FixedSOMLineCollection.cs
Copyright (C) 2005 Microsoft Corporation. All rights reserved.
Description:
Internal helper class that can store a set of sorted horizontal and vertical FixedSOMLineRanges.
These ranges are used in construction of FixedBlocks and Tables
History:
05/17/2005: agurcan - Created
--*/
namespace System.Windows.Documents
{
using System.Collections.Generic;
using System.Windows.Shapes;
using System.Windows.Media;
using System.Diagnostics;
using System.Windows;
//Stores a collection of horizontal and vertical lines sorted by y and x axis respectively
//
internal sealed class FixedSOMLineCollection
{
//--------------------------------------------------------------------
//
// Constructors
//
//---------------------------------------------------------------------
#region Constructors
public FixedSOMLineCollection()
{
_verticals = new List();
_horizontals = new List();
}
#endregion Constructors
//-------------------------------------------------------------------
//
// Internal Methods
//
//---------------------------------------------------------------------
#region Public Methods
public bool IsVerticallySeparated(double left, double top, double right, double bottom)
{
return _IsSeparated(_verticals, left, top, right, bottom);
}
public bool IsHorizontallySeparated(double left, double top, double right, double bottom)
{
return _IsSeparated(_horizontals, top, left, bottom, right);
}
public void AddVertical(Point point1, Point point2)
{
Debug.Assert(point1.X == point2.X);
_AddLineToRanges(_verticals, point1.X, point1.Y, point2.Y);
}
public void AddHorizontal(Point point1, Point point2)
{
Debug.Assert(point1.Y == point2.Y);
_AddLineToRanges(_horizontals, point1.Y, point1.X, point2.X);
}
#endregion Public Methods
#region Private Methods
//Merge line 2 into line 1
private void _AddLineToRanges(List ranges, double line, double start, double end)
{
if (start > end)
{
double temp = start;
start = end;
end = temp;
}
FixedSOMLineRanges range;
double maxSeparation = .5 * FixedSOMLineRanges.MinLineSeparation;
for (int i=0; i < ranges.Count; i++)
{
if (line < ranges[i].Line - maxSeparation)
{
range = new FixedSOMLineRanges();
range.Line = line;
range.AddRange(start, end);
ranges.Insert(i, range);
return;
}
else if (line < ranges[i].Line + maxSeparation)
{
ranges[i].AddRange(start, end);
return;
}
}
// add to end
range = new FixedSOMLineRanges();
range.Line = line;
range.AddRange(start, end);
ranges.Add(range);
return;
}
//Generic function that decides whether or not a rectangle as spefied by the points is
//divided by any of the lines in the line ranges in the passed in list
private bool _IsSeparated(List lines, double parallelLowEnd, double perpLowEnd, double parallelHighEnd, double perpHighEnd)
{
int startIndex = 0;
int endIndex = lines.Count;
if (endIndex == 0)
{
return false;
}
int i = 0;
while (endIndex > startIndex)
{
i = (startIndex + endIndex) >> 1;
if (lines[i].Line < parallelLowEnd)
{
startIndex = i + 1;
}
else
{
if (lines[i].Line <= parallelHighEnd)
{
break;
}
endIndex = i;
}
}
if (lines[i].Line >= parallelLowEnd && lines[i].Line <= parallelHighEnd)
{
do
{
i--;
} while (i>=0 && lines[i].Line >= parallelLowEnd);
i++;
while (i=0)
{
double end = lines[i].End[rangeIndex];
if (end >= perpHighEnd - allowedMargin)
{
return true;
}
}
i++;
};
}
return false;
}
#endregion Private Methods
#region Public Properties
public List HorizontalLines
{
get
{
return _horizontals;
}
}
public List VerticalLines
{
get
{
return _verticals;
}
}
#endregion Public Properties
//--------------------------------------------------------------------
//
// Private Fields
//
//---------------------------------------------------------------------
#region Private Fields
private List _horizontals;
private List _verticals;
private const double _fudgeFactor = 0.1; // We allow 10% margin at each end
#endregion Private Fields
}
}
// 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
- PerspectiveCamera.cs
- IPCCacheManager.cs
- DomainLiteralReader.cs
- ContractCodeDomInfo.cs
- WebDescriptionAttribute.cs
- UiaCoreTypesApi.cs
- SrgsSemanticInterpretationTag.cs
- LoadGrammarCompletedEventArgs.cs
- ValueQuery.cs
- SettingsContext.cs
- AQNBuilder.cs
- FileLevelControlBuilderAttribute.cs
- TextDecoration.cs
- SigningCredentials.cs
- ModelChangedEventArgsImpl.cs
- BamlMapTable.cs
- SortedDictionary.cs
- AssemblyNameUtility.cs
- Point3DCollection.cs
- CryptographicAttribute.cs
- CornerRadius.cs
- VsPropertyGrid.cs
- ResolveDuplexCD1AsyncResult.cs
- TypeUtil.cs
- PolyBezierSegmentFigureLogic.cs
- ConfigXmlDocument.cs
- ToolStripDropDownClosingEventArgs.cs
- DetailsViewRow.cs
- _ConnectionGroup.cs
- SqlBooleanMismatchVisitor.cs
- ObjectQueryExecutionPlan.cs
- GeneralTransform3D.cs
- AdapterUtil.cs
- XPathAncestorIterator.cs
- Utility.cs
- EnvironmentPermission.cs
- ZipPackage.cs
- BamlCollectionHolder.cs
- WindowsGraphics.cs
- HttpBrowserCapabilitiesBase.cs
- SerializationAttributes.cs
- UnsafeNativeMethods.cs
- baseshape.cs
- DbConnectionPoolGroup.cs
- NodeLabelEditEvent.cs
- RoleManagerModule.cs
- CharacterMetricsDictionary.cs
- xsdvalidator.cs
- PrimaryKeyTypeConverter.cs
- DataGridViewLinkColumn.cs
- SQLStringStorage.cs
- RowUpdatingEventArgs.cs
- ConstraintStruct.cs
- StringSource.cs
- LogFlushAsyncResult.cs
- HMACSHA256.cs
- TreeViewImageIndexConverter.cs
- HtmlTitle.cs
- WindowPattern.cs
- XmlSchemaElement.cs
- PrintPreviewControl.cs
- Rect3D.cs
- ResponseBodyWriter.cs
- HtmlElement.cs
- DocumentViewerHelper.cs
- OperationBehaviorAttribute.cs
- Parallel.cs
- ToolStripDropDownMenu.cs
- Parsers.cs
- EnumMember.cs
- WSDualHttpBinding.cs
- SafeNativeMemoryHandle.cs
- InputLanguageEventArgs.cs
- ViewStateChangedEventArgs.cs
- EntityDesignerBuildProvider.cs
- OLEDB_Enum.cs
- NameScopePropertyAttribute.cs
- recordstatefactory.cs
- CancelEventArgs.cs
- SystemWebCachingSectionGroup.cs
- SemaphoreFullException.cs
- WebPartMenuStyle.cs
- LinkConverter.cs
- Tuple.cs
- Boolean.cs
- SeekStoryboard.cs
- BitArray.cs
- CheckPair.cs
- SHA1CryptoServiceProvider.cs
- TypeSystem.cs
- EntityContainerEntitySet.cs
- AnimationClockResource.cs
- HttpListenerException.cs
- DataSpaceManager.cs
- ComProxy.cs
- IBuiltInEvidence.cs
- OutputCacheSettings.cs
- CTreeGenerator.cs
- ConfigurationSettings.cs
- SessionEndingEventArgs.cs