DotNet 4.8.1 build of DotNetBar

This commit is contained in:
2025-02-07 10:35:23 -05:00
parent 33439b63a0
commit 6b0a5d60f4
2609 changed files with 989814 additions and 7 deletions

View File

@@ -0,0 +1,87 @@
using System;
using System.Text;
using System.Drawing;
using System.ComponentModel;
#if TREEGX
namespace DevComponents.Tree
#elif DOTNETBAR
namespace DevComponents.DotNetBar
#endif
{
/// <summary>
/// Defines single color blend point for the multicolor gradient fills.
/// </summary>
[ToolboxItem(false),DesignTimeVisible(false),TypeConverter(typeof(BackgroundColorBlendConverter))]
public class BackgroundColorBlend
{
#region Private Variables
private Color m_Color = Color.Empty;
private float m_Position = 0;
#endregion
#region Internal Implementation
/// <summary>
/// Creates new instance of the class. When defining multicolor gradinet blends and using the percentage positions the positions created
/// must start with 0f and end with 1f.
/// </summary>
public BackgroundColorBlend() {}
/// <summary>
/// Creates new instance of the class and initialize it with default values.
/// </summary>
public BackgroundColorBlend(Color color, float position)
{
m_Color=color;
m_Position=position;
}
/// <summary>
/// Creates new instance of the class and initialize it with default values.
/// </summary>
public BackgroundColorBlend(int color, float position)
{
m_Color = ColorScheme.GetColor(color);
m_Position = position;
}
/// <summary>
/// Gets or sets Color to use in multicolor gradient blend at specified position.
/// </summary>
[Browsable(true), Description("Indicates the Color to use in multicolor gradient blend at specified position.")]
public Color Color
{
get { return m_Color; }
set
{
m_Color = value;
OnColorBlendChanged();
}
}
private bool ShouldSerializeColor()
{
return !m_Color.IsEmpty;
}
/// <summary>
/// Gets or sets the color position in multicolor gradient blend. Values less or equal to 1 are used as percentage specifing percentages of distance along the gradient line.
/// Values greater than 1 are used as absolute pixel values of distance along the gradient line.
/// </summary>
[Browsable(true), DefaultValue(0f), Description("")]
public float Position
{
get { return m_Position; }
set
{
m_Position = value;
OnColorBlendChanged();
}
}
private void OnColorBlendChanged()
{
}
#endregion
}
}

View File

@@ -0,0 +1,244 @@
using System;
using System.Collections;
using System.Text;
using System.Drawing.Drawing2D;
using System.Drawing;
#if TREEGX
namespace DevComponents.Tree
#elif DOTNETBAR
namespace DevComponents.DotNetBar
#endif
{
/// <summary>
/// Represents Collection for the BackgroundColorBlend objects.
/// </summary>
public class BackgroundColorBlendCollection : CollectionBase
{
#region Private Variables
private ElementStyle m_Parent = null;
#endregion
#region Internal Implementation
/// <summary>Creates new instance of the class.</summary>
public BackgroundColorBlendCollection() {}
internal ElementStyle Parent
{
get { return m_Parent; }
set { m_Parent = value; }
}
/// <summary>
/// Adds new object to the collection.
/// </summary>
/// <param name="item">Object to add.</param>
/// <returns>Index of newly added object.</returns>
public int Add(BackgroundColorBlend item)
{
return List.Add(item);
}
/// <summary>
/// Adds array of new objects to the collection.
/// </summary>
/// <param name="items">Array of object to add.</param>
public void AddRange(BackgroundColorBlend[] items)
{
foreach (BackgroundColorBlend item in items)
this.Add(item);
}
/// <summary>
/// Returns reference to the object in collection based on it's index.
/// </summary>
public BackgroundColorBlend this[int index]
{
get {return (BackgroundColorBlend)(List[index]);}
set {List[index] = value;}
}
/// <summary>
/// Inserts new object into the collection.
/// </summary>
/// <param name="index">Position of the object.</param>
/// <param name="value">Object to insert.</param>
public void Insert(int index, BackgroundColorBlend value)
{
List.Insert(index, value);
}
/// <summary>
/// Returns index of the object inside of the collection.
/// </summary>
/// <param name="value">Reference to the object.</param>
/// <returns>Index of the object.</returns>
public int IndexOf(BackgroundColorBlend value)
{
return List.IndexOf(value);
}
/// <summary>
/// Returns whether collection contains specified object.
/// </summary>
/// <param name="value">Object to look for.</param>
/// <returns>true if object is part of the collection, otherwise false.</returns>
public bool Contains(BackgroundColorBlend value)
{
return List.Contains(value);
}
/// <summary>
/// Removes specified object from the collection.
/// </summary>
/// <param name="value"></param>
public void Remove(BackgroundColorBlend value)
{
List.Remove(value);
}
//protected override void OnRemoveComplete(int index,object value)
//{
// base.OnRemoveComplete(index,value);
// BackgroundColorBlend me=value as BackgroundColorBlend;
//}
//protected override void OnInsertComplete(int index,object value)
//{
// base.OnInsertComplete(index,value);
// BackgroundColorBlend me=value as BackgroundColorBlend;
//}
/// <summary>
/// Copies collection into the specified array.
/// </summary>
/// <param name="array">Array to copy collection to.</param>
/// <param name="index">Starting index.</param>
public void CopyTo(BackgroundColorBlend[] array, int index)
{
List.CopyTo(array, index);
}
/// <summary>
/// Copies contained items to the BackgroundColorBlend array.
/// </summary>
/// <param name="array">Array to copy to.</param>
internal void CopyTo(BackgroundColorBlend[] array)
{
List.CopyTo(array,0);
}
/// <summary>
/// Creates ColorBlend object based on the members of the collection. ColorBlend object will be valid only if all members of the collection
/// represents relative/percentage based color blends.
/// </summary>
/// <returns></returns>
public ColorBlend GetColorBlend()
{
ColorBlend blend = new ColorBlend();
Color[] colors = new Color[this.Count];
float[] positions = new float[this.Count];
for(int i=0; i<this.Count; i++)
{
BackgroundColorBlend b = this[i];
colors[i] = b.Color;
positions[i] = b.Position;
}
blend.Colors = colors;
blend.Positions = positions;
return blend;
}
/// <summary>
/// Adds the BackgroundColorBlend objects from the collection.
/// </summary>
/// <param name="col">Collection to copy objects from</param>
public void CopyFrom(BackgroundColorBlendCollection col)
{
foreach (BackgroundColorBlend b in col)
this.Add(b);
}
internal eBackgroundColorBlendType GetBlendType()
{
BackgroundColorBlendCollection c = this;
if (c.Count <= 1)
return eBackgroundColorBlendType.Invalid;
eBackgroundColorBlendType t = eBackgroundColorBlendType.Invalid;
foreach (BackgroundColorBlend b in c)
{
if (b.Position == 0 || b.Position == 1f)
continue;
if (b.Position <= 1f)
{
if (t == eBackgroundColorBlendType.Invalid)
t = eBackgroundColorBlendType.Relative;
else if (t == eBackgroundColorBlendType.Absolute)
{
t = eBackgroundColorBlendType.Invalid;
break;
}
}
else
{
if (t == eBackgroundColorBlendType.Invalid)
t = eBackgroundColorBlendType.Absolute;
else if (t == eBackgroundColorBlendType.Relative)
{
t = eBackgroundColorBlendType.Invalid;
break;
}
}
}
if (c.Count == 2 && c[0].Position == 0f && c[1].Position == 1f)
return eBackgroundColorBlendType.Relative;
if (t == eBackgroundColorBlendType.Invalid)
return t;
if (t == eBackgroundColorBlendType.Relative && c[0].Position != 0f && c[c.Count - 1].Position != 1f)
return eBackgroundColorBlendType.Invalid;
else if (t == eBackgroundColorBlendType.Absolute && ((c.Count / 2) * 2 != c.Count))
return eBackgroundColorBlendType.Invalid;
return t;
}
/// <summary>
/// Initializes the collection with the two color blend.
/// </summary>
/// <param name="collection">Collection to initialize.</param>
/// <param name="backColor1">Start color.</param>
/// <param name="backColor2">End color.</param>
public static void InitializeCollection(BackgroundColorBlendCollection collection, int backColor1, int backColor2)
{
InitializeCollection(collection, ColorScheme.GetColor(backColor1), ColorScheme.GetColor(backColor2));
}
/// <summary>
/// Initializes the collection with the two color blend.
/// </summary>
/// <param name="collection">Collection to initialize.</param>
/// <param name="backColor1">Start color.</param>
/// <param name="backColor2">End color.</param>
public static void InitializeCollection(BackgroundColorBlendCollection collection, Color backColor1, Color backColor2)
{
collection.Clear();
collection.Add(new BackgroundColorBlend(backColor1, 0f));
collection.Add(new BackgroundColorBlend(backColor2, 1f));
}
#endregion
}
internal enum eBackgroundColorBlendType
{
Invalid,
Relative,
Absolute
}
}

View File

@@ -0,0 +1,53 @@
using System;
using System.ComponentModel;
using System.ComponentModel.Design.Serialization;
using System.Globalization;
using System.Reflection;
using System.Drawing;
#if TREEGX
namespace DevComponents.Tree
#elif DOTNETBAR
namespace DevComponents.DotNetBar
#endif
{
/// <summary>
/// Represents BackgroundColorBlend object converter.
/// </summary>
public class BackgroundColorBlendConverter : TypeConverter
{
public BackgroundColorBlendConverter() { }
public override bool CanConvertTo(ITypeDescriptorContext context, Type destinationType)
{
if(destinationType==typeof(InstanceDescriptor))
return true;
return base.CanConvertTo(context, destinationType);
}
public override object ConvertTo(ITypeDescriptorContext context, CultureInfo culture, object value, Type destinationType)
{
if(destinationType==null)
throw new ArgumentNullException("destinationType");
if((destinationType==typeof(InstanceDescriptor)) && (value is BackgroundColorBlend))
{
BackgroundColorBlend doc = (BackgroundColorBlend)value;
Type[] constructorParams = null;
MemberInfo constructorMemberInfo = null;
object[] constructorValues = null;
constructorParams = new Type[2] { typeof(Color), typeof(float) };
constructorMemberInfo = typeof(BackgroundColorBlend).GetConstructor(constructorParams);
constructorValues = new object[2] { doc.Color, doc.Position };
if (constructorMemberInfo != null)
{
return new InstanceDescriptor(constructorMemberInfo, constructorValues);
}
}
return base.ConvertTo(context, culture, value, destinationType);
}
}
}

View File

@@ -0,0 +1,23 @@
using System;
using System.Text;
#if TREEGX
namespace DevComponents.Tree
#elif DOTNETBAR
namespace DevComponents.DotNetBar
#endif
{
/// <summary>
/// Defines the provider for the element style classes support.
/// </summary>
public interface IElementStyleClassProvider
{
/// <summary>
/// Returns the instance of the ElementStyle with given class name or null if there is no class with that name defined.
/// </summary>
/// <param name="className">Class name. See static members of ElementStyleClassKeys class for the list of available keys.</param>
/// <returns>Instance of ElementStyle for given class name or null if class cannot be found.</returns>
ElementStyle GetClass(string className);
}
}