本文整理汇总了C#中OxyPlot.Axes.Axis.IsHorizontal方法的典型用法代码示例。如果您正苦于以下问题:C# Axis.IsHorizontal方法的具体用法?C# Axis.IsHorizontal怎么用?C# Axis.IsHorizontal使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类OxyPlot.Axes.Axis
的用法示例。
在下文中一共展示了Axis.IsHorizontal方法的6个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: Render
/// <summary>
/// Renders the specified axis.
/// </summary>
/// <param name="axis">The axis.</param>
/// <param name="pass">The pass.</param>
public override void Render(Axis axis, int pass)
{
base.Render(axis, pass);
double totalShift = axis.AxisDistance + axis.PositionTierMinShift;
double tierSize = axis.PositionTierSize - this.Plot.AxisTierDistance;
// store properties locally for performance
double plotAreaLeft = this.Plot.PlotArea.Left;
double plotAreaRight = this.Plot.PlotArea.Right;
double plotAreaTop = this.Plot.PlotArea.Top;
double plotAreaBottom = this.Plot.PlotArea.Bottom;
// Axis position (x or y screen coordinate)
double axisPosition = 0;
double titlePosition = 0;
switch (axis.Position)
{
case AxisPosition.Left:
axisPosition = plotAreaLeft - totalShift;
titlePosition = axisPosition - tierSize;
break;
case AxisPosition.Right:
axisPosition = plotAreaRight + totalShift;
titlePosition = axisPosition + tierSize;
break;
case AxisPosition.Top:
axisPosition = plotAreaTop - totalShift;
titlePosition = axisPosition - tierSize;
break;
case AxisPosition.Bottom:
axisPosition = plotAreaBottom + totalShift;
titlePosition = axisPosition + tierSize;
break;
}
if (axis.PositionAtZeroCrossing)
{
var perpendicularAxis = axis.IsHorizontal() ? this.Plot.DefaultYAxis : this.Plot.DefaultXAxis;
axisPosition = perpendicularAxis.Transform(0);
}
if (pass == 0)
{
this.RenderMinorItems(axis, axisPosition);
}
if (pass == 1)
{
this.RenderMajorItems(axis, axisPosition, titlePosition);
this.RenderAxisTitle(axis, titlePosition);
}
}
示例2: RenderMinorItems
/// <summary>
/// Renders the minor items.
/// </summary>
/// <param name="axis">The axis.</param>
/// <param name="axisPosition">The axis position.</param>
protected virtual void RenderMinorItems(Axis axis, double axisPosition)
{
double eps = axis.ActualMinorStep * 1e-3;
double actualMinimum = axis.ActualMinimum;
double actualMaximum = axis.ActualMaximum;
double plotAreaLeft = this.Plot.PlotArea.Left;
double plotAreaRight = this.Plot.PlotArea.Right;
double plotAreaTop = this.Plot.PlotArea.Top;
double plotAreaBottom = this.Plot.PlotArea.Bottom;
bool isHorizontal = axis.IsHorizontal();
double a0;
double a1;
var minorSegments = new List<ScreenPoint>();
var minorTickSegments = new List<ScreenPoint>();
this.GetTickPositions(axis, axis.TickStyle, axis.MinorTickSize, axis.Position, out a0, out a1);
foreach (double value in this.MinorTickValues)
{
if (value < actualMinimum - eps || value > actualMaximum + eps)
{
continue;
}
if (this.MajorTickValues.Contains(value))
{
continue;
}
if (axis.PositionAtZeroCrossing && Math.Abs(value) < eps)
{
continue;
}
double transformedValue = axis.Transform(value);
if (isHorizontal)
{
SnapTo(plotAreaLeft, ref transformedValue);
SnapTo(plotAreaRight, ref transformedValue);
}
else
{
SnapTo(plotAreaTop, ref transformedValue);
SnapTo(plotAreaBottom, ref transformedValue);
}
// Draw the minor grid line
if (this.MinorPen != null)
{
if (isHorizontal)
{
minorSegments.Add(new ScreenPoint(transformedValue, plotAreaTop));
minorSegments.Add(new ScreenPoint(transformedValue, plotAreaBottom));
}
else
{
if (transformedValue < plotAreaTop || transformedValue > plotAreaBottom)
{
}
minorSegments.Add(new ScreenPoint(plotAreaLeft, transformedValue));
minorSegments.Add(new ScreenPoint(plotAreaRight, transformedValue));
}
}
// Draw the minor tick
if (axis.TickStyle != TickStyle.None && axis.MinorTickSize > 0)
{
if (isHorizontal)
{
minorTickSegments.Add(new ScreenPoint(transformedValue, axisPosition + a0));
minorTickSegments.Add(new ScreenPoint(transformedValue, axisPosition + a1));
}
else
{
minorTickSegments.Add(new ScreenPoint(axisPosition + a0, transformedValue));
minorTickSegments.Add(new ScreenPoint(axisPosition + a1, transformedValue));
}
}
}
// Draw all the line segments);
if (this.MinorPen != null)
{
this.RenderContext.DrawLineSegments(minorSegments, this.MinorPen);
}
if (this.MinorTickPen != null)
{
this.RenderContext.DrawLineSegments(minorTickSegments, this.MinorTickPen);
}
}
示例3: Render
/// <summary>
/// Renders the specified axis.
/// </summary>
/// <param name="axis">The axis.</param>
/// <param name="pass">The pass.</param>
public override void Render(Axis axis, int pass)
{
base.Render(axis, pass);
bool drawAxisLine = true;
double totalShift = axis.AxisDistance + axis.PositionTierMinShift;
double tierSize = axis.PositionTierSize - this.Plot.AxisTierDistance;
// store properties locally for performance
double plotAreaLeft = this.Plot.PlotArea.Left;
double plotAreaRight = this.Plot.PlotArea.Right;
double plotAreaTop = this.Plot.PlotArea.Top;
double plotAreaBottom = this.Plot.PlotArea.Bottom;
// Axis position (x or y screen coordinate)
double axisPosition = 0;
double titlePosition = 0;
switch (axis.Position)
{
case AxisPosition.Left:
axisPosition = plotAreaLeft - totalShift;
break;
case AxisPosition.Right:
axisPosition = plotAreaRight + totalShift;
break;
case AxisPosition.Top:
axisPosition = plotAreaTop - totalShift;
break;
case AxisPosition.Bottom:
axisPosition = plotAreaBottom + totalShift;
break;
}
if (axis.PositionAtZeroCrossing)
{
var perpendicularAxis = axis.IsHorizontal() ? this.Plot.DefaultYAxis : this.Plot.DefaultXAxis;
// the axis should be positioned at the origin of the perpendicular axis
axisPosition = perpendicularAxis.Transform(0);
var p0 = perpendicularAxis.Transform(perpendicularAxis.ActualMinimum);
var p1 = perpendicularAxis.Transform(perpendicularAxis.ActualMaximum);
// find the min/max positions
var min = Math.Min(p0, p1);
var max = Math.Max(p0, p1);
// also consider the plot area
var areaMin = axis.IsHorizontal() ? plotAreaTop : plotAreaLeft;
var areaMax = axis.IsHorizontal() ? plotAreaBottom : plotAreaRight;
min = Math.Max(min, areaMin);
max = Math.Min(max, areaMax);
if (axisPosition < min)
{
axisPosition = min;
var borderThickness = axis.IsHorizontal()
? this.Plot.PlotAreaBorderThickness.Top
: this.Plot.PlotAreaBorderThickness.Left;
if (borderThickness > 0 && this.Plot.PlotAreaBorderColor.IsVisible())
{
// there is already a line here...
drawAxisLine = false;
}
}
if (axisPosition > max)
{
axisPosition = max;
var borderThickness = axis.IsHorizontal()
? this.Plot.PlotAreaBorderThickness.Bottom
: this.Plot.PlotAreaBorderThickness.Right;
if (borderThickness > 0 && this.Plot.PlotAreaBorderColor.IsVisible())
{
// there is already a line here...
drawAxisLine = false;
}
}
}
switch (axis.Position)
{
case AxisPosition.Left:
titlePosition = axisPosition - tierSize;
break;
case AxisPosition.Right:
titlePosition = axisPosition + tierSize;
break;
case AxisPosition.Top:
titlePosition = axisPosition - tierSize;
break;
case AxisPosition.Bottom:
//.........这里部分代码省略.........
示例4: RenderMajorItems
/// <summary>
/// Renders the major items.
/// </summary>
/// <param name="axis">The axis.</param>
/// <param name="axisPosition">The axis position.</param>
/// <param name="titlePosition">The title position.</param>
/// <param name="drawAxisLine">Draw the axis line if set to <c>true</c>.</param>
protected virtual void RenderMajorItems(Axis axis, double axisPosition, double titlePosition, bool drawAxisLine)
{
double eps = axis.ActualMinorStep * 1e-3;
double actualMinimum = axis.ActualMinimum;
double actualMaximum = axis.ActualMaximum;
double plotAreaLeft = this.Plot.PlotArea.Left;
double plotAreaRight = this.Plot.PlotArea.Right;
double plotAreaTop = this.Plot.PlotArea.Top;
double plotAreaBottom = this.Plot.PlotArea.Bottom;
bool isHorizontal = axis.IsHorizontal();
double a0;
double a1;
var majorSegments = new List<ScreenPoint>();
var majorTickSegments = new List<ScreenPoint>();
this.GetTickPositions(axis, axis.TickStyle, axis.MajorTickSize, axis.Position, out a0, out a1);
foreach (double value in this.MajorTickValues)
{
if (value < actualMinimum - eps || value > actualMaximum + eps)
{
continue;
}
if (axis.PositionAtZeroCrossing && Math.Abs(value) < eps)
{
continue;
}
double transformedValue = axis.Transform(value);
if (isHorizontal)
{
SnapTo(plotAreaLeft, ref transformedValue);
SnapTo(plotAreaRight, ref transformedValue);
}
else
{
SnapTo(plotAreaTop, ref transformedValue);
SnapTo(plotAreaBottom, ref transformedValue);
}
if (this.MajorPen != null)
{
if (isHorizontal)
{
majorSegments.Add(new ScreenPoint(transformedValue, plotAreaTop));
majorSegments.Add(new ScreenPoint(transformedValue, plotAreaBottom));
}
else
{
majorSegments.Add(new ScreenPoint(plotAreaLeft, transformedValue));
majorSegments.Add(new ScreenPoint(plotAreaRight, transformedValue));
}
}
if (axis.TickStyle != TickStyle.None && axis.MajorTickSize > 0)
{
if (isHorizontal)
{
majorTickSegments.Add(new ScreenPoint(transformedValue, axisPosition + a0));
majorTickSegments.Add(new ScreenPoint(transformedValue, axisPosition + a1));
}
else
{
majorTickSegments.Add(new ScreenPoint(axisPosition + a0, transformedValue));
majorTickSegments.Add(new ScreenPoint(axisPosition + a1, transformedValue));
}
}
}
// Render the axis labels (numbers or category names)
foreach (double value in this.MajorLabelValues)
{
if (value < actualMinimum - eps || value > actualMaximum + eps)
{
continue;
}
if (axis.PositionAtZeroCrossing && Math.Abs(value) < eps)
{
continue;
}
double transformedValue = axis.Transform(value);
if (isHorizontal)
{
SnapTo(plotAreaLeft, ref transformedValue);
SnapTo(plotAreaRight, ref transformedValue);
}
else
{
//.........这里部分代码省略.........
示例5: RenderAxisTitle
/// <summary>
/// Renders the axis title.
/// </summary>
/// <param name="axis">The axis.</param>
/// <param name="titlePosition">The title position.</param>
protected virtual void RenderAxisTitle(Axis axis, double titlePosition)
{
if (string.IsNullOrEmpty(axis.ActualTitle))
{
return;
}
bool isHorizontal = axis.IsHorizontal();
OxySize? maxSize = null;
if (axis.ClipTitle)
{
// Calculate the title clipping dimensions
double screenLength = isHorizontal
? Math.Abs(axis.ScreenMax.X - axis.ScreenMin.X)
: Math.Abs(axis.ScreenMax.Y - axis.ScreenMin.Y);
maxSize = new OxySize(screenLength * axis.TitleClippingLength, double.MaxValue);
}
double angle = -90;
var halign = HorizontalAlignment.Center;
var valign = VerticalAlignment.Top;
var lpt = this.GetAxisTitlePositionAndAlignment(axis, titlePosition, ref angle, ref halign, ref valign);
this.RenderContext.DrawMathText(
lpt,
axis.ActualTitle,
axis.ActualTitleColor,
axis.ActualTitleFont,
axis.ActualTitleFontSize,
axis.ActualTitleFontWeight,
angle,
halign,
valign,
maxSize);
}
示例6: GetAxisTitlePositionAndAlignment
/// <summary>
/// Gets the axis title position, rotation and alignment.
/// </summary>
/// <param name="axis">The axis.</param>
/// <param name="titlePosition">The title position.</param>
/// <param name="angle">The angle.</param>
/// <param name="halign">The horizontal alignment.</param>
/// <param name="valign">The vertical alignment.</param>
/// <returns>The <see cref="ScreenPoint" />.</returns>
protected virtual ScreenPoint GetAxisTitlePositionAndAlignment(
Axis axis,
double titlePosition,
ref double angle,
ref HorizontalAlignment halign,
ref VerticalAlignment valign)
{
double middle = axis.IsHorizontal()
? Lerp(axis.ScreenMin.X, axis.ScreenMax.X, axis.TitlePosition)
: Lerp(axis.ScreenMax.Y, axis.ScreenMin.Y, axis.TitlePosition);
if (axis.PositionAtZeroCrossing)
{
middle = Lerp(axis.Transform(axis.ActualMaximum), axis.Transform(axis.ActualMinimum), axis.TitlePosition);
}
switch (axis.Position)
{
case AxisPosition.Left:
return new ScreenPoint(titlePosition, middle);
case AxisPosition.Right:
valign = VerticalAlignment.Bottom;
return new ScreenPoint(titlePosition, middle);
case AxisPosition.Top:
halign = HorizontalAlignment.Center;
valign = VerticalAlignment.Top;
angle = 0;
return new ScreenPoint(middle, titlePosition);
case AxisPosition.Bottom:
halign = HorizontalAlignment.Center;
valign = VerticalAlignment.Bottom;
angle = 0;
return new ScreenPoint(middle, titlePosition);
default:
throw new ArgumentOutOfRangeException("axis");
}
}