190 lines
5.8 KiB
C#
190 lines
5.8 KiB
C#
using System;
|
|
using System.Text;
|
|
using System.Drawing;
|
|
|
|
#if AdvTree
|
|
namespace DevComponents.Tree.TextMarkup
|
|
#elif DOTNETBAR
|
|
namespace DevComponents.DotNetBar.TextMarkup
|
|
#elif SUPERGRID
|
|
namespace DevComponents.SuperGrid.TextMarkup
|
|
#elif LAYOUT
|
|
namespace DevComponents.DotNetBar.Layout.TextMarkup
|
|
#endif
|
|
{
|
|
#if FRAMEWORK20
|
|
public static class MarkupSettings
|
|
#else
|
|
public class MarkupSettings
|
|
#endif
|
|
{
|
|
private static HyperlinkStyle _NormalHyperlink = new HyperlinkStyle(Color.Blue, eHyperlinkUnderlineStyle.SolidLine);
|
|
/// <summary>
|
|
/// Gets the style of the hyperlink in its default state.
|
|
/// </summary>
|
|
public static HyperlinkStyle NormalHyperlink
|
|
{
|
|
get { return _NormalHyperlink; }
|
|
}
|
|
|
|
private static HyperlinkStyle _MouseOverHyperlink = new HyperlinkStyle();
|
|
/// <summary>
|
|
/// Gets the style of the hyperlink when mouse is over the link.
|
|
/// </summary>
|
|
public static HyperlinkStyle MouseOverHyperlink
|
|
{
|
|
get { return _MouseOverHyperlink; }
|
|
}
|
|
|
|
private static HyperlinkStyle _VisitedHyperlink = new HyperlinkStyle();
|
|
/// <summary>
|
|
/// Gets the style of the visited hyperlink.
|
|
/// </summary>
|
|
public static HyperlinkStyle VisitedHyperlink
|
|
{
|
|
get { return _VisitedHyperlink; }
|
|
}
|
|
|
|
/// <summary>
|
|
/// Represents the method that will handle the ResolveImage event.
|
|
/// </summary>
|
|
public delegate void ResolveImageEventHandler(object sender, ResolveImageEventArgs e);
|
|
// <summary>
|
|
/// Occurs when DotNetBar is looking for an image for one of the internal img tags that is
|
|
/// used within the minimarkup. You need to set Handled=true if you want your custom image
|
|
/// to be used instead of the built-in resource resolving mechanism.
|
|
/// </summary>
|
|
public static event ResolveImageEventHandler ResolveImage;
|
|
internal static void InvokeResolveImage(ResolveImageEventArgs e)
|
|
{
|
|
if (ResolveImage != null)
|
|
ResolveImage(null, e);
|
|
}
|
|
}
|
|
|
|
/// <summary>
|
|
/// Defines the text-markup hyperlink appearance style.
|
|
/// </summary>
|
|
public class HyperlinkStyle
|
|
{
|
|
/// <summary>
|
|
/// Initializes a new instance of the HyperlinkStyle class.
|
|
/// </summary>
|
|
public HyperlinkStyle()
|
|
{
|
|
}
|
|
|
|
/// <summary>
|
|
/// Initializes a new instance of the HyperlinkStyle class.
|
|
/// </summary>
|
|
/// <param name="textColor"></param>
|
|
/// <param name="underlineStyle"></param>
|
|
public HyperlinkStyle(Color textColor, eHyperlinkUnderlineStyle underlineStyle)
|
|
{
|
|
_TextColor = textColor;
|
|
_UnderlineStyle = underlineStyle;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Initializes a new instance of the HyperlinkStyle class.
|
|
/// </summary>
|
|
/// <param name="textColor"></param>
|
|
/// <param name="backColor"></param>
|
|
/// <param name="underlineStyle"></param>
|
|
public HyperlinkStyle(Color textColor, Color backColor, eHyperlinkUnderlineStyle underlineStyle)
|
|
{
|
|
_TextColor = textColor;
|
|
_BackColor = backColor;
|
|
_UnderlineStyle = underlineStyle;
|
|
}
|
|
private Color _TextColor = Color.Empty;
|
|
/// <summary>
|
|
/// Gets or sets hyperlink text color.
|
|
/// </summary>
|
|
public Color TextColor
|
|
{
|
|
get { return _TextColor; }
|
|
set
|
|
{
|
|
if (_TextColor != value)
|
|
{
|
|
_TextColor = value;
|
|
}
|
|
}
|
|
}
|
|
|
|
private Color _BackColor = Color.Empty;
|
|
/// <summary>
|
|
/// Gets or sets hyperlink back color.
|
|
/// </summary>
|
|
public Color BackColor
|
|
{
|
|
get { return _BackColor; }
|
|
set
|
|
{
|
|
if (_BackColor != value)
|
|
{
|
|
_BackColor = value;
|
|
}
|
|
}
|
|
}
|
|
|
|
private eHyperlinkUnderlineStyle _UnderlineStyle = eHyperlinkUnderlineStyle.None;
|
|
/// <summary>
|
|
/// Gets or sets the underline style for the hyperlink.
|
|
/// </summary>
|
|
public eHyperlinkUnderlineStyle UnderlineStyle
|
|
{
|
|
get { return _UnderlineStyle; }
|
|
set
|
|
{
|
|
if (_UnderlineStyle != value)
|
|
{
|
|
_UnderlineStyle = value;
|
|
}
|
|
}
|
|
}
|
|
|
|
/// <summary>
|
|
/// Gets whether style has been changed from its default state.
|
|
/// </summary>
|
|
public bool IsChanged
|
|
{
|
|
get { return !_TextColor.IsEmpty || !_BackColor.IsEmpty || _UnderlineStyle != eHyperlinkUnderlineStyle.None; }
|
|
}
|
|
}
|
|
|
|
public enum eHyperlinkUnderlineStyle
|
|
{
|
|
None,
|
|
SolidLine,
|
|
DashedLine
|
|
}
|
|
|
|
/// <summary>
|
|
/// <summary>
|
|
/// Event arguments for ResolveImage event.
|
|
/// </summary>
|
|
public class ResolveImageEventArgs : EventArgs
|
|
{
|
|
/// <summary>
|
|
/// Indicates that event has been handled and that ResolvedImage should be used.
|
|
/// </summary>
|
|
public bool Handled = false;
|
|
/// <summary>
|
|
/// Indicates the string key parameters in url-style for the image that needs to be resolved.
|
|
/// </summary>
|
|
public string Key = "";
|
|
/// <summary>
|
|
/// Indicates the resolved image value.
|
|
/// you need to set this value to the resolved image and you need to set Handled property to true.
|
|
/// </summary>
|
|
public Image ResolvedImage = null;
|
|
/// <summary>
|
|
/// Default constructor.
|
|
/// </summary>
|
|
public ResolveImageEventArgs() { }
|
|
}
|
|
|
|
}
|