mirror of
https://github.com/XCharts-Team/XCharts.git
synced 2026-05-25 10:20:10 +00:00
3.0 - serie clone and covert
This commit is contained in:
@@ -252,10 +252,8 @@ namespace XCharts
|
||||
foreach (var kvp in typeMap)
|
||||
{
|
||||
var type = kvp;
|
||||
if (RuntimeUtil.HasSubclass(type))
|
||||
continue;
|
||||
|
||||
list.Add(type);
|
||||
if (type.IsDefined(typeof(SerieHandlerAttribute), false))
|
||||
list.Add(type);
|
||||
}
|
||||
list.Sort((a, b) => { return a.Name.CompareTo(b.Name); });
|
||||
return list;
|
||||
|
||||
@@ -21,6 +21,7 @@ namespace XCharts
|
||||
//Editor m_Inspector;
|
||||
internal SerializedProperty baseProperty;
|
||||
internal SerializedProperty showProperty;
|
||||
internal List<HeaderMenuInfo> menus = new List<HeaderMenuInfo>();
|
||||
protected Dictionary<string, Type> m_CoordOptionsDic;
|
||||
protected List<string> m_CoordOptionsNames;
|
||||
|
||||
|
||||
@@ -62,7 +62,6 @@ namespace XCharts
|
||||
if (m_DataDimension.intValue < 1) m_DataDimension.intValue = 1;
|
||||
int dimension = m_DataDimension.intValue;
|
||||
bool showName = m_ShowDataName.boolValue;
|
||||
bool showSelected = serie is Pie;
|
||||
if (listSize != m_Datas.arraySize)
|
||||
{
|
||||
while (listSize > m_Datas.arraySize) m_Datas.arraySize++;
|
||||
@@ -73,25 +72,25 @@ namespace XCharts
|
||||
int num = listSize > 10 ? 10 : listSize;
|
||||
for (int i = 0; i < num; i++)
|
||||
{
|
||||
DrawSerieData(dimension, m_Datas, i, showName, showSelected);
|
||||
DrawSerieData(dimension, m_Datas, i, showName);
|
||||
}
|
||||
if (num >= 10)
|
||||
{
|
||||
ChartEditorHelper.DrawHeader("... ", false, false, null, null);
|
||||
DrawSerieData(dimension, m_Datas, listSize - 1, showName, showSelected);
|
||||
DrawSerieData(dimension, m_Datas, listSize - 1, showName);
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
for (int i = 0; i < m_Datas.arraySize; i++)
|
||||
{
|
||||
DrawSerieData(dimension, m_Datas, i, showName, showSelected);
|
||||
DrawSerieData(dimension, m_Datas, i, showName);
|
||||
}
|
||||
}
|
||||
EditorGUI.indentLevel--;
|
||||
}
|
||||
|
||||
private void DrawSerieData(int dimension, SerializedProperty m_Datas, int index, bool showName, bool showSelected)
|
||||
private void DrawSerieData(int dimension, SerializedProperty m_Datas, int index, bool showName)
|
||||
{
|
||||
bool flag;
|
||||
if (!m_DataElementFoldout.TryGetValue(index, out flag))
|
||||
@@ -112,8 +111,6 @@ namespace XCharts
|
||||
var lastLabelWid = EditorGUIUtility.labelWidth;
|
||||
var serieData = m_Datas.GetArrayElementAtIndex(index);
|
||||
var sereName = serieData.FindPropertyRelative("m_Name");
|
||||
var selected = serieData.FindPropertyRelative("m_Selected");
|
||||
|
||||
var data = serieData.FindPropertyRelative("m_Data");
|
||||
#if UNITY_2019_3_OR_NEWER
|
||||
var gap = 2;
|
||||
@@ -132,21 +129,9 @@ namespace XCharts
|
||||
}
|
||||
SerializedProperty element = data.GetArrayElementAtIndex(1);
|
||||
var startX = drawRect.x + EditorGUIUtility.labelWidth - EditorGUI.indentLevel * 15 + gap;
|
||||
if (showSelected)
|
||||
{
|
||||
drawRect.width = drawRect.width - 18;
|
||||
EditorGUI.PropertyField(drawRect, element, GUIContent.none);
|
||||
drawRect.x = currentWidth - 40;
|
||||
EditorGUI.PropertyField(drawRect, selected, GUIContent.none);
|
||||
drawRect.x = lastX;
|
||||
drawRect.width = lastWid;
|
||||
}
|
||||
else
|
||||
{
|
||||
drawRect.x = startX;
|
||||
drawRect.xMax = maxX;
|
||||
EditorGUI.PropertyField(drawRect, element, GUIContent.none);
|
||||
}
|
||||
drawRect.x = startX;
|
||||
drawRect.xMax = maxX;
|
||||
EditorGUI.PropertyField(drawRect, element, GUIContent.none);
|
||||
}
|
||||
else
|
||||
{
|
||||
|
||||
@@ -84,46 +84,20 @@ namespace XCharts
|
||||
{
|
||||
var editor = m_Editors[i];
|
||||
string title = editor.GetDisplayTitle();
|
||||
int id = i;
|
||||
var menus = new List<HeaderMenuInfo>();
|
||||
menus.Add(new HeaderMenuInfo("Remove", () => { RemoveSerieEditor(id); }));
|
||||
if (i < m_Editors.Count - 1)
|
||||
menus.Add(new HeaderMenuInfo("Move Down", () =>
|
||||
{
|
||||
if (chart.MoveDownSerie(id))
|
||||
{
|
||||
m_SeriesProperty = m_BaseEditor.RefreshSeries();
|
||||
RefreshEditors();
|
||||
}
|
||||
}));
|
||||
if (i > 0)
|
||||
menus.Add(new HeaderMenuInfo("Move Up", () =>
|
||||
{
|
||||
if (chart.MoveUpSerie(id))
|
||||
{
|
||||
m_SeriesProperty = m_BaseEditor.RefreshSeries();
|
||||
RefreshEditors();
|
||||
}
|
||||
}));
|
||||
bool displayContent = ChartEditorHelper.DrawHeader(
|
||||
title,
|
||||
editor.baseProperty,
|
||||
editor.showProperty,
|
||||
menus.ToArray());
|
||||
editor.menus.ToArray());
|
||||
if (displayContent)
|
||||
{
|
||||
editor.OnInternalInspectorGUI();
|
||||
}
|
||||
}
|
||||
if (m_Editors.Count > 0)
|
||||
{
|
||||
//EditorGUILayout.Space();
|
||||
}
|
||||
else
|
||||
if (m_Editors.Count <= 0)
|
||||
{
|
||||
EditorGUILayout.HelpBox("No serie.", MessageType.Info);
|
||||
}
|
||||
//EditorGUILayout.Space();
|
||||
}
|
||||
|
||||
void RefreshEditors()
|
||||
@@ -142,7 +116,7 @@ namespace XCharts
|
||||
|
||||
void CreateEditor(Serie serie, SerializedProperty property, int index = -1)
|
||||
{
|
||||
|
||||
var id = index >= 0 ? index : m_Editors.Count;
|
||||
var settingsType = serie.GetType();
|
||||
Type editorType;
|
||||
|
||||
@@ -150,6 +124,39 @@ namespace XCharts
|
||||
editorType = typeof(SerieBaseEditor);
|
||||
var editor = (SerieBaseEditor)Activator.CreateInstance(editorType);
|
||||
editor.Init(chart, serie, property, m_BaseEditor);
|
||||
editor.menus.Clear();
|
||||
editor.menus.Add(new HeaderMenuInfo("Clone", () =>
|
||||
{
|
||||
CloneSerie(editor.serie);
|
||||
}));
|
||||
editor.menus.Add(new HeaderMenuInfo("Remove", () =>
|
||||
{
|
||||
if (EditorUtility.DisplayDialog("", "Sure remove serie?", "Yes", "Cancel"))
|
||||
RemoveSerieEditor(id);
|
||||
}));
|
||||
editor.menus.Add(new HeaderMenuInfo("Move Down", () =>
|
||||
{
|
||||
if (chart.MoveDownSerie(id))
|
||||
{
|
||||
m_SeriesProperty = m_BaseEditor.RefreshSeries();
|
||||
RefreshEditors();
|
||||
}
|
||||
}));
|
||||
editor.menus.Add(new HeaderMenuInfo("Move Up", () =>
|
||||
{
|
||||
if (chart.MoveUpSerie(id))
|
||||
{
|
||||
m_SeriesProperty = m_BaseEditor.RefreshSeries();
|
||||
RefreshEditors();
|
||||
}
|
||||
}));
|
||||
foreach (var type in GetCovertToSerie(editor.serie.GetType()))
|
||||
{
|
||||
editor.menus.Add(new HeaderMenuInfo("Covert to " + type.Name, () =>
|
||||
{
|
||||
CovertSerie(editor.serie, type);
|
||||
}));
|
||||
}
|
||||
|
||||
if (index < 0)
|
||||
m_Editors.Add(editor);
|
||||
@@ -173,6 +180,21 @@ namespace XCharts
|
||||
AssetDatabase.Refresh();
|
||||
}
|
||||
|
||||
public void CovertSerie(Serie serie, Type type)
|
||||
{
|
||||
chart.CovertSerie(serie, type);
|
||||
m_SeriesProperty = m_BaseEditor.RefreshSeries();
|
||||
RefreshEditors();
|
||||
}
|
||||
|
||||
public void CloneSerie(Serie serie){
|
||||
var newSerie = serie.Clone();
|
||||
newSerie.serieName = chart.GenerateDefaultSerieName();
|
||||
chart.InsertSerie(newSerie);
|
||||
m_SeriesProperty = m_BaseEditor.RefreshSeries();
|
||||
RefreshEditors();
|
||||
}
|
||||
|
||||
private void RemoveSerieEditor(int id)
|
||||
{
|
||||
m_Editors[id].OnDisable();
|
||||
@@ -186,5 +208,23 @@ namespace XCharts
|
||||
AssetDatabase.SaveAssets();
|
||||
AssetDatabase.Refresh();
|
||||
}
|
||||
|
||||
private List<Type> GetCovertToSerie(Type serie)
|
||||
{
|
||||
var list = new List<Type>();
|
||||
var typeMap = RuntimeUtil.GetAllTypesDerivedFrom<Serie>();
|
||||
foreach (var kvp in typeMap)
|
||||
{
|
||||
var type = kvp;
|
||||
if (type.IsDefined(typeof(SerieConvertAttribute), false))
|
||||
{
|
||||
var attribute = type.GetAttribute<SerieConvertAttribute>();
|
||||
if (attribute != null && attribute.Contains(serie))
|
||||
list.Add(type);
|
||||
}
|
||||
}
|
||||
list.Sort((a, b) => { return a.Name.CompareTo(b.Name); });
|
||||
return list;
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -5,7 +5,9 @@
|
||||
/* */
|
||||
/************************************************/
|
||||
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Reflection;
|
||||
using System.Text;
|
||||
using UnityEngine;
|
||||
|
||||
@@ -721,5 +723,24 @@ namespace XCharts
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
public static T CloneSerie<T>(Serie serie) where T : Serie
|
||||
{
|
||||
var newSerie = Activator.CreateInstance<T>();
|
||||
SerieHelper.CopySerie(serie, newSerie);
|
||||
return newSerie;
|
||||
}
|
||||
|
||||
public static void CopySerie(Serie oldSerie, Serie newSerie)
|
||||
{
|
||||
var fields = typeof(Serie).GetFields(BindingFlags.Public | BindingFlags.NonPublic | BindingFlags.Instance);
|
||||
foreach (var field in fields)
|
||||
{
|
||||
if (field.IsDefined(typeof(SerializeField)))
|
||||
{
|
||||
field.SetValue(newSerie, field.GetValue(oldSerie));
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -9,6 +9,9 @@ using System;
|
||||
namespace XCharts
|
||||
{
|
||||
[AttributeUsage(AttributeTargets.Class, AllowMultiple = true)]
|
||||
/// <summary>
|
||||
/// What serie can convert to me
|
||||
/// </summary>
|
||||
public sealed class SerieConvertAttribute : Attribute
|
||||
{
|
||||
public readonly Type type0;
|
||||
@@ -39,9 +42,13 @@ namespace XCharts
|
||||
type3 = serie4;
|
||||
}
|
||||
|
||||
public bool Contains<T>() where T : CoordSystem
|
||||
public bool Contains<T>() where T : Serie
|
||||
{
|
||||
return Contains(typeof(T));
|
||||
}
|
||||
|
||||
public bool Contains(Type type)
|
||||
{
|
||||
var type = typeof(T);
|
||||
return (type == type0 || type == type1 || type == type2 || type == type3);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -8,6 +8,7 @@
|
||||
using UnityEngine;
|
||||
using System.Collections.Generic;
|
||||
using System;
|
||||
using System.Reflection;
|
||||
|
||||
namespace XCharts
|
||||
{
|
||||
@@ -28,6 +29,16 @@ namespace XCharts
|
||||
return InsertSerie(index, typeof(T), serieName, show) as T;
|
||||
}
|
||||
|
||||
public void InsertSerie(Serie serie, int index = -1, bool addToHead = false)
|
||||
{
|
||||
serie.AnimationRestart();
|
||||
if (addToHead) m_Series.Insert(0, serie);
|
||||
else if (index >= 0) m_Series.Insert(index, serie);
|
||||
else m_Series.Add(serie);
|
||||
ResetSeriesIndex();
|
||||
SeriesHelper.UpdateSerieNameList(this, ref m_LegendRealShowName);
|
||||
}
|
||||
|
||||
public bool MoveUpSerie(int serieIndex)
|
||||
{
|
||||
if (serieIndex < 0 || serieIndex > m_Series.Count - 1) return false;
|
||||
@@ -145,6 +156,46 @@ namespace XCharts
|
||||
RefreshChart();
|
||||
}
|
||||
|
||||
public bool CovertSerie<T>(Serie serie) where T : Serie
|
||||
{
|
||||
return CovertSerie(serie, typeof(T));
|
||||
}
|
||||
|
||||
public bool CovertSerie(Serie serie, Type type)
|
||||
{
|
||||
try
|
||||
{
|
||||
var newSerie = type.InvokeMember("CovertSerie",
|
||||
BindingFlags.InvokeMethod | BindingFlags.Static | BindingFlags.Public, null, null,
|
||||
new object[] { serie }) as Serie;
|
||||
return ReplaceSerie(serie, newSerie);
|
||||
}
|
||||
catch
|
||||
{
|
||||
Debug.LogError(string.Format("CovertSerie Failed: can't found {0}.CovertSerie(Serie serie)", type.Name));
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
public bool ReplaceSerie(Serie oldSerie, Serie newSerie)
|
||||
{
|
||||
if (oldSerie == null || newSerie == null)
|
||||
return false;
|
||||
|
||||
var index = m_Series.IndexOf(oldSerie);
|
||||
if (index < 0)
|
||||
return false;
|
||||
|
||||
oldSerie.OnRemove();
|
||||
m_Series.RemoveAt(index);
|
||||
m_Series.Insert(index, newSerie);
|
||||
ResetSeriesIndex();
|
||||
InitSerieHandlers();
|
||||
RefreshAllComponent();
|
||||
RefreshChart();
|
||||
return true;
|
||||
}
|
||||
|
||||
|
||||
/// <summary>
|
||||
/// Add a data to serie.
|
||||
@@ -786,15 +837,12 @@ namespace XCharts
|
||||
{
|
||||
serie.symbol.show = false;
|
||||
}
|
||||
serie.AnimationRestart();
|
||||
if (addToHead) m_Series.Insert(0, serie);
|
||||
else if (index >= 0) m_Series.Insert(index, serie);
|
||||
else m_Series.Add(serie);
|
||||
ResetSeriesIndex();
|
||||
SeriesHelper.UpdateSerieNameList(this, ref m_LegendRealShowName);
|
||||
InsertSerie(serie, index, addToHead);
|
||||
return serie;
|
||||
}
|
||||
|
||||
|
||||
|
||||
private void ResetSeriesIndex()
|
||||
{
|
||||
for (int i = 0; i < m_Series.Count; i++)
|
||||
|
||||
@@ -5,10 +5,15 @@
|
||||
/* */
|
||||
/************************************************/
|
||||
|
||||
using System;
|
||||
using System.Reflection;
|
||||
using UnityEngine;
|
||||
|
||||
namespace XCharts
|
||||
{
|
||||
[System.Serializable]
|
||||
[SerieHandler(typeof(BarHandler), true)]
|
||||
[SerieConvert(typeof(Line),typeof(Pie))]
|
||||
[RequireChartComponent(typeof(GridCoord))]
|
||||
public class Bar : Serie, INeedSerieContainer
|
||||
{
|
||||
@@ -23,5 +28,11 @@ namespace XCharts
|
||||
chart.AddData(serie.index, UnityEngine.Random.Range(10, 90));
|
||||
}
|
||||
}
|
||||
|
||||
public static Bar CovertSerie(Serie serie)
|
||||
{
|
||||
var newSerie = SerieHelper.CloneSerie<Bar>(serie);
|
||||
return newSerie;
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -12,7 +12,7 @@ namespace XCharts
|
||||
{
|
||||
[Serializable]
|
||||
[SerieHandler(typeof(LineHandler), true)]
|
||||
[SerieConvert(typeof(Bar))]
|
||||
[SerieConvert(typeof(Bar), typeof(Pie))]
|
||||
[CoordOptions(typeof(GridCoord), typeof(PolarCoord))]
|
||||
public class Line : Serie, INeedSerieContainer
|
||||
{
|
||||
@@ -29,5 +29,11 @@ namespace XCharts
|
||||
chart.AddData(serie.index, UnityEngine.Random.Range(10, 90));
|
||||
}
|
||||
}
|
||||
|
||||
public static Line CovertSerie(Serie serie)
|
||||
{
|
||||
var newSerie = serie.Clone<Line>();
|
||||
return newSerie;
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -177,6 +177,9 @@ namespace XCharts
|
||||
for (int i = 0; i < count; i++)
|
||||
{
|
||||
var serieData = serie.GetSerieData(i);
|
||||
if (serieData == null)
|
||||
continue;
|
||||
|
||||
var symbol = SerieHelper.GetSerieSymbol(serie, serieData);
|
||||
|
||||
if (!symbol.show || !symbol.ShowSymbol(i, count))
|
||||
|
||||
@@ -8,9 +8,12 @@
|
||||
namespace XCharts
|
||||
{
|
||||
[System.Serializable]
|
||||
[SerieConvert(typeof(Line), typeof(Bar))]
|
||||
[SerieHandler(typeof(PieHandler), true)]
|
||||
public class Pie : Serie
|
||||
{
|
||||
public override bool useDataNameForColor { get { return true; } }
|
||||
|
||||
public static void AddDefaultSerie(BaseChart chart, string serieName)
|
||||
{
|
||||
var serie = chart.AddSerie<Pie>(serieName);
|
||||
@@ -19,6 +22,10 @@ namespace XCharts
|
||||
chart.AddData(serie.index, 10, "pie3");
|
||||
}
|
||||
|
||||
public override bool useDataNameForColor { get { return true; } }
|
||||
public static Pie CovertSerie(Serie serie)
|
||||
{
|
||||
var newSerie = SerieHelper.CloneSerie<Pie>(serie);
|
||||
return newSerie;
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1757,5 +1757,19 @@ namespace XCharts
|
||||
{
|
||||
return index.CompareTo((obj as Serie).index);
|
||||
}
|
||||
|
||||
public T Clone<T>() where T : Serie
|
||||
{
|
||||
var newSerie = Activator.CreateInstance<T>();
|
||||
SerieHelper.CopySerie(this, newSerie);
|
||||
return newSerie;
|
||||
}
|
||||
|
||||
public Serie Clone()
|
||||
{
|
||||
var newSerie = Activator.CreateInstance(GetType()) as Serie;
|
||||
SerieHelper.CopySerie(this, newSerie);
|
||||
return newSerie;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user