259 lines
		
	
	
		
			8.4 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			259 lines
		
	
	
		
			8.4 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
using System;
 | 
						|
using System.Collections;
 | 
						|
using System.Text;
 | 
						|
using System.Drawing.Drawing2D;
 | 
						|
using System.Drawing;
 | 
						|
 | 
						|
#if AdvTree
 | 
						|
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.SolidColor;
 | 
						|
            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));
 | 
						|
        }
 | 
						|
 | 
						|
        /// <summary>
 | 
						|
        /// Initializes the collection with the two color blend.
 | 
						|
        /// </summary>
 | 
						|
        /// <param name="collection">Collection to initialize.</param>
 | 
						|
        /// <param name="backColor1">Solid Color</param>
 | 
						|
        public static void InitializeCollection(BackgroundColorBlendCollection collection, Color backColor)
 | 
						|
        {
 | 
						|
            collection.Clear();
 | 
						|
            collection.Add(new BackgroundColorBlend(backColor, 0f));
 | 
						|
        }
 | 
						|
		#endregion
 | 
						|
    }
 | 
						|
 | 
						|
    internal enum eBackgroundColorBlendType
 | 
						|
    {
 | 
						|
        Invalid,
 | 
						|
        Relative,
 | 
						|
        Absolute,
 | 
						|
        SolidColor
 | 
						|
    }
 | 
						|
}
 |