mirror of
https://github.com/XCharts-Team/XCharts.git
synced 2026-05-28 03:58:49 +00:00
3.0 - serie clone and covert
This commit is contained in:
@@ -252,10 +252,8 @@ namespace XCharts
|
|||||||
foreach (var kvp in typeMap)
|
foreach (var kvp in typeMap)
|
||||||
{
|
{
|
||||||
var type = kvp;
|
var type = kvp;
|
||||||
if (RuntimeUtil.HasSubclass(type))
|
if (type.IsDefined(typeof(SerieHandlerAttribute), false))
|
||||||
continue;
|
list.Add(type);
|
||||||
|
|
||||||
list.Add(type);
|
|
||||||
}
|
}
|
||||||
list.Sort((a, b) => { return a.Name.CompareTo(b.Name); });
|
list.Sort((a, b) => { return a.Name.CompareTo(b.Name); });
|
||||||
return list;
|
return list;
|
||||||
|
|||||||
@@ -21,6 +21,7 @@ namespace XCharts
|
|||||||
//Editor m_Inspector;
|
//Editor m_Inspector;
|
||||||
internal SerializedProperty baseProperty;
|
internal SerializedProperty baseProperty;
|
||||||
internal SerializedProperty showProperty;
|
internal SerializedProperty showProperty;
|
||||||
|
internal List<HeaderMenuInfo> menus = new List<HeaderMenuInfo>();
|
||||||
protected Dictionary<string, Type> m_CoordOptionsDic;
|
protected Dictionary<string, Type> m_CoordOptionsDic;
|
||||||
protected List<string> m_CoordOptionsNames;
|
protected List<string> m_CoordOptionsNames;
|
||||||
|
|
||||||
|
|||||||
@@ -62,7 +62,6 @@ namespace XCharts
|
|||||||
if (m_DataDimension.intValue < 1) m_DataDimension.intValue = 1;
|
if (m_DataDimension.intValue < 1) m_DataDimension.intValue = 1;
|
||||||
int dimension = m_DataDimension.intValue;
|
int dimension = m_DataDimension.intValue;
|
||||||
bool showName = m_ShowDataName.boolValue;
|
bool showName = m_ShowDataName.boolValue;
|
||||||
bool showSelected = serie is Pie;
|
|
||||||
if (listSize != m_Datas.arraySize)
|
if (listSize != m_Datas.arraySize)
|
||||||
{
|
{
|
||||||
while (listSize > m_Datas.arraySize) m_Datas.arraySize++;
|
while (listSize > m_Datas.arraySize) m_Datas.arraySize++;
|
||||||
@@ -73,25 +72,25 @@ namespace XCharts
|
|||||||
int num = listSize > 10 ? 10 : listSize;
|
int num = listSize > 10 ? 10 : listSize;
|
||||||
for (int i = 0; i < num; i++)
|
for (int i = 0; i < num; i++)
|
||||||
{
|
{
|
||||||
DrawSerieData(dimension, m_Datas, i, showName, showSelected);
|
DrawSerieData(dimension, m_Datas, i, showName);
|
||||||
}
|
}
|
||||||
if (num >= 10)
|
if (num >= 10)
|
||||||
{
|
{
|
||||||
ChartEditorHelper.DrawHeader("... ", false, false, null, null);
|
ChartEditorHelper.DrawHeader("... ", false, false, null, null);
|
||||||
DrawSerieData(dimension, m_Datas, listSize - 1, showName, showSelected);
|
DrawSerieData(dimension, m_Datas, listSize - 1, showName);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
for (int i = 0; i < m_Datas.arraySize; i++)
|
for (int i = 0; i < m_Datas.arraySize; i++)
|
||||||
{
|
{
|
||||||
DrawSerieData(dimension, m_Datas, i, showName, showSelected);
|
DrawSerieData(dimension, m_Datas, i, showName);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
EditorGUI.indentLevel--;
|
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;
|
bool flag;
|
||||||
if (!m_DataElementFoldout.TryGetValue(index, out flag))
|
if (!m_DataElementFoldout.TryGetValue(index, out flag))
|
||||||
@@ -112,8 +111,6 @@ namespace XCharts
|
|||||||
var lastLabelWid = EditorGUIUtility.labelWidth;
|
var lastLabelWid = EditorGUIUtility.labelWidth;
|
||||||
var serieData = m_Datas.GetArrayElementAtIndex(index);
|
var serieData = m_Datas.GetArrayElementAtIndex(index);
|
||||||
var sereName = serieData.FindPropertyRelative("m_Name");
|
var sereName = serieData.FindPropertyRelative("m_Name");
|
||||||
var selected = serieData.FindPropertyRelative("m_Selected");
|
|
||||||
|
|
||||||
var data = serieData.FindPropertyRelative("m_Data");
|
var data = serieData.FindPropertyRelative("m_Data");
|
||||||
#if UNITY_2019_3_OR_NEWER
|
#if UNITY_2019_3_OR_NEWER
|
||||||
var gap = 2;
|
var gap = 2;
|
||||||
@@ -132,21 +129,9 @@ namespace XCharts
|
|||||||
}
|
}
|
||||||
SerializedProperty element = data.GetArrayElementAtIndex(1);
|
SerializedProperty element = data.GetArrayElementAtIndex(1);
|
||||||
var startX = drawRect.x + EditorGUIUtility.labelWidth - EditorGUI.indentLevel * 15 + gap;
|
var startX = drawRect.x + EditorGUIUtility.labelWidth - EditorGUI.indentLevel * 15 + gap;
|
||||||
if (showSelected)
|
drawRect.x = startX;
|
||||||
{
|
drawRect.xMax = maxX;
|
||||||
drawRect.width = drawRect.width - 18;
|
EditorGUI.PropertyField(drawRect, element, GUIContent.none);
|
||||||
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);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -84,46 +84,20 @@ namespace XCharts
|
|||||||
{
|
{
|
||||||
var editor = m_Editors[i];
|
var editor = m_Editors[i];
|
||||||
string title = editor.GetDisplayTitle();
|
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(
|
bool displayContent = ChartEditorHelper.DrawHeader(
|
||||||
title,
|
title,
|
||||||
editor.baseProperty,
|
editor.baseProperty,
|
||||||
editor.showProperty,
|
editor.showProperty,
|
||||||
menus.ToArray());
|
editor.menus.ToArray());
|
||||||
if (displayContent)
|
if (displayContent)
|
||||||
{
|
{
|
||||||
editor.OnInternalInspectorGUI();
|
editor.OnInternalInspectorGUI();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (m_Editors.Count > 0)
|
if (m_Editors.Count <= 0)
|
||||||
{
|
|
||||||
//EditorGUILayout.Space();
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
{
|
||||||
EditorGUILayout.HelpBox("No serie.", MessageType.Info);
|
EditorGUILayout.HelpBox("No serie.", MessageType.Info);
|
||||||
}
|
}
|
||||||
//EditorGUILayout.Space();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void RefreshEditors()
|
void RefreshEditors()
|
||||||
@@ -142,7 +116,7 @@ namespace XCharts
|
|||||||
|
|
||||||
void CreateEditor(Serie serie, SerializedProperty property, int index = -1)
|
void CreateEditor(Serie serie, SerializedProperty property, int index = -1)
|
||||||
{
|
{
|
||||||
|
var id = index >= 0 ? index : m_Editors.Count;
|
||||||
var settingsType = serie.GetType();
|
var settingsType = serie.GetType();
|
||||||
Type editorType;
|
Type editorType;
|
||||||
|
|
||||||
@@ -150,6 +124,39 @@ namespace XCharts
|
|||||||
editorType = typeof(SerieBaseEditor);
|
editorType = typeof(SerieBaseEditor);
|
||||||
var editor = (SerieBaseEditor)Activator.CreateInstance(editorType);
|
var editor = (SerieBaseEditor)Activator.CreateInstance(editorType);
|
||||||
editor.Init(chart, serie, property, m_BaseEditor);
|
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)
|
if (index < 0)
|
||||||
m_Editors.Add(editor);
|
m_Editors.Add(editor);
|
||||||
@@ -173,6 +180,21 @@ namespace XCharts
|
|||||||
AssetDatabase.Refresh();
|
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)
|
private void RemoveSerieEditor(int id)
|
||||||
{
|
{
|
||||||
m_Editors[id].OnDisable();
|
m_Editors[id].OnDisable();
|
||||||
@@ -186,5 +208,23 @@ namespace XCharts
|
|||||||
AssetDatabase.SaveAssets();
|
AssetDatabase.SaveAssets();
|
||||||
AssetDatabase.Refresh();
|
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.Collections.Generic;
|
||||||
|
using System.Reflection;
|
||||||
using System.Text;
|
using System.Text;
|
||||||
using UnityEngine;
|
using UnityEngine;
|
||||||
|
|
||||||
@@ -721,5 +723,24 @@ namespace XCharts
|
|||||||
break;
|
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
|
namespace XCharts
|
||||||
{
|
{
|
||||||
[AttributeUsage(AttributeTargets.Class, AllowMultiple = true)]
|
[AttributeUsage(AttributeTargets.Class, AllowMultiple = true)]
|
||||||
|
/// <summary>
|
||||||
|
/// What serie can convert to me
|
||||||
|
/// </summary>
|
||||||
public sealed class SerieConvertAttribute : Attribute
|
public sealed class SerieConvertAttribute : Attribute
|
||||||
{
|
{
|
||||||
public readonly Type type0;
|
public readonly Type type0;
|
||||||
@@ -39,9 +42,13 @@ namespace XCharts
|
|||||||
type3 = serie4;
|
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);
|
return (type == type0 || type == type1 || type == type2 || type == type3);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -8,6 +8,7 @@
|
|||||||
using UnityEngine;
|
using UnityEngine;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System;
|
using System;
|
||||||
|
using System.Reflection;
|
||||||
|
|
||||||
namespace XCharts
|
namespace XCharts
|
||||||
{
|
{
|
||||||
@@ -28,6 +29,16 @@ namespace XCharts
|
|||||||
return InsertSerie(index, typeof(T), serieName, show) as T;
|
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)
|
public bool MoveUpSerie(int serieIndex)
|
||||||
{
|
{
|
||||||
if (serieIndex < 0 || serieIndex > m_Series.Count - 1) return false;
|
if (serieIndex < 0 || serieIndex > m_Series.Count - 1) return false;
|
||||||
@@ -145,6 +156,46 @@ namespace XCharts
|
|||||||
RefreshChart();
|
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>
|
/// <summary>
|
||||||
/// Add a data to serie.
|
/// Add a data to serie.
|
||||||
@@ -786,15 +837,12 @@ namespace XCharts
|
|||||||
{
|
{
|
||||||
serie.symbol.show = false;
|
serie.symbol.show = false;
|
||||||
}
|
}
|
||||||
serie.AnimationRestart();
|
InsertSerie(serie, index, addToHead);
|
||||||
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);
|
|
||||||
return serie;
|
return serie;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
private void ResetSeriesIndex()
|
private void ResetSeriesIndex()
|
||||||
{
|
{
|
||||||
for (int i = 0; i < m_Series.Count; i++)
|
for (int i = 0; i < m_Series.Count; i++)
|
||||||
|
|||||||
@@ -5,10 +5,15 @@
|
|||||||
/* */
|
/* */
|
||||||
/************************************************/
|
/************************************************/
|
||||||
|
|
||||||
|
using System;
|
||||||
|
using System.Reflection;
|
||||||
|
using UnityEngine;
|
||||||
|
|
||||||
namespace XCharts
|
namespace XCharts
|
||||||
{
|
{
|
||||||
[System.Serializable]
|
[System.Serializable]
|
||||||
[SerieHandler(typeof(BarHandler), true)]
|
[SerieHandler(typeof(BarHandler), true)]
|
||||||
|
[SerieConvert(typeof(Line),typeof(Pie))]
|
||||||
[RequireChartComponent(typeof(GridCoord))]
|
[RequireChartComponent(typeof(GridCoord))]
|
||||||
public class Bar : Serie, INeedSerieContainer
|
public class Bar : Serie, INeedSerieContainer
|
||||||
{
|
{
|
||||||
@@ -23,5 +28,11 @@ namespace XCharts
|
|||||||
chart.AddData(serie.index, UnityEngine.Random.Range(10, 90));
|
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]
|
[Serializable]
|
||||||
[SerieHandler(typeof(LineHandler), true)]
|
[SerieHandler(typeof(LineHandler), true)]
|
||||||
[SerieConvert(typeof(Bar))]
|
[SerieConvert(typeof(Bar), typeof(Pie))]
|
||||||
[CoordOptions(typeof(GridCoord), typeof(PolarCoord))]
|
[CoordOptions(typeof(GridCoord), typeof(PolarCoord))]
|
||||||
public class Line : Serie, INeedSerieContainer
|
public class Line : Serie, INeedSerieContainer
|
||||||
{
|
{
|
||||||
@@ -29,5 +29,11 @@ namespace XCharts
|
|||||||
chart.AddData(serie.index, UnityEngine.Random.Range(10, 90));
|
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++)
|
for (int i = 0; i < count; i++)
|
||||||
{
|
{
|
||||||
var serieData = serie.GetSerieData(i);
|
var serieData = serie.GetSerieData(i);
|
||||||
|
if (serieData == null)
|
||||||
|
continue;
|
||||||
|
|
||||||
var symbol = SerieHelper.GetSerieSymbol(serie, serieData);
|
var symbol = SerieHelper.GetSerieSymbol(serie, serieData);
|
||||||
|
|
||||||
if (!symbol.show || !symbol.ShowSymbol(i, count))
|
if (!symbol.show || !symbol.ShowSymbol(i, count))
|
||||||
|
|||||||
@@ -8,9 +8,12 @@
|
|||||||
namespace XCharts
|
namespace XCharts
|
||||||
{
|
{
|
||||||
[System.Serializable]
|
[System.Serializable]
|
||||||
|
[SerieConvert(typeof(Line), typeof(Bar))]
|
||||||
[SerieHandler(typeof(PieHandler), true)]
|
[SerieHandler(typeof(PieHandler), true)]
|
||||||
public class Pie : Serie
|
public class Pie : Serie
|
||||||
{
|
{
|
||||||
|
public override bool useDataNameForColor { get { return true; } }
|
||||||
|
|
||||||
public static void AddDefaultSerie(BaseChart chart, string serieName)
|
public static void AddDefaultSerie(BaseChart chart, string serieName)
|
||||||
{
|
{
|
||||||
var serie = chart.AddSerie<Pie>(serieName);
|
var serie = chart.AddSerie<Pie>(serieName);
|
||||||
@@ -19,6 +22,10 @@ namespace XCharts
|
|||||||
chart.AddData(serie.index, 10, "pie3");
|
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);
|
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