mirror of https://github.com/ArduPilot/ardupilot
1956 lines
73 KiB
C#
1956 lines
73 KiB
C#
// Copyright (C) 2007 A.J.Bauer - Modified for multiple needles and scaling - Michael Oborne 2011
|
|
//
|
|
// This software is provided as-is, without any express or implied
|
|
// warranty. In no event will the authors be held liable for any damages
|
|
// arising from the use of this software.
|
|
|
|
// Permission is granted to anyone to use this software for any purpose,
|
|
// including commercial applications, and to alter it and redistribute it
|
|
// freely, subject to the following restrictions:
|
|
|
|
// 1. The origin of this software must not be misrepresented; you must not
|
|
// claim that you wrote the original software. if you use this software
|
|
// in a product, an acknowledgment in the product documentation would be
|
|
// appreciated but is not required.
|
|
// 2. Altered source versions must be plainly marked as such, and must not be
|
|
// misrepresented as being the original software.
|
|
// 3. This notice may not be removed or altered from any source distribution.
|
|
|
|
using System;
|
|
using System.Collections.Generic;
|
|
using System.ComponentModel;
|
|
using System.Data;
|
|
using System.Drawing;
|
|
using System.Text;
|
|
using System.Windows.Forms;
|
|
using System.Drawing.Drawing2D;
|
|
using System.Diagnostics;
|
|
|
|
|
|
namespace AGaugeApp
|
|
{
|
|
[ToolboxBitmapAttribute(typeof(AGauge), "AGauge.bmp"),
|
|
DefaultEvent("ValueInRangeChanged"),
|
|
Description("Displays a value on an analog gauge. Raises an event if the value enters one of the definable ranges.")]
|
|
public partial class AGauge : MyUserControl
|
|
{
|
|
#region enum, var, delegate, event
|
|
public enum NeedleColorEnum
|
|
{
|
|
Gray = 0,
|
|
Red = 1,
|
|
Green = 2,
|
|
Blue = 3,
|
|
Yellow = 4,
|
|
Violet = 5,
|
|
Magenta = 6
|
|
};
|
|
|
|
private const Byte ZERO = 0;
|
|
private const Byte NUMOFCAPS = 5;
|
|
private const Byte NUMOFRANGES = 5;
|
|
|
|
private Single fontBoundY1;
|
|
private Single fontBoundY2;
|
|
private Bitmap gaugeBitmap;
|
|
private Boolean drawGaugeBackground = true;
|
|
|
|
private Boolean[] m_valueIsInRange = { false, false, false, false, false };
|
|
private Byte m_CapIdx = 1;
|
|
private Color[] m_CapColor = { Color.Black, Color.Black, Color.Black, Color.Black, Color.Black };
|
|
private String[] m_CapText = { "", "", "", "", "" };
|
|
private Point[] m_CapPosition = { new Point(10, 10), new Point(10, 10), new Point(10, 10), new Point(10, 10), new Point(10, 10) };
|
|
private Point m_Center = new Point(100, 100);
|
|
private Single m_MinValue = -100;
|
|
private Single m_MaxValue = 400;
|
|
|
|
private Color m_BaseArcColor = Color.Gray;
|
|
private Int32 m_BaseArcRadius = 80;
|
|
private Int32 m_BaseArcStart = 135;
|
|
private Int32 m_BaseArcSweep = 270;
|
|
private Int32 m_BaseArcWidth = 2;
|
|
|
|
private Color m_ScaleLinesInterColor = Color.Black;
|
|
private Int32 m_ScaleLinesInterInnerRadius = 73;
|
|
private Int32 m_ScaleLinesInterOuterRadius = 80;
|
|
private Int32 m_ScaleLinesInterWidth = 1;
|
|
|
|
private Int32 m_ScaleLinesMinorNumOf = 9;
|
|
private Color m_ScaleLinesMinorColor = Color.Gray;
|
|
private Int32 m_ScaleLinesMinorInnerRadius = 75;
|
|
private Int32 m_ScaleLinesMinorOuterRadius = 80;
|
|
private Int32 m_ScaleLinesMinorWidth = 1;
|
|
|
|
private Single m_ScaleLinesMajorStepValue = 50.0f;
|
|
private Color m_ScaleLinesMajorColor = Color.Black;
|
|
private Int32 m_ScaleLinesMajorInnerRadius = 70;
|
|
private Int32 m_ScaleLinesMajorOuterRadius = 80;
|
|
private Int32 m_ScaleLinesMajorWidth = 2;
|
|
|
|
private Byte m_RangeIdx;
|
|
private Boolean[] m_RangeEnabled = { true, true, false, false, false };
|
|
private Color[] m_RangeColor = { Color.LightGreen, Color.Red, Color.FromKnownColor(KnownColor.Control), Color.FromKnownColor(KnownColor.Control), Color.FromKnownColor(KnownColor.Control) };
|
|
private Single[] m_RangeStartValue = { -100.0f, 300.0f, 0.0f, 0.0f, 0.0f };
|
|
private Single[] m_RangeEndValue = { 300.0f, 400.0f, 0.0f, 0.0f, 0.0f };
|
|
private Int32[] m_RangeInnerRadius = { 70, 70, 70, 70, 70 };
|
|
private Int32[] m_RangeOuterRadius = { 80, 80, 80, 80, 80 };
|
|
|
|
private Int32 m_ScaleNumbersRadius = 95;
|
|
private Color m_ScaleNumbersColor = Color.Black;
|
|
private String m_ScaleNumbersFormat;
|
|
private Int32 m_ScaleNumbersStartScaleLine;
|
|
private Int32 m_ScaleNumbersStepScaleLines = 1;
|
|
private Int32 m_ScaleNumbersRotation = 0;
|
|
|
|
private Byte m_NeedIdx = 0;
|
|
private Int32[] m_NeedleType = { 0, 0, 0, 0 };
|
|
private Int32[] m_NeedleRadius = { 80, 80, 80, 80};
|
|
private NeedleColorEnum[] m_NeedleColor1 = { NeedleColorEnum.Gray, NeedleColorEnum.Gray, NeedleColorEnum.Gray, NeedleColorEnum.Gray };
|
|
private Color[] m_NeedleColor2 = { Color.DimGray, Color.DimGray, Color.DimGray, Color.DimGray };
|
|
private Int32[] m_NeedleWidth = { 2, 2, 2, 2 };
|
|
private bool[] m_NeedleEnabled = { true, false, false, false };
|
|
|
|
private Single[] m_value = { 0, 0, 0, 0 };
|
|
|
|
public class ValueInRangeChangedEventArgs : EventArgs
|
|
{
|
|
public Int32 valueInRange;
|
|
|
|
public ValueInRangeChangedEventArgs(Int32 valueInRange)
|
|
{
|
|
this.valueInRange = valueInRange;
|
|
}
|
|
}
|
|
|
|
public delegate void ValueInRangeChangedDelegate(Object sender, ValueInRangeChangedEventArgs e);
|
|
[Description("This event is raised if the value falls into a defined range.")]
|
|
public event ValueInRangeChangedDelegate ValueInRangeChanged;
|
|
#endregion
|
|
|
|
#region hidden , overridden inherited properties
|
|
public new Boolean AllowDrop
|
|
{
|
|
get
|
|
{
|
|
return false;
|
|
}
|
|
set
|
|
{
|
|
|
|
}
|
|
}
|
|
public new Boolean AutoSize
|
|
{
|
|
get
|
|
{
|
|
return false;
|
|
}
|
|
set
|
|
{
|
|
|
|
}
|
|
}
|
|
public new Boolean ForeColor
|
|
{
|
|
get
|
|
{
|
|
return false;
|
|
}
|
|
set
|
|
{
|
|
}
|
|
}
|
|
public new Boolean ImeMode
|
|
{
|
|
get
|
|
{
|
|
return false;
|
|
}
|
|
set
|
|
{
|
|
}
|
|
}
|
|
|
|
public override System.Drawing.Color BackColor
|
|
{
|
|
get
|
|
{
|
|
return base.BackColor;
|
|
}
|
|
set
|
|
{
|
|
base.BackColor = value;
|
|
drawGaugeBackground = true;
|
|
Refresh();
|
|
}
|
|
}
|
|
public override System.Drawing.Font Font
|
|
{
|
|
get
|
|
{
|
|
return base.Font;
|
|
}
|
|
set
|
|
{
|
|
base.Font = value;
|
|
drawGaugeBackground = true;
|
|
Refresh();
|
|
}
|
|
}
|
|
public override System.Windows.Forms.ImageLayout BackgroundImageLayout
|
|
{
|
|
get
|
|
{
|
|
return base.BackgroundImageLayout;
|
|
}
|
|
set
|
|
{
|
|
base.BackgroundImageLayout = value;
|
|
drawGaugeBackground = true;
|
|
Refresh();
|
|
}
|
|
}
|
|
#endregion
|
|
|
|
public AGauge()
|
|
{
|
|
InitializeComponent();
|
|
|
|
SetStyle(ControlStyles.OptimizedDoubleBuffer, true);
|
|
}
|
|
|
|
#region properties
|
|
[System.ComponentModel.Browsable(true)]
|
|
public Single Value0 { get { return m_value[0]; } set { m_NeedIdx = 0; m_value[0] = value; this.Invalidate(); } }
|
|
[System.ComponentModel.Browsable(true)]
|
|
public Single Value1 { get { return m_value[1]; } set { m_NeedIdx = 1; m_value[1] = value; this.Invalidate(); } }
|
|
[System.ComponentModel.Browsable(true)]
|
|
public Single Value2 { get { return m_value[2]; } set { m_NeedIdx = 2; m_value[2] = value; this.Invalidate(); } }
|
|
[System.ComponentModel.Browsable(true)]
|
|
public Single Value3 { get { return m_value[3]; } set { m_NeedIdx = 3; m_value[3] = value; this.Invalidate(); } }
|
|
|
|
[System.ComponentModel.Browsable(true),
|
|
System.ComponentModel.Category("AGauge"),
|
|
System.ComponentModel.Description("The value.")]
|
|
public Single Value
|
|
{
|
|
get
|
|
{
|
|
return m_value[m_NeedIdx];
|
|
}
|
|
set
|
|
{
|
|
if (m_value[m_NeedIdx] != value)
|
|
{
|
|
m_value[m_NeedIdx] = Math.Min(Math.Max(value, m_MinValue), m_MaxValue);
|
|
|
|
if (this.DesignMode)
|
|
{
|
|
drawGaugeBackground = true;
|
|
}
|
|
|
|
for (Int32 counter = 0; counter < NUMOFRANGES - 1; counter++)
|
|
{
|
|
if ((m_RangeStartValue[counter] <= m_value[m_NeedIdx])
|
|
&& (m_value[m_NeedIdx] <= m_RangeEndValue[counter])
|
|
&& (m_RangeEnabled[counter]))
|
|
{
|
|
if (!m_valueIsInRange[counter])
|
|
{
|
|
if (ValueInRangeChanged!=null)
|
|
{
|
|
ValueInRangeChanged(this, new ValueInRangeChangedEventArgs(counter));
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
m_valueIsInRange[counter] = false;
|
|
}
|
|
}
|
|
Refresh();
|
|
}
|
|
}
|
|
}
|
|
|
|
[System.ComponentModel.Browsable(true),
|
|
System.ComponentModel.Category("AGauge"),
|
|
System.ComponentModel.RefreshProperties(RefreshProperties.All),
|
|
System.ComponentModel.Description("The caption index. set this to a value of 0 up to 4 to change the corresponding caption's properties.")]
|
|
public Byte Cap_Idx
|
|
{
|
|
get
|
|
{
|
|
return m_CapIdx;
|
|
}
|
|
set
|
|
{
|
|
if ((m_CapIdx != value)
|
|
&& (0 <= value)
|
|
&& (value < 5))
|
|
{
|
|
m_CapIdx = value;
|
|
}
|
|
}
|
|
}
|
|
|
|
[System.ComponentModel.Browsable(true),
|
|
System.ComponentModel.Category("AGauge"),
|
|
System.ComponentModel.Description("The color of the caption text.")]
|
|
public Color CapColor
|
|
{
|
|
get
|
|
{
|
|
return m_CapColor[m_CapIdx];
|
|
}
|
|
set
|
|
{
|
|
if (m_CapColor[m_CapIdx] != value)
|
|
{
|
|
m_CapColor[m_CapIdx] = value;
|
|
CapColors = m_CapColor;
|
|
drawGaugeBackground = true;
|
|
Refresh();
|
|
}
|
|
}
|
|
}
|
|
|
|
[System.ComponentModel.Browsable(false)]
|
|
public Color[] CapColors
|
|
{
|
|
get
|
|
{
|
|
return m_CapColor;
|
|
}
|
|
set
|
|
{
|
|
m_CapColor = value;
|
|
}
|
|
}
|
|
|
|
[System.ComponentModel.Browsable(true),
|
|
System.ComponentModel.Category("AGauge"),
|
|
System.ComponentModel.Description("The text of the caption.")]
|
|
public String CapText
|
|
{
|
|
get
|
|
{
|
|
return m_CapText[m_CapIdx];
|
|
}
|
|
set
|
|
{
|
|
if (m_CapText[m_CapIdx] != value)
|
|
{
|
|
m_CapText[m_CapIdx] = value;
|
|
CapsText = m_CapText;
|
|
drawGaugeBackground = true;
|
|
Refresh();
|
|
}
|
|
}
|
|
}
|
|
|
|
[System.ComponentModel.Browsable(false)]
|
|
public String[] CapsText
|
|
{
|
|
get
|
|
{
|
|
return m_CapText;
|
|
}
|
|
set
|
|
{
|
|
for (Int32 counter = 0; counter < 5; counter++)
|
|
{
|
|
m_CapText[counter] = value[counter];
|
|
}
|
|
}
|
|
}
|
|
|
|
[System.ComponentModel.Browsable(true),
|
|
System.ComponentModel.Category("AGauge"),
|
|
System.ComponentModel.Description("The position of the caption.")]
|
|
public Point CapPosition
|
|
{
|
|
get
|
|
{
|
|
return m_CapPosition[m_CapIdx];
|
|
}
|
|
set
|
|
{
|
|
if (m_CapPosition[m_CapIdx] != value)
|
|
{
|
|
m_CapPosition[m_CapIdx] = value;
|
|
CapsPosition = m_CapPosition;
|
|
drawGaugeBackground = true;
|
|
Refresh();
|
|
}
|
|
}
|
|
}
|
|
|
|
[System.ComponentModel.Browsable(false)]
|
|
public Point[] CapsPosition
|
|
{
|
|
get
|
|
{
|
|
return m_CapPosition;
|
|
}
|
|
set
|
|
{
|
|
m_CapPosition = value;
|
|
}
|
|
}
|
|
|
|
[System.ComponentModel.Browsable(true),
|
|
System.ComponentModel.Category("AGauge"),
|
|
System.ComponentModel.Description("The center of the gauge (in the control's client area).")]
|
|
public Point Center
|
|
{
|
|
get
|
|
{
|
|
return m_Center;
|
|
}
|
|
set
|
|
{
|
|
if (m_Center != value)
|
|
{
|
|
m_Center = value;
|
|
drawGaugeBackground = true;
|
|
Refresh();
|
|
}
|
|
}
|
|
}
|
|
|
|
[System.ComponentModel.Browsable(true),
|
|
System.ComponentModel.Category("AGauge"),
|
|
System.ComponentModel.Description("The minimum value to show on the scale.")]
|
|
public Single MinValue
|
|
{
|
|
get
|
|
{
|
|
return m_MinValue;
|
|
}
|
|
set
|
|
{
|
|
if ((m_MinValue != value)
|
|
&& (value < m_MaxValue))
|
|
{
|
|
m_MinValue = value;
|
|
drawGaugeBackground = true;
|
|
Refresh();
|
|
}
|
|
}
|
|
}
|
|
|
|
[System.ComponentModel.Browsable(true),
|
|
System.ComponentModel.Category("AGauge"),
|
|
System.ComponentModel.Description("The maximum value to show on the scale.")]
|
|
public Single MaxValue
|
|
{
|
|
get
|
|
{
|
|
return m_MaxValue;
|
|
}
|
|
set
|
|
{
|
|
if ((m_MaxValue != value)
|
|
&& (value > m_MinValue))
|
|
{
|
|
m_MaxValue = value;
|
|
drawGaugeBackground = true;
|
|
Refresh();
|
|
}
|
|
}
|
|
}
|
|
|
|
[System.ComponentModel.Browsable(true),
|
|
System.ComponentModel.Category("AGauge"),
|
|
System.ComponentModel.Description("The color of the base arc.")]
|
|
public Color BaseArcColor
|
|
{
|
|
get
|
|
{
|
|
return m_BaseArcColor;
|
|
}
|
|
set
|
|
{
|
|
if (m_BaseArcColor != value)
|
|
{
|
|
m_BaseArcColor = value;
|
|
drawGaugeBackground = true;
|
|
Refresh();
|
|
}
|
|
}
|
|
}
|
|
|
|
[System.ComponentModel.Browsable(true),
|
|
System.ComponentModel.Category("AGauge"),
|
|
System.ComponentModel.Description("The radius of the base arc.")]
|
|
public Int32 BaseArcRadius
|
|
{
|
|
get
|
|
{
|
|
return m_BaseArcRadius;
|
|
}
|
|
set
|
|
{
|
|
if (m_BaseArcRadius != value)
|
|
{
|
|
m_BaseArcRadius = value;
|
|
drawGaugeBackground = true;
|
|
Refresh();
|
|
}
|
|
}
|
|
}
|
|
|
|
[System.ComponentModel.Browsable(true),
|
|
System.ComponentModel.Category("AGauge"),
|
|
System.ComponentModel.Description("The start angle of the base arc.")]
|
|
public Int32 BaseArcStart
|
|
{
|
|
get
|
|
{
|
|
return m_BaseArcStart;
|
|
}
|
|
set
|
|
{
|
|
if (m_BaseArcStart != value)
|
|
{
|
|
m_BaseArcStart = value;
|
|
drawGaugeBackground = true;
|
|
Refresh();
|
|
}
|
|
}
|
|
}
|
|
|
|
[System.ComponentModel.Browsable(true),
|
|
System.ComponentModel.Category("AGauge"),
|
|
System.ComponentModel.Description("The sweep angle of the base arc.")]
|
|
public Int32 BaseArcSweep
|
|
{
|
|
get
|
|
{
|
|
return m_BaseArcSweep;
|
|
}
|
|
set
|
|
{
|
|
if (m_BaseArcSweep != value)
|
|
{
|
|
m_BaseArcSweep = value;
|
|
drawGaugeBackground = true;
|
|
Refresh();
|
|
}
|
|
}
|
|
}
|
|
|
|
[System.ComponentModel.Browsable(true),
|
|
System.ComponentModel.Category("AGauge"),
|
|
System.ComponentModel.Description("The width of the base arc.")]
|
|
public Int32 BaseArcWidth
|
|
{
|
|
get
|
|
{
|
|
return m_BaseArcWidth;
|
|
}
|
|
set
|
|
{
|
|
if (m_BaseArcWidth != value)
|
|
{
|
|
m_BaseArcWidth = value;
|
|
drawGaugeBackground = true;
|
|
Refresh();
|
|
}
|
|
}
|
|
}
|
|
|
|
[System.ComponentModel.Browsable(true),
|
|
System.ComponentModel.Category("AGauge"),
|
|
System.ComponentModel.Description("The color of the inter scale lines which are the middle scale lines for an uneven number of minor scale lines.")]
|
|
public Color ScaleLinesInterColor
|
|
{
|
|
get
|
|
{
|
|
return m_ScaleLinesInterColor;
|
|
}
|
|
set
|
|
{
|
|
if (m_ScaleLinesInterColor != value)
|
|
{
|
|
m_ScaleLinesInterColor = value;
|
|
drawGaugeBackground = true;
|
|
Refresh();
|
|
}
|
|
}
|
|
}
|
|
|
|
[System.ComponentModel.Browsable(true),
|
|
System.ComponentModel.Category("AGauge"),
|
|
System.ComponentModel.Description("The inner radius of the inter scale lines which are the middle scale lines for an uneven number of minor scale lines.")]
|
|
public Int32 ScaleLinesInterInnerRadius
|
|
{
|
|
get
|
|
{
|
|
return m_ScaleLinesInterInnerRadius;
|
|
}
|
|
set
|
|
{
|
|
if (m_ScaleLinesInterInnerRadius != value)
|
|
{
|
|
m_ScaleLinesInterInnerRadius = value;
|
|
drawGaugeBackground = true;
|
|
Refresh();
|
|
}
|
|
}
|
|
}
|
|
|
|
[System.ComponentModel.Browsable(true),
|
|
System.ComponentModel.Category("AGauge"),
|
|
System.ComponentModel.Description("The outer radius of the inter scale lines which are the middle scale lines for an uneven number of minor scale lines.")]
|
|
public Int32 ScaleLinesInterOuterRadius
|
|
{
|
|
get
|
|
{
|
|
return m_ScaleLinesInterOuterRadius;
|
|
}
|
|
set
|
|
{
|
|
if (m_ScaleLinesInterOuterRadius != value)
|
|
{
|
|
m_ScaleLinesInterOuterRadius = value;
|
|
drawGaugeBackground = true;
|
|
Refresh();
|
|
}
|
|
}
|
|
}
|
|
|
|
[System.ComponentModel.Browsable(true),
|
|
System.ComponentModel.Category("AGauge"),
|
|
System.ComponentModel.Description("The width of the inter scale lines which are the middle scale lines for an uneven number of minor scale lines.")]
|
|
public Int32 ScaleLinesInterWidth
|
|
{
|
|
get
|
|
{
|
|
return m_ScaleLinesInterWidth;
|
|
}
|
|
set
|
|
{
|
|
if (m_ScaleLinesInterWidth != value)
|
|
{
|
|
m_ScaleLinesInterWidth = value;
|
|
drawGaugeBackground = true;
|
|
Refresh();
|
|
}
|
|
}
|
|
}
|
|
|
|
[System.ComponentModel.Browsable(true),
|
|
System.ComponentModel.Category("AGauge"),
|
|
System.ComponentModel.Description("The number of minor scale lines.")]
|
|
public Int32 ScaleLinesMinorNumOf
|
|
{
|
|
get
|
|
{
|
|
return m_ScaleLinesMinorNumOf;
|
|
}
|
|
set
|
|
{
|
|
if (m_ScaleLinesMinorNumOf != value)
|
|
{
|
|
m_ScaleLinesMinorNumOf = value;
|
|
drawGaugeBackground = true;
|
|
Refresh();
|
|
}
|
|
}
|
|
}
|
|
|
|
[System.ComponentModel.Browsable(true),
|
|
System.ComponentModel.Category("AGauge"),
|
|
System.ComponentModel.Description("The color of the minor scale lines.")]
|
|
public Color ScaleLinesMinorColor
|
|
{
|
|
get
|
|
{
|
|
return m_ScaleLinesMinorColor;
|
|
}
|
|
set
|
|
{
|
|
if (m_ScaleLinesMinorColor != value)
|
|
{
|
|
m_ScaleLinesMinorColor = value;
|
|
drawGaugeBackground = true;
|
|
Refresh();
|
|
}
|
|
}
|
|
}
|
|
|
|
[System.ComponentModel.Browsable(true),
|
|
System.ComponentModel.Category("AGauge"),
|
|
System.ComponentModel.Description("The inner radius of the minor scale lines.")]
|
|
public Int32 ScaleLinesMinorInnerRadius
|
|
{
|
|
get
|
|
{
|
|
return m_ScaleLinesMinorInnerRadius;
|
|
}
|
|
set
|
|
{
|
|
if (m_ScaleLinesMinorInnerRadius != value)
|
|
{
|
|
m_ScaleLinesMinorInnerRadius = value;
|
|
drawGaugeBackground = true;
|
|
Refresh();
|
|
}
|
|
}
|
|
}
|
|
|
|
[System.ComponentModel.Browsable(true),
|
|
System.ComponentModel.Category("AGauge"),
|
|
System.ComponentModel.Description("The outer radius of the minor scale lines.")]
|
|
public Int32 ScaleLinesMinorOuterRadius
|
|
{
|
|
get
|
|
{
|
|
return m_ScaleLinesMinorOuterRadius;
|
|
}
|
|
set
|
|
{
|
|
if (m_ScaleLinesMinorOuterRadius != value)
|
|
{
|
|
m_ScaleLinesMinorOuterRadius = value;
|
|
drawGaugeBackground = true;
|
|
Refresh();
|
|
}
|
|
}
|
|
}
|
|
|
|
[System.ComponentModel.Browsable(true),
|
|
System.ComponentModel.Category("AGauge"),
|
|
System.ComponentModel.Description("The width of the minor scale lines.")]
|
|
public Int32 ScaleLinesMinorWidth
|
|
{
|
|
get
|
|
{
|
|
return m_ScaleLinesMinorWidth;
|
|
}
|
|
set
|
|
{
|
|
if (m_ScaleLinesMinorWidth != value)
|
|
{
|
|
m_ScaleLinesMinorWidth = value;
|
|
drawGaugeBackground = true;
|
|
Refresh();
|
|
}
|
|
}
|
|
}
|
|
|
|
[System.ComponentModel.Browsable(true),
|
|
System.ComponentModel.Category("AGauge"),
|
|
System.ComponentModel.Description("The step value of the major scale lines.")]
|
|
public Single ScaleLinesMajorStepValue
|
|
{
|
|
get
|
|
{
|
|
return m_ScaleLinesMajorStepValue;
|
|
}
|
|
set
|
|
{
|
|
if ((m_ScaleLinesMajorStepValue != value) && (value > 0))
|
|
{
|
|
m_ScaleLinesMajorStepValue = Math.Max(Math.Min(value, m_MaxValue), m_MinValue);
|
|
drawGaugeBackground = true;
|
|
Refresh();
|
|
}
|
|
}
|
|
}
|
|
[System.ComponentModel.Browsable(true),
|
|
System.ComponentModel.Category("AGauge"),
|
|
System.ComponentModel.Description("The color of the major scale lines.")]
|
|
public Color ScaleLinesMajorColor
|
|
{
|
|
get
|
|
{
|
|
return m_ScaleLinesMajorColor;
|
|
}
|
|
set
|
|
{
|
|
if (m_ScaleLinesMajorColor != value)
|
|
{
|
|
m_ScaleLinesMajorColor = value;
|
|
drawGaugeBackground = true;
|
|
Refresh();
|
|
}
|
|
}
|
|
}
|
|
|
|
[System.ComponentModel.Browsable(true),
|
|
System.ComponentModel.Category("AGauge"),
|
|
System.ComponentModel.Description("The inner radius of the major scale lines.")]
|
|
public Int32 ScaleLinesMajorInnerRadius
|
|
{
|
|
get
|
|
{
|
|
return m_ScaleLinesMajorInnerRadius;
|
|
}
|
|
set
|
|
{
|
|
if (m_ScaleLinesMajorInnerRadius != value)
|
|
{
|
|
m_ScaleLinesMajorInnerRadius = value;
|
|
drawGaugeBackground = true;
|
|
Refresh();
|
|
}
|
|
}
|
|
}
|
|
|
|
[System.ComponentModel.Browsable(true),
|
|
System.ComponentModel.Category("AGauge"),
|
|
System.ComponentModel.Description("The outer radius of the major scale lines.")]
|
|
public Int32 ScaleLinesMajorOuterRadius
|
|
{
|
|
get
|
|
{
|
|
return m_ScaleLinesMajorOuterRadius;
|
|
}
|
|
set
|
|
{
|
|
if (m_ScaleLinesMajorOuterRadius != value)
|
|
{
|
|
m_ScaleLinesMajorOuterRadius = value;
|
|
drawGaugeBackground = true;
|
|
Refresh();
|
|
}
|
|
}
|
|
}
|
|
|
|
[System.ComponentModel.Browsable(true),
|
|
System.ComponentModel.Category("AGauge"),
|
|
System.ComponentModel.Description("The width of the major scale lines.")]
|
|
public Int32 ScaleLinesMajorWidth
|
|
{
|
|
get
|
|
{
|
|
return m_ScaleLinesMajorWidth;
|
|
}
|
|
set
|
|
{
|
|
if (m_ScaleLinesMajorWidth != value)
|
|
{
|
|
m_ScaleLinesMajorWidth = value;
|
|
drawGaugeBackground = true;
|
|
Refresh();
|
|
}
|
|
}
|
|
}
|
|
|
|
[System.ComponentModel.Browsable(true),
|
|
System.ComponentModel.Category("AGauge"),
|
|
System.ComponentModel.RefreshProperties(RefreshProperties.All),
|
|
System.ComponentModel.Description("The range index. set this to a value of 0 up to 4 to change the corresponding range's properties.")]
|
|
public Byte Range_Idx
|
|
{
|
|
get
|
|
{
|
|
return m_RangeIdx;
|
|
}
|
|
set
|
|
{
|
|
if ((m_RangeIdx != value)
|
|
&& (0 <= value)
|
|
&& (value < NUMOFRANGES))
|
|
{
|
|
m_RangeIdx = value;
|
|
drawGaugeBackground = true;
|
|
Refresh();
|
|
}
|
|
}
|
|
}
|
|
|
|
[System.ComponentModel.Browsable(true),
|
|
System.ComponentModel.Category("AGauge"),
|
|
System.ComponentModel.Description("Enables or disables the range selected by Range_Idx.")]
|
|
public Boolean RangeEnabled
|
|
{
|
|
get
|
|
{
|
|
return m_RangeEnabled[m_RangeIdx];
|
|
}
|
|
set
|
|
{
|
|
if (m_RangeEnabled[m_RangeIdx] != value)
|
|
{
|
|
m_RangeEnabled[m_RangeIdx] = value;
|
|
RangesEnabled = m_RangeEnabled;
|
|
drawGaugeBackground = true;
|
|
Refresh();
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
[System.ComponentModel.Browsable(false)]
|
|
public Boolean[] RangesEnabled
|
|
{
|
|
get
|
|
{
|
|
return m_RangeEnabled;
|
|
}
|
|
set
|
|
{
|
|
m_RangeEnabled = value;
|
|
}
|
|
}
|
|
|
|
[System.ComponentModel.Browsable(true),
|
|
System.ComponentModel.Category("AGauge"),
|
|
System.ComponentModel.Description("The color of the range.")]
|
|
public Color RangeColor
|
|
{
|
|
get
|
|
{
|
|
return m_RangeColor[m_RangeIdx];
|
|
}
|
|
set
|
|
{
|
|
if (m_RangeColor[m_RangeIdx] != value)
|
|
{
|
|
m_RangeColor[m_RangeIdx] = value;
|
|
RangesColor = m_RangeColor;
|
|
drawGaugeBackground = true;
|
|
Refresh();
|
|
}
|
|
}
|
|
}
|
|
|
|
[System.ComponentModel.Browsable(false)]
|
|
public Color[] RangesColor
|
|
{
|
|
get
|
|
{
|
|
return m_RangeColor;
|
|
}
|
|
set
|
|
{
|
|
m_RangeColor = value;
|
|
}
|
|
}
|
|
|
|
[System.ComponentModel.Browsable(true),
|
|
System.ComponentModel.Category("AGauge"),
|
|
System.ComponentModel.Description("The start value of the range, must be less than RangeEndValue.")]
|
|
public Single RangeStartValue
|
|
{
|
|
get
|
|
{
|
|
return m_RangeStartValue[m_RangeIdx];
|
|
}
|
|
set
|
|
{
|
|
if ((m_RangeStartValue[m_RangeIdx] != value)
|
|
&& (value < m_RangeEndValue[m_RangeIdx]))
|
|
{
|
|
m_RangeStartValue[m_RangeIdx] = value;
|
|
RangesStartValue = m_RangeStartValue;
|
|
drawGaugeBackground = true;
|
|
Refresh();
|
|
}
|
|
}
|
|
}
|
|
|
|
[System.ComponentModel.Browsable(false)]
|
|
public Single[] RangesStartValue
|
|
{
|
|
get
|
|
{
|
|
return m_RangeStartValue;
|
|
}
|
|
set
|
|
{
|
|
m_RangeStartValue = value;
|
|
}
|
|
}
|
|
|
|
[System.ComponentModel.Browsable(true),
|
|
System.ComponentModel.Category("AGauge"),
|
|
System.ComponentModel.Description("The end value of the range. Must be greater than RangeStartValue.")]
|
|
public Single RangeEndValue
|
|
{
|
|
get
|
|
{
|
|
return m_RangeEndValue[m_RangeIdx];
|
|
}
|
|
set
|
|
{
|
|
if ((m_RangeEndValue[m_RangeIdx] != value)
|
|
&& (m_RangeStartValue[m_RangeIdx] < value))
|
|
{
|
|
m_RangeEndValue[m_RangeIdx] = value;
|
|
RangesEndValue = m_RangeEndValue;
|
|
drawGaugeBackground = true;
|
|
Refresh();
|
|
}
|
|
}
|
|
}
|
|
|
|
[System.ComponentModel.Browsable(false)]
|
|
public Single[] RangesEndValue
|
|
{
|
|
get
|
|
{
|
|
return m_RangeEndValue;
|
|
}
|
|
set
|
|
{
|
|
m_RangeEndValue = value;
|
|
}
|
|
}
|
|
|
|
[System.ComponentModel.Browsable(true),
|
|
System.ComponentModel.Category("AGauge"),
|
|
System.ComponentModel.Description("The inner radius of the range.")]
|
|
public Int32 RangeInnerRadius
|
|
{
|
|
get
|
|
{
|
|
return m_RangeInnerRadius[m_RangeIdx];
|
|
}
|
|
set
|
|
{
|
|
if (m_RangeInnerRadius[m_RangeIdx] != value)
|
|
{
|
|
m_RangeInnerRadius[m_RangeIdx] = value;
|
|
RangesInnerRadius = m_RangeInnerRadius;
|
|
drawGaugeBackground = true;
|
|
Refresh();
|
|
}
|
|
}
|
|
}
|
|
|
|
[System.ComponentModel.Browsable(false)]
|
|
public Int32[] RangesInnerRadius
|
|
{
|
|
get
|
|
{
|
|
return m_RangeInnerRadius;
|
|
}
|
|
set
|
|
{
|
|
m_RangeInnerRadius = value;
|
|
}
|
|
}
|
|
|
|
[System.ComponentModel.Browsable(true),
|
|
System.ComponentModel.Category("AGauge"),
|
|
System.ComponentModel.Description("The inner radius of the range.")]
|
|
public Int32 RangeOuterRadius
|
|
{
|
|
get
|
|
{
|
|
return m_RangeOuterRadius[m_RangeIdx];
|
|
}
|
|
set
|
|
{
|
|
if (m_RangeOuterRadius[m_RangeIdx] != value)
|
|
{
|
|
m_RangeOuterRadius[m_RangeIdx] = value;
|
|
RangesOuterRadius = m_RangeOuterRadius;
|
|
drawGaugeBackground = true;
|
|
Refresh();
|
|
}
|
|
}
|
|
}
|
|
|
|
[System.ComponentModel.Browsable(false)]
|
|
public Int32[] RangesOuterRadius
|
|
{
|
|
get
|
|
{
|
|
return m_RangeOuterRadius;
|
|
}
|
|
set
|
|
{
|
|
m_RangeOuterRadius = value;
|
|
}
|
|
}
|
|
|
|
[System.ComponentModel.Browsable(true),
|
|
System.ComponentModel.Category("AGauge"),
|
|
System.ComponentModel.Description("The radius of the scale numbers.")]
|
|
public Int32 ScaleNumbersRadius
|
|
{
|
|
get
|
|
{
|
|
return m_ScaleNumbersRadius;
|
|
}
|
|
set
|
|
{
|
|
if (m_ScaleNumbersRadius != value)
|
|
{
|
|
m_ScaleNumbersRadius = value;
|
|
drawGaugeBackground = true;
|
|
Refresh();
|
|
}
|
|
}
|
|
}
|
|
|
|
[System.ComponentModel.Browsable(true),
|
|
System.ComponentModel.Category("AGauge"),
|
|
System.ComponentModel.Description("The color of the scale numbers.")]
|
|
public Color ScaleNumbersColor
|
|
{
|
|
get
|
|
{
|
|
return m_ScaleNumbersColor;
|
|
}
|
|
set
|
|
{
|
|
if (m_ScaleNumbersColor != value)
|
|
{
|
|
m_ScaleNumbersColor = value;
|
|
drawGaugeBackground = true;
|
|
Refresh();
|
|
}
|
|
}
|
|
}
|
|
|
|
[System.ComponentModel.Browsable(true),
|
|
System.ComponentModel.Category("AGauge"),
|
|
System.ComponentModel.Description("The format of the scale numbers.")]
|
|
public String ScaleNumbersFormat
|
|
{
|
|
get
|
|
{
|
|
return m_ScaleNumbersFormat;
|
|
}
|
|
set
|
|
{
|
|
if (m_ScaleNumbersFormat != value)
|
|
{
|
|
m_ScaleNumbersFormat = value;
|
|
drawGaugeBackground = true;
|
|
Refresh();
|
|
}
|
|
}
|
|
}
|
|
|
|
[System.ComponentModel.Browsable(true),
|
|
System.ComponentModel.Category("AGauge"),
|
|
System.ComponentModel.Description("The number of the scale line to start writing numbers next to.")]
|
|
public Int32 ScaleNumbersStartScaleLine
|
|
{
|
|
get
|
|
{
|
|
return m_ScaleNumbersStartScaleLine;
|
|
}
|
|
set
|
|
{
|
|
if (m_ScaleNumbersStartScaleLine != value)
|
|
{
|
|
m_ScaleNumbersStartScaleLine = Math.Max(value, 1);
|
|
drawGaugeBackground = true;
|
|
Refresh();
|
|
}
|
|
}
|
|
}
|
|
|
|
[System.ComponentModel.Browsable(true),
|
|
System.ComponentModel.Category("AGauge"),
|
|
System.ComponentModel.Description("The number of scale line steps for writing numbers.")]
|
|
public Int32 ScaleNumbersStepScaleLines
|
|
{
|
|
get
|
|
{
|
|
return m_ScaleNumbersStepScaleLines;
|
|
}
|
|
set
|
|
{
|
|
if (m_ScaleNumbersStepScaleLines != value)
|
|
{
|
|
m_ScaleNumbersStepScaleLines = Math.Max(value, 1);
|
|
drawGaugeBackground = true;
|
|
Refresh();
|
|
}
|
|
}
|
|
}
|
|
|
|
[System.ComponentModel.Browsable(true),
|
|
System.ComponentModel.Category("AGauge"),
|
|
System.ComponentModel.Description("The angle relative to the tangent of the base arc at a scale line that is used to rotate numbers. set to 0 for no rotation or e.g. set to 90.")]
|
|
public Int32 ScaleNumbersRotation
|
|
{
|
|
get
|
|
{
|
|
return m_ScaleNumbersRotation;
|
|
}
|
|
set
|
|
{
|
|
if (m_ScaleNumbersRotation != value)
|
|
{
|
|
m_ScaleNumbersRotation = value;
|
|
drawGaugeBackground = true;
|
|
Refresh();
|
|
}
|
|
}
|
|
}
|
|
|
|
[System.ComponentModel.Browsable(true),
|
|
System.ComponentModel.Category("AGauge"),
|
|
System.ComponentModel.RefreshProperties(RefreshProperties.All),
|
|
System.ComponentModel.Description("set needle number")]
|
|
public Byte Need_Idx
|
|
{
|
|
get
|
|
{
|
|
return m_NeedIdx;
|
|
}
|
|
set
|
|
{
|
|
if ((m_NeedIdx != value)
|
|
&& (0 <= value)
|
|
&& (value < 5))
|
|
{
|
|
m_NeedIdx = value;
|
|
}
|
|
}
|
|
}
|
|
|
|
[System.ComponentModel.Browsable(true),
|
|
System.ComponentModel.Category("AGauge"),
|
|
System.ComponentModel.Description("The type of the needle, currently only type 0 and 1 are supported. Type 0 looks nicers but if you experience performance problems you might consider using type 1.")]
|
|
public Int32 NeedleType
|
|
{
|
|
get
|
|
{
|
|
return m_NeedleType[m_NeedIdx];
|
|
}
|
|
set
|
|
{
|
|
if (m_NeedleType[m_NeedIdx] != value)
|
|
{
|
|
m_NeedleType[m_NeedIdx] = value;
|
|
drawGaugeBackground = true;
|
|
Refresh();
|
|
}
|
|
}
|
|
}
|
|
|
|
[System.ComponentModel.Browsable(false)]
|
|
public Int32[] NeedlesType
|
|
{
|
|
get
|
|
{
|
|
return m_NeedleType;
|
|
}
|
|
set
|
|
{
|
|
m_NeedleType = value;
|
|
}
|
|
}
|
|
|
|
[System.ComponentModel.Browsable(true),
|
|
System.ComponentModel.Category("AGauge"),
|
|
System.ComponentModel.Description("The radius of the needle.")]
|
|
public Int32 NeedleRadius
|
|
{
|
|
get
|
|
{
|
|
return m_NeedleRadius[m_NeedIdx];
|
|
}
|
|
set
|
|
{
|
|
if (m_NeedleRadius[m_NeedIdx] != value)
|
|
{
|
|
m_NeedleRadius[m_NeedIdx] = value;
|
|
drawGaugeBackground = true;
|
|
Refresh();
|
|
}
|
|
}
|
|
}
|
|
|
|
[System.ComponentModel.Browsable(false)]
|
|
public Int32[] NeedlesRadius
|
|
{
|
|
get
|
|
{
|
|
return m_NeedleRadius;
|
|
}
|
|
set
|
|
{
|
|
m_NeedleRadius = value;
|
|
}
|
|
}
|
|
|
|
[System.ComponentModel.Browsable(true),
|
|
System.ComponentModel.Category("AGauge"),
|
|
System.ComponentModel.Description("The first color of the needle.")]
|
|
public NeedleColorEnum NeedleColor1
|
|
{
|
|
get
|
|
{
|
|
return m_NeedleColor1[m_NeedIdx];
|
|
}
|
|
set
|
|
{
|
|
if (m_NeedleColor1[m_NeedIdx] != value)
|
|
{
|
|
m_NeedleColor1[m_NeedIdx] = value;
|
|
drawGaugeBackground = true;
|
|
Refresh();
|
|
}
|
|
}
|
|
}
|
|
|
|
[System.ComponentModel.Browsable(false)]
|
|
public NeedleColorEnum[] NeedlesColor1
|
|
{
|
|
get
|
|
{
|
|
return m_NeedleColor1;
|
|
}
|
|
set
|
|
{
|
|
m_NeedleColor1 = value;
|
|
}
|
|
}
|
|
|
|
[System.ComponentModel.Browsable(true),
|
|
System.ComponentModel.Category("AGauge"),
|
|
System.ComponentModel.Description("The second color of the needle.")]
|
|
public Color NeedleColor2
|
|
{
|
|
get
|
|
{
|
|
return m_NeedleColor2[m_NeedIdx];
|
|
}
|
|
set
|
|
{
|
|
if (m_NeedleColor2[m_NeedIdx] != value)
|
|
{
|
|
m_NeedleColor2[m_NeedIdx] = value;
|
|
drawGaugeBackground = true;
|
|
Refresh();
|
|
}
|
|
}
|
|
}
|
|
|
|
[System.ComponentModel.Browsable(false)]
|
|
public Color[] NeedlesColor2
|
|
{
|
|
get
|
|
{
|
|
return m_NeedleColor2;
|
|
}
|
|
set
|
|
{
|
|
m_NeedleColor2 = value;
|
|
}
|
|
}
|
|
|
|
[System.ComponentModel.Browsable(true),
|
|
System.ComponentModel.Category("AGauge"),
|
|
System.ComponentModel.Description("The width of the needle.")]
|
|
public Int32 NeedleWidth
|
|
{
|
|
get
|
|
{
|
|
return m_NeedleWidth[m_NeedIdx];
|
|
}
|
|
set
|
|
{
|
|
if (m_NeedleWidth[m_NeedIdx] != value)
|
|
{
|
|
m_NeedleWidth[m_NeedIdx] = value;
|
|
drawGaugeBackground = true;
|
|
Refresh();
|
|
}
|
|
}
|
|
}
|
|
|
|
[System.ComponentModel.Browsable(false)]
|
|
public Int32[] NeedlesWidth
|
|
{
|
|
get
|
|
{
|
|
return m_NeedleWidth;
|
|
}
|
|
set
|
|
{
|
|
m_NeedleWidth = value;
|
|
}
|
|
}
|
|
|
|
[System.ComponentModel.Browsable(true),
|
|
System.ComponentModel.Category("AGauge"),
|
|
System.ComponentModel.Description("Enables or disables the range selected by Need_Idx.")]
|
|
public Boolean NeedleEnabled
|
|
{
|
|
get
|
|
{
|
|
return m_NeedleEnabled[m_NeedIdx];
|
|
}
|
|
set
|
|
{
|
|
if (m_NeedleEnabled[m_NeedIdx] != value)
|
|
{
|
|
m_NeedleEnabled[m_NeedIdx] = value;
|
|
NeedlesEnabled = m_NeedleEnabled;
|
|
drawGaugeBackground = true;
|
|
Refresh();
|
|
}
|
|
}
|
|
}
|
|
|
|
[System.ComponentModel.Browsable(false)]
|
|
public Boolean[] NeedlesEnabled
|
|
{
|
|
get
|
|
{
|
|
return m_NeedleEnabled;
|
|
}
|
|
set
|
|
{
|
|
m_NeedleEnabled = value;
|
|
}
|
|
}
|
|
|
|
|
|
|
|
#endregion
|
|
|
|
#region helper
|
|
private void FindFontBounds()
|
|
{
|
|
//find upper and lower bounds for numeric characters
|
|
Int32 c1;
|
|
Int32 c2;
|
|
Boolean boundfound;
|
|
Bitmap b;
|
|
Graphics g;
|
|
SolidBrush backBrush = new SolidBrush(Color.White);
|
|
SolidBrush foreBrush = new SolidBrush(Color.Black);
|
|
SizeF boundingBox;
|
|
|
|
b = new Bitmap(5, 5);
|
|
g = Graphics.FromImage(b);
|
|
boundingBox = g.MeasureString("0123456789", Font, -1, StringFormat.GenericTypographic);
|
|
b = new Bitmap((Int32)(boundingBox.Width), (Int32)(boundingBox.Height));
|
|
g = Graphics.FromImage(b);
|
|
g.FillRectangle(backBrush, 0.0F, 0.0F, boundingBox.Width, boundingBox.Height);
|
|
g.DrawString("0123456789", Font, foreBrush, 0.0F, 0.0F, StringFormat.GenericTypographic);
|
|
|
|
fontBoundY1 = 0;
|
|
fontBoundY2 = 0;
|
|
c1 = 0;
|
|
boundfound = false;
|
|
while ((c1 < b.Height) && (!boundfound))
|
|
{
|
|
c2 = 0;
|
|
while ((c2 < b.Width) && (!boundfound))
|
|
{
|
|
if (b.GetPixel(c2, c1) != backBrush.Color)
|
|
{
|
|
fontBoundY1 = c1;
|
|
boundfound = true;
|
|
}
|
|
c2++;
|
|
}
|
|
c1++;
|
|
}
|
|
|
|
c1 = b.Height - 1;
|
|
boundfound = false;
|
|
while ((0 < c1) && (!boundfound))
|
|
{
|
|
c2 = 0;
|
|
while ((c2 < b.Width) && (!boundfound))
|
|
{
|
|
if (b.GetPixel(c2, c1) != backBrush.Color)
|
|
{
|
|
fontBoundY2 = c1;
|
|
boundfound = true;
|
|
}
|
|
c2++;
|
|
}
|
|
c1--;
|
|
}
|
|
}
|
|
#endregion
|
|
|
|
/// <summary>
|
|
/// Override to prevent offscreen drawing the control - mono mac
|
|
/// </summary>
|
|
public new void Invalidate()
|
|
{
|
|
if (!ThisReallyVisible())
|
|
{
|
|
return;
|
|
}
|
|
|
|
base.Invalidate();
|
|
}
|
|
|
|
public override void Refresh()
|
|
{
|
|
base.Refresh();
|
|
}
|
|
|
|
/// <summary>
|
|
/// this is to fix a mono off screen drawing issue
|
|
/// </summary>
|
|
/// <returns></returns>
|
|
public bool ThisReallyVisible()
|
|
{
|
|
Control ctl = Control.FromHandle(this.Handle);
|
|
return ctl.Visible;
|
|
}
|
|
|
|
#region base member overrides
|
|
protected override void OnPaintBackground(PaintEventArgs pevent)
|
|
{
|
|
}
|
|
|
|
protected override void OnPaint(PaintEventArgs pe)
|
|
{
|
|
if ((Width < 10) || (Height < 10))
|
|
{
|
|
return;
|
|
}
|
|
|
|
if (!ThisReallyVisible())
|
|
{
|
|
Console.WriteLine(this.Visible);
|
|
base.OnPaint(pe);
|
|
return;
|
|
}
|
|
|
|
float scale = 1;
|
|
|
|
// scale it
|
|
if (basesize != null)
|
|
{
|
|
scale = (float)this.Width / basesize.Width;
|
|
|
|
// Console.WriteLine("Scale: " + scale);
|
|
}
|
|
|
|
if (drawGaugeBackground)
|
|
{
|
|
drawGaugeBackground = false;
|
|
try
|
|
{
|
|
FindFontBounds();
|
|
}
|
|
catch { } // ignore for now - happens when the control gets to small for text
|
|
|
|
gaugeBitmap = new Bitmap(Width, Height, pe.Graphics);
|
|
Graphics ggr = Graphics.FromImage(gaugeBitmap);
|
|
ggr.FillRectangle(new SolidBrush(BackColor), ClientRectangle);
|
|
|
|
if (BackgroundImage!=null)
|
|
{
|
|
switch (BackgroundImageLayout)
|
|
{
|
|
case ImageLayout.Center:
|
|
ggr.DrawImageUnscaled(BackgroundImage, Width / 2 - BackgroundImage.Width / 2, Height / 2 - BackgroundImage.Height / 2);
|
|
break;
|
|
case ImageLayout.None:
|
|
ggr.DrawImageUnscaled(BackgroundImage, 0, 0);
|
|
break;
|
|
case ImageLayout.Stretch:
|
|
ggr.DrawImage(BackgroundImage, 0, 0, Width, Height);
|
|
break;
|
|
case ImageLayout.Tile:
|
|
Int32 pixelOffsetX = 0;
|
|
Int32 pixelOffsetY = 0;
|
|
while (pixelOffsetX < Width)
|
|
{
|
|
pixelOffsetY = 0;
|
|
while (pixelOffsetY < Height)
|
|
{
|
|
ggr.DrawImageUnscaled(BackgroundImage, pixelOffsetX, pixelOffsetY);
|
|
pixelOffsetY += BackgroundImage.Height;
|
|
}
|
|
pixelOffsetX += BackgroundImage.Width;
|
|
}
|
|
break;
|
|
case ImageLayout.Zoom:
|
|
if ((Single)(BackgroundImage.Width / Width) < (Single)(BackgroundImage.Height / Height))
|
|
{
|
|
ggr.DrawImage(BackgroundImage, 0, 0, Height, Height);
|
|
}
|
|
else
|
|
{
|
|
ggr.DrawImage(BackgroundImage, 0, 0, Width, Width);
|
|
}
|
|
break;
|
|
}
|
|
}
|
|
|
|
ggr.SmoothingMode = SmoothingMode.HighQuality;
|
|
ggr.PixelOffsetMode = PixelOffsetMode.HighQuality;
|
|
|
|
// scale it
|
|
if (basesize != null)
|
|
{
|
|
ggr.ScaleTransform(scale, scale);
|
|
}
|
|
|
|
GraphicsPath gp = new GraphicsPath();
|
|
Single rangeStartAngle;
|
|
Single rangeSweepAngle;
|
|
for (Int32 counter= 0; counter<NUMOFRANGES; counter++)
|
|
{
|
|
if (m_RangeEndValue[counter] > m_RangeStartValue[counter]
|
|
&& m_RangeEnabled[counter])
|
|
{
|
|
rangeStartAngle = m_BaseArcStart + (m_RangeStartValue[counter] - m_MinValue) * m_BaseArcSweep / (m_MaxValue - m_MinValue);
|
|
rangeSweepAngle = (m_RangeEndValue[counter] - m_RangeStartValue[counter]) * m_BaseArcSweep / (m_MaxValue - m_MinValue);
|
|
gp.Reset();
|
|
gp.AddPie(new Rectangle(m_Center.X - m_RangeOuterRadius[counter], m_Center.Y - m_RangeOuterRadius[counter], 2 * m_RangeOuterRadius[counter], 2 * m_RangeOuterRadius[counter]), rangeStartAngle, rangeSweepAngle);
|
|
gp.Reverse();
|
|
gp.AddPie(new Rectangle(m_Center.X - m_RangeInnerRadius[counter], m_Center.Y - m_RangeInnerRadius[counter], 2 * m_RangeInnerRadius[counter], 2 * m_RangeInnerRadius[counter]), rangeStartAngle, rangeSweepAngle);
|
|
gp.Reverse();
|
|
ggr.SetClip(gp);
|
|
ggr.FillPie(new SolidBrush(m_RangeColor[counter]), new Rectangle(m_Center.X - m_RangeOuterRadius[counter], m_Center.Y - m_RangeOuterRadius[counter], 2 * m_RangeOuterRadius[counter], 2 * m_RangeOuterRadius[counter]), rangeStartAngle, rangeSweepAngle);
|
|
}
|
|
}
|
|
|
|
ggr.SetClip(ClientRectangle);
|
|
if (m_BaseArcRadius > 0)
|
|
{
|
|
ggr.DrawArc(new Pen(m_BaseArcColor, m_BaseArcWidth), new Rectangle(m_Center.X - m_BaseArcRadius, m_Center.Y - m_BaseArcRadius, 2 * m_BaseArcRadius, 2 * m_BaseArcRadius), m_BaseArcStart, m_BaseArcSweep);
|
|
}
|
|
|
|
String valueText = "";
|
|
SizeF boundingBox;
|
|
Single countValue= 0;
|
|
Int32 counter1 = 0;
|
|
while (countValue <= (m_MaxValue - m_MinValue))
|
|
{
|
|
valueText = (m_MinValue + countValue).ToString(m_ScaleNumbersFormat);
|
|
ggr.ResetTransform();
|
|
// scale it
|
|
if (basesize != null)
|
|
{
|
|
ggr.ScaleTransform(scale, scale);
|
|
}
|
|
boundingBox = ggr.MeasureString(valueText, Font, -1, StringFormat.GenericTypographic);
|
|
|
|
gp.Reset();
|
|
gp.AddEllipse(new Rectangle(m_Center.X - m_ScaleLinesMajorOuterRadius, m_Center.Y - m_ScaleLinesMajorOuterRadius, 2 * m_ScaleLinesMajorOuterRadius, 2 * m_ScaleLinesMajorOuterRadius));
|
|
gp.Reverse();
|
|
gp.AddEllipse(new Rectangle(m_Center.X - m_ScaleLinesMajorInnerRadius, m_Center.Y - m_ScaleLinesMajorInnerRadius, 2 * m_ScaleLinesMajorInnerRadius, 2 * m_ScaleLinesMajorInnerRadius));
|
|
gp.Reverse();
|
|
ggr.SetClip(gp);
|
|
|
|
ggr.DrawLine(new Pen(m_ScaleLinesMajorColor, m_ScaleLinesMajorWidth),
|
|
(Single)(Center.X),
|
|
(Single)(Center.Y),
|
|
(Single)(Center.X + 2 * m_ScaleLinesMajorOuterRadius * Math.Cos((m_BaseArcStart + countValue * m_BaseArcSweep / (m_MaxValue - m_MinValue)) * Math.PI / 180.0)),
|
|
(Single)(Center.Y + 2 * m_ScaleLinesMajorOuterRadius * Math.Sin((m_BaseArcStart + countValue * m_BaseArcSweep / (m_MaxValue - m_MinValue)) * Math.PI / 180.0)));
|
|
|
|
gp.Reset();
|
|
gp.AddEllipse(new Rectangle(m_Center.X - m_ScaleLinesMinorOuterRadius, m_Center.Y - m_ScaleLinesMinorOuterRadius, 2 * m_ScaleLinesMinorOuterRadius, 2 * m_ScaleLinesMinorOuterRadius));
|
|
gp.Reverse();
|
|
gp.AddEllipse(new Rectangle(m_Center.X - m_ScaleLinesMinorInnerRadius, m_Center.Y - m_ScaleLinesMinorInnerRadius, 2 * m_ScaleLinesMinorInnerRadius, 2 * m_ScaleLinesMinorInnerRadius));
|
|
gp.Reverse();
|
|
ggr.SetClip(gp);
|
|
|
|
if (countValue < (m_MaxValue - m_MinValue))
|
|
{
|
|
for (Int32 counter2= 1; counter2<=m_ScaleLinesMinorNumOf; counter2++)
|
|
{
|
|
if (((m_ScaleLinesMinorNumOf % 2) == 1) && ((Int32)(m_ScaleLinesMinorNumOf / 2) + 1 == counter2))
|
|
{
|
|
gp.Reset();
|
|
gp.AddEllipse(new Rectangle(m_Center.X - m_ScaleLinesInterOuterRadius, m_Center.Y - m_ScaleLinesInterOuterRadius, 2 * m_ScaleLinesInterOuterRadius, 2 * m_ScaleLinesInterOuterRadius));
|
|
gp.Reverse();
|
|
gp.AddEllipse(new Rectangle(m_Center.X - m_ScaleLinesInterInnerRadius, m_Center.Y - m_ScaleLinesInterInnerRadius, 2 * m_ScaleLinesInterInnerRadius, 2 * m_ScaleLinesInterInnerRadius));
|
|
gp.Reverse();
|
|
ggr.SetClip(gp);
|
|
|
|
ggr.DrawLine(new Pen(m_ScaleLinesInterColor, m_ScaleLinesInterWidth),
|
|
(Single)(Center.X),
|
|
(Single)(Center.Y),
|
|
(Single)(Center.X + 2 * m_ScaleLinesInterOuterRadius * Math.Cos((m_BaseArcStart + countValue * m_BaseArcSweep / (m_MaxValue - m_MinValue) + counter2 * m_BaseArcSweep / (((Single)((m_MaxValue - m_MinValue) / m_ScaleLinesMajorStepValue)) * (m_ScaleLinesMinorNumOf + 1))) * Math.PI / 180.0)),
|
|
(Single)(Center.Y + 2 * m_ScaleLinesInterOuterRadius * Math.Sin((m_BaseArcStart + countValue * m_BaseArcSweep / (m_MaxValue - m_MinValue) + counter2 * m_BaseArcSweep / (((Single)((m_MaxValue - m_MinValue) / m_ScaleLinesMajorStepValue)) * (m_ScaleLinesMinorNumOf + 1))) * Math.PI / 180.0)));
|
|
|
|
gp.Reset();
|
|
gp.AddEllipse(new Rectangle(m_Center.X - m_ScaleLinesMinorOuterRadius, m_Center.Y - m_ScaleLinesMinorOuterRadius, 2 * m_ScaleLinesMinorOuterRadius, 2 * m_ScaleLinesMinorOuterRadius));
|
|
gp.Reverse();
|
|
gp.AddEllipse(new Rectangle(m_Center.X - m_ScaleLinesMinorInnerRadius, m_Center.Y - m_ScaleLinesMinorInnerRadius, 2 * m_ScaleLinesMinorInnerRadius, 2 * m_ScaleLinesMinorInnerRadius));
|
|
gp.Reverse();
|
|
ggr.SetClip(gp);
|
|
}
|
|
else
|
|
{
|
|
ggr.DrawLine(new Pen(m_ScaleLinesMinorColor, m_ScaleLinesMinorWidth),
|
|
(Single)(Center.X),
|
|
(Single)(Center.Y),
|
|
(Single)(Center.X + 2 * m_ScaleLinesMinorOuterRadius * Math.Cos((m_BaseArcStart + countValue * m_BaseArcSweep / (m_MaxValue - m_MinValue) + counter2 * m_BaseArcSweep / (((Single)((m_MaxValue - m_MinValue) / m_ScaleLinesMajorStepValue)) * (m_ScaleLinesMinorNumOf + 1))) * Math.PI / 180.0)),
|
|
(Single)(Center.Y + 2 * m_ScaleLinesMinorOuterRadius * Math.Sin((m_BaseArcStart + countValue * m_BaseArcSweep / (m_MaxValue - m_MinValue) + counter2 * m_BaseArcSweep / (((Single)((m_MaxValue - m_MinValue) / m_ScaleLinesMajorStepValue)) * (m_ScaleLinesMinorNumOf + 1))) * Math.PI / 180.0)));
|
|
}
|
|
}
|
|
}
|
|
|
|
ggr.SetClip(ClientRectangle);
|
|
|
|
if (m_ScaleNumbersRotation != 0)
|
|
{
|
|
ggr.TextRenderingHint = System.Drawing.Text.TextRenderingHint.AntiAlias;
|
|
ggr.RotateTransform(90.0F + m_BaseArcStart + countValue * m_BaseArcSweep / (m_MaxValue - m_MinValue));
|
|
}
|
|
|
|
/*ggr.TranslateTransform((Single)(Center.X + m_ScaleNumbersRadius * Math.Cos((m_BaseArcStart + countValue * m_BaseArcSweep / (m_MaxValue - m_MinValue)) * Math.PI / 180.0f)),
|
|
(Single)(Center.Y + m_ScaleNumbersRadius * Math.Sin((m_BaseArcStart + countValue * m_BaseArcSweep / (m_MaxValue - m_MinValue)) * Math.PI / 180.0f)),
|
|
System.Drawing.Drawing2D.MatrixOrder.Append);*/
|
|
|
|
ggr.TranslateTransform((Single)(Center.X * scale + m_ScaleNumbersRadius * scale * Math.Cos((m_BaseArcStart + countValue * m_BaseArcSweep / (m_MaxValue - m_MinValue)) * Math.PI / 180.0f)),
|
|
(Single)(Center.Y * scale + m_ScaleNumbersRadius * scale * Math.Sin((m_BaseArcStart + countValue * m_BaseArcSweep / (m_MaxValue - m_MinValue)) * Math.PI / 180.0f)),
|
|
System.Drawing.Drawing2D.MatrixOrder.Append);
|
|
|
|
if (counter1 >= ScaleNumbersStartScaleLine - 1)
|
|
{
|
|
ggr.DrawString(valueText, Font, new SolidBrush(m_ScaleNumbersColor), -boundingBox.Width / 2, -fontBoundY1 - (fontBoundY2 - fontBoundY1 + 1) / 2, StringFormat.GenericTypographic);
|
|
}
|
|
|
|
countValue += m_ScaleLinesMajorStepValue;
|
|
counter1 ++;
|
|
}
|
|
|
|
ggr.ResetTransform();
|
|
// scale it
|
|
if (basesize != null)
|
|
{
|
|
ggr.ScaleTransform(scale, scale);
|
|
}
|
|
ggr.SetClip(ClientRectangle);
|
|
|
|
if (m_ScaleNumbersRotation != 0)
|
|
{
|
|
ggr.TextRenderingHint = System.Drawing.Text.TextRenderingHint.SystemDefault;
|
|
}
|
|
|
|
for (Int32 counter= 0; counter<NUMOFCAPS; counter++)
|
|
{
|
|
if (m_CapText[counter] != "")
|
|
{
|
|
ggr.DrawString(m_CapText[counter], Font, new SolidBrush(m_CapColor[counter]), m_CapPosition[counter].X, m_CapPosition[counter].Y, StringFormat.GenericTypographic);
|
|
}
|
|
}
|
|
}
|
|
|
|
pe.Graphics.DrawImageUnscaled(gaugeBitmap, 0, 0);
|
|
pe.Graphics.SmoothingMode = SmoothingMode.AntiAlias;
|
|
pe.Graphics.PixelOffsetMode = PixelOffsetMode.HighQuality;
|
|
|
|
// scale it
|
|
if (basesize != null)
|
|
{
|
|
pe.Graphics.ScaleTransform(scale, scale);
|
|
}
|
|
|
|
byte m_NeedIdx; // make a local one
|
|
|
|
for (byte counter = 0; counter < m_NeedleEnabled.Length; counter++)
|
|
{
|
|
m_NeedIdx = counter;
|
|
|
|
if (!m_NeedleEnabled[m_NeedIdx])
|
|
continue;
|
|
|
|
Single brushAngle = (Int32)(m_BaseArcStart + (m_value[m_NeedIdx] - m_MinValue) * m_BaseArcSweep / (m_MaxValue - m_MinValue)) % 360;
|
|
Double needleAngle = brushAngle * Math.PI / 180;
|
|
|
|
switch (m_NeedleType[m_NeedIdx])
|
|
{
|
|
case 0:
|
|
PointF[] points = new PointF[3];
|
|
Brush brush1 = Brushes.White;
|
|
Brush brush2 = Brushes.White;
|
|
Brush brush3 = Brushes.White;
|
|
Brush brush4 = Brushes.White;
|
|
|
|
Brush brushBucket = Brushes.White;
|
|
Int32 subcol = (Int32)(((brushAngle + 225) % 180) * 100 / 180);
|
|
Int32 subcol2 = (Int32)(((brushAngle + 135) % 180) * 100 / 180);
|
|
|
|
pe.Graphics.FillEllipse(new SolidBrush(m_NeedleColor2[m_NeedIdx]), Center.X - m_NeedleWidth[m_NeedIdx] * 3, Center.Y - m_NeedleWidth[m_NeedIdx] * 3, m_NeedleWidth[m_NeedIdx] * 6, m_NeedleWidth[m_NeedIdx] * 6);
|
|
switch (m_NeedleColor1[m_NeedIdx])
|
|
{
|
|
case NeedleColorEnum.Gray:
|
|
brush1 = new SolidBrush(Color.FromArgb(80 + subcol, 80 + subcol, 80 + subcol));
|
|
brush2 = new SolidBrush(Color.FromArgb(180 - subcol, 180 - subcol, 180 - subcol));
|
|
brush3 = new SolidBrush(Color.FromArgb(80 + subcol2, 80 + subcol2, 80 + subcol2));
|
|
brush4 = new SolidBrush(Color.FromArgb(180 - subcol2, 180 - subcol2, 180 - subcol2));
|
|
pe.Graphics.DrawEllipse(Pens.Gray, Center.X - m_NeedleWidth[m_NeedIdx] * 3, Center.Y - m_NeedleWidth[m_NeedIdx] * 3, m_NeedleWidth[m_NeedIdx] * 6, m_NeedleWidth[m_NeedIdx] * 6);
|
|
break;
|
|
case NeedleColorEnum.Red:
|
|
brush1 = new SolidBrush(Color.FromArgb(145 + subcol, subcol, subcol));
|
|
brush2 = new SolidBrush(Color.FromArgb(245 - subcol, 100 - subcol, 100 - subcol));
|
|
brush3 = new SolidBrush(Color.FromArgb(145 + subcol2, subcol2, subcol2));
|
|
brush4 = new SolidBrush(Color.FromArgb(245 - subcol2, 100 - subcol2, 100 - subcol2));
|
|
pe.Graphics.DrawEllipse(Pens.Red, Center.X - m_NeedleWidth[m_NeedIdx] * 3, Center.Y - m_NeedleWidth[m_NeedIdx] * 3, m_NeedleWidth[m_NeedIdx] * 6, m_NeedleWidth[m_NeedIdx] * 6);
|
|
break;
|
|
case NeedleColorEnum.Green:
|
|
brush1 = new SolidBrush(Color.FromArgb(subcol, 145 + subcol, subcol));
|
|
brush2 = new SolidBrush(Color.FromArgb(100 - subcol, 245 - subcol, 100 - subcol));
|
|
brush3 = new SolidBrush(Color.FromArgb(subcol2, 145 + subcol2, subcol2));
|
|
brush4 = new SolidBrush(Color.FromArgb(100 - subcol2, 245 - subcol2, 100 - subcol2));
|
|
pe.Graphics.DrawEllipse(Pens.Green, Center.X - m_NeedleWidth[m_NeedIdx] * 3, Center.Y - m_NeedleWidth[m_NeedIdx] * 3, m_NeedleWidth[m_NeedIdx] * 6, m_NeedleWidth[m_NeedIdx] * 6);
|
|
break;
|
|
case NeedleColorEnum.Blue:
|
|
brush1 = new SolidBrush(Color.FromArgb(subcol, subcol, 145 + subcol));
|
|
brush2 = new SolidBrush(Color.FromArgb(100 - subcol, 100 - subcol, 245 - subcol));
|
|
brush3 = new SolidBrush(Color.FromArgb(subcol2, subcol2, 145 + subcol2));
|
|
brush4 = new SolidBrush(Color.FromArgb(100 - subcol2, 100 - subcol2, 245 - subcol2));
|
|
pe.Graphics.DrawEllipse(Pens.Blue, Center.X - m_NeedleWidth[m_NeedIdx] * 3, Center.Y - m_NeedleWidth[m_NeedIdx] * 3, m_NeedleWidth[m_NeedIdx] * 6, m_NeedleWidth[m_NeedIdx] * 6);
|
|
break;
|
|
case NeedleColorEnum.Magenta:
|
|
brush1 = new SolidBrush(Color.FromArgb(subcol, 145 + subcol, 145 + subcol));
|
|
brush2 = new SolidBrush(Color.FromArgb(100 - subcol, 245 - subcol, 245 - subcol));
|
|
brush3 = new SolidBrush(Color.FromArgb(subcol2, 145 + subcol2, 145 + subcol2));
|
|
brush4 = new SolidBrush(Color.FromArgb(100 - subcol2, 245 - subcol2, 245 - subcol2));
|
|
pe.Graphics.DrawEllipse(Pens.Magenta, Center.X - m_NeedleWidth[m_NeedIdx] * 3, Center.Y - m_NeedleWidth[m_NeedIdx] * 3, m_NeedleWidth[m_NeedIdx] * 6, m_NeedleWidth[m_NeedIdx] * 6);
|
|
break;
|
|
case NeedleColorEnum.Violet:
|
|
brush1 = new SolidBrush(Color.FromArgb(145 + subcol, subcol, 145 + subcol));
|
|
brush2 = new SolidBrush(Color.FromArgb(245 - subcol, 100 - subcol, 245 - subcol));
|
|
brush3 = new SolidBrush(Color.FromArgb(145 + subcol2, subcol2, 145 + subcol2));
|
|
brush4 = new SolidBrush(Color.FromArgb(245 - subcol2, 100 - subcol2, 245 - subcol2));
|
|
pe.Graphics.DrawEllipse(Pens.Violet, Center.X - m_NeedleWidth[m_NeedIdx] * 3, Center.Y - m_NeedleWidth[m_NeedIdx] * 3, m_NeedleWidth[m_NeedIdx] * 6, m_NeedleWidth[m_NeedIdx] * 6);
|
|
break;
|
|
case NeedleColorEnum.Yellow:
|
|
brush1 = new SolidBrush(Color.FromArgb(145 + subcol, 145 + subcol, subcol));
|
|
brush2 = new SolidBrush(Color.FromArgb(245 - subcol, 245 - subcol, 100 - subcol));
|
|
brush3 = new SolidBrush(Color.FromArgb(145 + subcol2, 145 + subcol2, subcol2));
|
|
brush4 = new SolidBrush(Color.FromArgb(245 - subcol2, 245 - subcol2, 100 - subcol2));
|
|
pe.Graphics.DrawEllipse(Pens.Violet, Center.X - m_NeedleWidth[m_NeedIdx] * 3, Center.Y - m_NeedleWidth[m_NeedIdx] * 3, m_NeedleWidth[m_NeedIdx] * 6, m_NeedleWidth[m_NeedIdx] * 6);
|
|
break;
|
|
}
|
|
|
|
if (Math.Floor((Single)(((brushAngle + 225) % 360) / 180.0)) == 0)
|
|
{
|
|
brushBucket = brush1;
|
|
brush1 = brush2;
|
|
brush2 = brushBucket;
|
|
}
|
|
|
|
if (Math.Floor((Single)(((brushAngle + 135) % 360) / 180.0)) == 0)
|
|
{
|
|
brush4 = brush3;
|
|
}
|
|
|
|
points[0].X = (Single)(Center.X + m_NeedleRadius[m_NeedIdx] * Math.Cos(needleAngle));
|
|
points[0].Y = (Single)(Center.Y + m_NeedleRadius[m_NeedIdx] * Math.Sin(needleAngle));
|
|
points[1].X = (Single)(Center.X - m_NeedleRadius[m_NeedIdx] / 20 * Math.Cos(needleAngle));
|
|
points[1].Y = (Single)(Center.Y - m_NeedleRadius[m_NeedIdx] / 20 * Math.Sin(needleAngle));
|
|
points[2].X = (Single)(Center.X - m_NeedleRadius[m_NeedIdx] / 5 * Math.Cos(needleAngle) + m_NeedleWidth[m_NeedIdx] * 2 * Math.Cos(needleAngle + Math.PI / 2));
|
|
points[2].Y = (Single)(Center.Y - m_NeedleRadius[m_NeedIdx] / 5 * Math.Sin(needleAngle) + m_NeedleWidth[m_NeedIdx] * 2 * Math.Sin(needleAngle + Math.PI / 2));
|
|
pe.Graphics.FillPolygon(brush1, points);
|
|
|
|
points[2].X = (Single)(Center.X - m_NeedleRadius[m_NeedIdx] / 5 * Math.Cos(needleAngle) + m_NeedleWidth[m_NeedIdx] * 2 * Math.Cos(needleAngle - Math.PI / 2));
|
|
points[2].Y = (Single)(Center.Y - m_NeedleRadius[m_NeedIdx] / 5 * Math.Sin(needleAngle) + m_NeedleWidth[m_NeedIdx] * 2 * Math.Sin(needleAngle - Math.PI / 2));
|
|
pe.Graphics.FillPolygon(brush2, points);
|
|
|
|
points[0].X = (Single)(Center.X - (m_NeedleRadius[m_NeedIdx] / 20 - 1) * Math.Cos(needleAngle));
|
|
points[0].Y = (Single)(Center.Y - (m_NeedleRadius[m_NeedIdx] / 20 - 1) * Math.Sin(needleAngle));
|
|
points[1].X = (Single)(Center.X - m_NeedleRadius[m_NeedIdx] / 5 * Math.Cos(needleAngle) + m_NeedleWidth[m_NeedIdx] * 2 * Math.Cos(needleAngle + Math.PI / 2));
|
|
points[1].Y = (Single)(Center.Y - m_NeedleRadius[m_NeedIdx] / 5 * Math.Sin(needleAngle) + m_NeedleWidth[m_NeedIdx] * 2 * Math.Sin(needleAngle + Math.PI / 2));
|
|
points[2].X = (Single)(Center.X - m_NeedleRadius[m_NeedIdx] / 5 * Math.Cos(needleAngle) + m_NeedleWidth[m_NeedIdx] * 2 * Math.Cos(needleAngle - Math.PI / 2));
|
|
points[2].Y = (Single)(Center.Y - m_NeedleRadius[m_NeedIdx] / 5 * Math.Sin(needleAngle) + m_NeedleWidth[m_NeedIdx] * 2 * Math.Sin(needleAngle - Math.PI / 2));
|
|
pe.Graphics.FillPolygon(brush4, points);
|
|
|
|
points[0].X = (Single)(Center.X - m_NeedleRadius[m_NeedIdx] / 20 * Math.Cos(needleAngle));
|
|
points[0].Y = (Single)(Center.Y - m_NeedleRadius[m_NeedIdx] / 20 * Math.Sin(needleAngle));
|
|
points[1].X = (Single)(Center.X + m_NeedleRadius[m_NeedIdx] * Math.Cos(needleAngle));
|
|
points[1].Y = (Single)(Center.Y + m_NeedleRadius[m_NeedIdx] * Math.Sin(needleAngle));
|
|
|
|
pe.Graphics.DrawLine(new Pen(m_NeedleColor2[m_NeedIdx]), Center.X, Center.Y, points[0].X, points[0].Y);
|
|
pe.Graphics.DrawLine(new Pen(m_NeedleColor2[m_NeedIdx]), Center.X, Center.Y, points[1].X, points[1].Y);
|
|
break;
|
|
case 1:
|
|
Point startPoint = new Point((Int32)(Center.X - m_NeedleRadius[m_NeedIdx] / 8 * Math.Cos(needleAngle)),
|
|
(Int32)(Center.Y - m_NeedleRadius[m_NeedIdx] / 8 * Math.Sin(needleAngle)));
|
|
Point endPoint = new Point((Int32)(Center.X + m_NeedleRadius[m_NeedIdx] * Math.Cos(needleAngle)),
|
|
(Int32)(Center.Y + m_NeedleRadius[m_NeedIdx] * Math.Sin(needleAngle)));
|
|
|
|
pe.Graphics.FillEllipse(new SolidBrush(m_NeedleColor2[m_NeedIdx]), Center.X - m_NeedleWidth[m_NeedIdx] * 3, Center.Y - m_NeedleWidth[m_NeedIdx] * 3, m_NeedleWidth[m_NeedIdx] * 6, m_NeedleWidth[m_NeedIdx] * 6);
|
|
|
|
switch (m_NeedleColor1[m_NeedIdx])
|
|
{
|
|
case NeedleColorEnum.Gray:
|
|
pe.Graphics.DrawLine(new Pen(Color.DarkGray, m_NeedleWidth[m_NeedIdx]), Center.X, Center.Y, endPoint.X, endPoint.Y);
|
|
pe.Graphics.DrawLine(new Pen(Color.DarkGray, m_NeedleWidth[m_NeedIdx]), Center.X, Center.Y, startPoint.X, startPoint.Y);
|
|
break;
|
|
case NeedleColorEnum.Red:
|
|
pe.Graphics.DrawLine(new Pen(Color.Red, m_NeedleWidth[m_NeedIdx]), Center.X, Center.Y, endPoint.X, endPoint.Y);
|
|
pe.Graphics.DrawLine(new Pen(Color.Red, m_NeedleWidth[m_NeedIdx]), Center.X, Center.Y, startPoint.X, startPoint.Y);
|
|
break;
|
|
case NeedleColorEnum.Green:
|
|
pe.Graphics.DrawLine(new Pen(Color.Green, m_NeedleWidth[m_NeedIdx]), Center.X, Center.Y, endPoint.X, endPoint.Y);
|
|
pe.Graphics.DrawLine(new Pen(Color.Green, m_NeedleWidth[m_NeedIdx]), Center.X, Center.Y, startPoint.X, startPoint.Y);
|
|
break;
|
|
case NeedleColorEnum.Blue:
|
|
pe.Graphics.DrawLine(new Pen(Color.Blue, m_NeedleWidth[m_NeedIdx]), Center.X, Center.Y, endPoint.X, endPoint.Y);
|
|
pe.Graphics.DrawLine(new Pen(Color.Blue, m_NeedleWidth[m_NeedIdx]), Center.X, Center.Y, startPoint.X, startPoint.Y);
|
|
break;
|
|
case NeedleColorEnum.Magenta:
|
|
pe.Graphics.DrawLine(new Pen(Color.Magenta, m_NeedleWidth[m_NeedIdx]), Center.X, Center.Y, endPoint.X, endPoint.Y);
|
|
pe.Graphics.DrawLine(new Pen(Color.Magenta, m_NeedleWidth[m_NeedIdx]), Center.X, Center.Y, startPoint.X, startPoint.Y);
|
|
break;
|
|
case NeedleColorEnum.Violet:
|
|
pe.Graphics.DrawLine(new Pen(Color.Violet, m_NeedleWidth[m_NeedIdx]), Center.X, Center.Y, endPoint.X, endPoint.Y);
|
|
pe.Graphics.DrawLine(new Pen(Color.Violet, m_NeedleWidth[m_NeedIdx]), Center.X, Center.Y, startPoint.X, startPoint.Y);
|
|
break;
|
|
case NeedleColorEnum.Yellow:
|
|
pe.Graphics.DrawLine(new Pen(Color.Yellow, m_NeedleWidth[m_NeedIdx]), Center.X, Center.Y, endPoint.X, endPoint.Y);
|
|
pe.Graphics.DrawLine(new Pen(Color.Yellow, m_NeedleWidth[m_NeedIdx]), Center.X, Center.Y, startPoint.X, startPoint.Y);
|
|
break;
|
|
}
|
|
break;
|
|
}
|
|
} // needles
|
|
}
|
|
|
|
protected override void OnResize(EventArgs e)
|
|
{
|
|
//if (this.Width > this.Height)
|
|
{
|
|
// this.Height = this.Width;
|
|
}
|
|
//else
|
|
{
|
|
this.Width = this.Height;
|
|
}
|
|
//this.Center = new Point(this.Width / 2, this.Width / 2);
|
|
|
|
drawGaugeBackground = true;
|
|
Refresh();
|
|
}
|
|
|
|
public new Size Size { get { return base.Size; } set { base.Size = value; } }
|
|
|
|
[System.ComponentModel.Browsable(true),
|
|
System.ComponentModel.Category("AGauge"),
|
|
System.ComponentModel.Description("Base Size the dials are designed for")]
|
|
public Size basesize { get { return _basesize; } set { _basesize = value; } }
|
|
|
|
private Size _basesize = new Size(150,150);
|
|
|
|
#endregion
|
|
|
|
private void InitializeComponent()
|
|
{
|
|
this.SuspendLayout();
|
|
//
|
|
// AGauge
|
|
//
|
|
this.BackColor = System.Drawing.Color.Transparent;
|
|
this.BackgroundImageLayout = System.Windows.Forms.ImageLayout.Zoom;
|
|
this.DoubleBuffered = true;
|
|
this.Name = "AGauge";
|
|
this.ResumeLayout(false);
|
|
|
|
}
|
|
|
|
}
|
|
}
|