mirror of
https://github.com/XCharts-Team/XCharts.git
synced 2026-05-23 17:30:10 +00:00
优化PieChart在数据全为0时的显示为等份的效果
This commit is contained in:
@@ -1,6 +1,7 @@
|
|||||||
|
|
||||||
# 更新日志
|
# 更新日志
|
||||||
|
|
||||||
|
* (2020.06.07) 优化`PieChart`在数据全为`0`时的显示为等份的效果
|
||||||
* (2020.06.04) 增加`SerieLabel`的`autoOffset`参数设置是否自动判断上下偏移
|
* (2020.06.04) 增加`SerieLabel`的`autoOffset`参数设置是否自动判断上下偏移
|
||||||
* (2020.06.04) 增加`Tooltip`的`alwayShow`参数设置触发后一直显示
|
* (2020.06.04) 增加`Tooltip`的`alwayShow`参数设置触发后一直显示
|
||||||
* (2020.06.04) 优化`Tooltip`的`formatter`支持`{.1}`通配符
|
* (2020.06.04) 优化`Tooltip`的`formatter`支持`{.1}`通配符
|
||||||
|
|||||||
@@ -1326,6 +1326,17 @@ namespace XCharts
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public float GetDataTotal(int dimension)
|
||||||
|
{
|
||||||
|
float total = 0;
|
||||||
|
foreach (var sdata in data)
|
||||||
|
{
|
||||||
|
if (sdata.show)
|
||||||
|
total += sdata.GetData(dimension);
|
||||||
|
}
|
||||||
|
return total;
|
||||||
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// 获得系列的数据列表
|
/// 获得系列的数据列表
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
|||||||
174
Assets/XCharts/Runtime/Helper/FormatterHelper.cs
Normal file
174
Assets/XCharts/Runtime/Helper/FormatterHelper.cs
Normal file
@@ -0,0 +1,174 @@
|
|||||||
|
/******************************************/
|
||||||
|
/* */
|
||||||
|
/* Copyright (c) 2018 monitor1394 */
|
||||||
|
/* https://github.com/monitor1394 */
|
||||||
|
/* */
|
||||||
|
/******************************************/
|
||||||
|
|
||||||
|
using System.Text;
|
||||||
|
using System.Text.RegularExpressions;
|
||||||
|
using UnityEngine;
|
||||||
|
using System.Linq;
|
||||||
|
|
||||||
|
namespace XCharts
|
||||||
|
{
|
||||||
|
public static class FormatterHelper
|
||||||
|
{
|
||||||
|
public const string PH_NN = "\n";
|
||||||
|
private static Regex s_Regex = new Regex(@"{([a-d|.]\d*)(:\d+(-\d+)?)?(:[c-g|x|p|r]\d*)?}", RegexOptions.IgnoreCase);
|
||||||
|
private static Regex s_RegexSub = new Regex(@"(\w?-?\d+)|(\w)|(\.)", RegexOptions.IgnoreCase);
|
||||||
|
private static Regex s_RegexN = new Regex(@"^\d+", RegexOptions.IgnoreCase);
|
||||||
|
private static Regex s_RegexN_N = new Regex(@"\d+-\d+", RegexOptions.IgnoreCase);
|
||||||
|
private static Regex s_RegexFn = new Regex(@"[c-g|x|p|r]\d*", RegexOptions.IgnoreCase);
|
||||||
|
private static Regex s_RegexNewLine = new Regex(@"[\\|/]+n", RegexOptions.IgnoreCase);
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// 替换字符串中的通配符,支持的通配符有{.}、{a}、{b}、{c}、{d}。
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="content">要替换的字符串</param>
|
||||||
|
/// <param name="dataIndex">选中的数据项serieData索引</param>
|
||||||
|
/// <param name="numericFormatter">默认的数字格式化</param>
|
||||||
|
/// <param name="serie">选中的serie</param>
|
||||||
|
/// <param name="series">所有serie</param>
|
||||||
|
/// <param name="themeInfo">用来获取指定index的颜色</param>
|
||||||
|
/// <param name="category">选中的类目,一般用在折线图和柱状图</param>
|
||||||
|
/// <param name="dataZoom">dataZoom</param>
|
||||||
|
/// <returns></returns>
|
||||||
|
public static bool ReplaceContent(ref string content, int dataIndex, string numericFormatter, Serie serie, Series series,
|
||||||
|
ThemeInfo themeInfo, string category = null, DataZoom dataZoom = null)
|
||||||
|
{
|
||||||
|
var foundDot = false;
|
||||||
|
var mc = s_Regex.Matches(content);
|
||||||
|
foreach (var m in mc)
|
||||||
|
{
|
||||||
|
var old = m.ToString();
|
||||||
|
var args = s_RegexSub.Matches(m.ToString());
|
||||||
|
var argsCount = args.Count;
|
||||||
|
if (argsCount <= 0) continue;
|
||||||
|
int targetIndex = 0;
|
||||||
|
char p = GetSerieIndex(args[0].ToString(), ref targetIndex);
|
||||||
|
if (serie == null)
|
||||||
|
{
|
||||||
|
if (targetIndex == -1) continue;
|
||||||
|
serie = series.GetSerie(targetIndex);
|
||||||
|
if (serie == null) continue;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
targetIndex = serie.index;
|
||||||
|
}
|
||||||
|
if (p == '.')
|
||||||
|
{
|
||||||
|
var bIndex = targetIndex;
|
||||||
|
if (argsCount >= 2)
|
||||||
|
{
|
||||||
|
var args1Str = args[1].ToString();
|
||||||
|
if (s_RegexN.IsMatch(args1Str)) bIndex = int.Parse(args1Str);
|
||||||
|
}
|
||||||
|
content = content.Replace(old, ChartCached.ColorToDotStr(themeInfo.GetColor(bIndex)));
|
||||||
|
foundDot = true;
|
||||||
|
}
|
||||||
|
else if (p == 'a' || p == 'A')
|
||||||
|
{
|
||||||
|
if (argsCount == 1)
|
||||||
|
{
|
||||||
|
content = content.Replace(old, serie.name);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (p == 'b' || p == 'B')
|
||||||
|
{
|
||||||
|
var bIndex = dataIndex;
|
||||||
|
if (argsCount >= 2)
|
||||||
|
{
|
||||||
|
var args1Str = args[1].ToString();
|
||||||
|
if (s_RegexN.IsMatch(args1Str)) bIndex = int.Parse(args1Str);
|
||||||
|
}
|
||||||
|
var needCategory = serie.type == SerieType.Line || serie.type == SerieType.Bar;
|
||||||
|
if (needCategory)
|
||||||
|
{
|
||||||
|
content = content.Replace(old, category);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
var serieData = serie.GetSerieData(bIndex, dataZoom);
|
||||||
|
content = content.Replace(old, serieData.name);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (p == 'c' || p == 'C' || p == 'd' || p == 'D')
|
||||||
|
{
|
||||||
|
var isPercent = p == 'd' || p == 'D';
|
||||||
|
var bIndex = dataIndex;
|
||||||
|
var dimensionIndex = -1;
|
||||||
|
if (argsCount >= 2)
|
||||||
|
{
|
||||||
|
var args1Str = args[1].ToString();
|
||||||
|
if (s_RegexFn.IsMatch(args1Str))
|
||||||
|
{
|
||||||
|
numericFormatter = args1Str;
|
||||||
|
}
|
||||||
|
else if (s_RegexN_N.IsMatch(args1Str))
|
||||||
|
{
|
||||||
|
var temp = args1Str.Split('-');
|
||||||
|
bIndex = int.Parse(temp[0]);
|
||||||
|
dimensionIndex = int.Parse(temp[1]);
|
||||||
|
}
|
||||||
|
else if (s_RegexN.IsMatch(args1Str))
|
||||||
|
{
|
||||||
|
dimensionIndex = int.Parse(args1Str);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Debug.LogError("unmatch:" + args1Str);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (argsCount >= 3)
|
||||||
|
{
|
||||||
|
numericFormatter = args[2].ToString();
|
||||||
|
}
|
||||||
|
if (dimensionIndex == -1) dimensionIndex = 1;
|
||||||
|
if (numericFormatter == string.Empty)
|
||||||
|
{
|
||||||
|
numericFormatter = SerieHelper.GetNumericFormatter(serie, serie.GetSerieData(bIndex));
|
||||||
|
}
|
||||||
|
var value = serie.GetData(bIndex, dimensionIndex, dataZoom);
|
||||||
|
if (isPercent)
|
||||||
|
{
|
||||||
|
var total = serie.GetDataTotal(dimensionIndex);
|
||||||
|
var percent = total == 0 ? 0 : value / serie.yTotal * 100;
|
||||||
|
content = content.Replace(old, ChartCached.FloatToStr(percent, numericFormatter));
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
content = content.Replace(old, ChartCached.FloatToStr(value, numericFormatter));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
content = s_RegexNewLine.Replace(content, PH_NN);
|
||||||
|
return foundDot;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static char GetSerieIndex(string strType, ref int index)
|
||||||
|
{
|
||||||
|
index = 0;
|
||||||
|
if (strType.Length > 1)
|
||||||
|
{
|
||||||
|
if (!int.TryParse(strType.Substring(1), out index))
|
||||||
|
{
|
||||||
|
index = -1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return strType.ElementAt(0);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static string TrimAndReplaceLine(StringBuilder sb)
|
||||||
|
{
|
||||||
|
return TrimAndReplaceLine(sb.ToString());
|
||||||
|
}
|
||||||
|
|
||||||
|
public static string TrimAndReplaceLine(string content)
|
||||||
|
{
|
||||||
|
return s_RegexNewLine.Replace(content.Trim(), PH_NN);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
11
Assets/XCharts/Runtime/Helper/FormatterHelper.cs.meta
Normal file
11
Assets/XCharts/Runtime/Helper/FormatterHelper.cs.meta
Normal file
@@ -0,0 +1,11 @@
|
|||||||
|
fileFormatVersion: 2
|
||||||
|
guid: 0fddcb81df44148ed86496564b120261
|
||||||
|
MonoImporter:
|
||||||
|
externalObjects: {}
|
||||||
|
serializedVersion: 2
|
||||||
|
defaultReferences: []
|
||||||
|
executionOrder: 0
|
||||||
|
icon: {instanceID: 0}
|
||||||
|
userData:
|
||||||
|
assetBundleName:
|
||||||
|
assetBundleVariant:
|
||||||
@@ -306,5 +306,21 @@ namespace XCharts
|
|||||||
serie.runtimeDataMin = ChartHelper.GetMinDivisibleValue(min, ceilRate);
|
serie.runtimeDataMin = ChartHelper.GetMinDivisibleValue(min, ceilRate);
|
||||||
serie.runtimeDataMax = ChartHelper.GetMaxDivisibleValue(max, ceilRate);
|
serie.runtimeDataMax = ChartHelper.GetMaxDivisibleValue(max, ceilRate);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static bool IsAllZeroValue(Serie serie, int dimension = 1)
|
||||||
|
{
|
||||||
|
foreach (var serieData in serie.data)
|
||||||
|
{
|
||||||
|
if (serieData.GetData(dimension) != 0) return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static string GetNumericFormatter(Serie serie, SerieData serieData)
|
||||||
|
{
|
||||||
|
var itemStyle = SerieHelper.GetItemStyle(serie, serieData);
|
||||||
|
if (!string.IsNullOrEmpty(itemStyle.numericFormatter)) return itemStyle.numericFormatter;
|
||||||
|
else return string.Empty;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -105,14 +105,11 @@ namespace XCharts
|
|||||||
content = content.Replace("{c:f0}", ChartCached.IntToStr((int)Mathf.Round(dataValue)));
|
content = content.Replace("{c:f0}", ChartCached.IntToStr((int)Mathf.Round(dataValue)));
|
||||||
content = content.Replace("{c:f1}", ChartCached.FloatToStr(dataValue, string.Empty, 1));
|
content = content.Replace("{c:f1}", ChartCached.FloatToStr(dataValue, string.Empty, 1));
|
||||||
content = content.Replace("{c:f2}", ChartCached.FloatToStr(dataValue, string.Empty, 2));
|
content = content.Replace("{c:f2}", ChartCached.FloatToStr(dataValue, string.Empty, 2));
|
||||||
if (dataTotal > 0)
|
var percent = dataValue == 0 && dataTotal == 0 ? 0 : dataValue / dataTotal * 100;
|
||||||
{
|
content = content.Replace("{d}", ChartCached.NumberToStr(percent, numericFormatter));
|
||||||
var percent = dataValue / dataTotal * 100;
|
content = content.Replace("{d:f0}", ChartCached.IntToStr((int)Mathf.Round(percent)));
|
||||||
content = content.Replace("{d}", ChartCached.NumberToStr(percent, numericFormatter));
|
content = content.Replace("{d:f1}", ChartCached.FloatToStr(percent, string.Empty, 1));
|
||||||
content = content.Replace("{d:f0}", ChartCached.IntToStr((int)Mathf.Round(percent)));
|
content = content.Replace("{d:f2}", ChartCached.FloatToStr(percent, string.Empty, 2));
|
||||||
content = content.Replace("{d:f1}", ChartCached.FloatToStr(percent, string.Empty, 1));
|
|
||||||
content = content.Replace("{d:f2}", ChartCached.FloatToStr(percent, string.Empty, 2));
|
|
||||||
}
|
|
||||||
content = content.Replace("\\n", "\n");
|
content = content.Replace("\\n", "\n");
|
||||||
content = content.Replace("<br/>", "\n");
|
content = content.Replace("<br/>", "\n");
|
||||||
return content;
|
return content;
|
||||||
|
|||||||
@@ -4,23 +4,14 @@
|
|||||||
/* https://github.com/monitor1394 */
|
/* https://github.com/monitor1394 */
|
||||||
/* */
|
/* */
|
||||||
/******************************************/
|
/******************************************/
|
||||||
|
|
||||||
using System.Text;
|
using System.Text;
|
||||||
using System.Text.RegularExpressions;
|
|
||||||
using UnityEngine;
|
using UnityEngine;
|
||||||
using System.Linq;
|
|
||||||
|
|
||||||
namespace XCharts
|
namespace XCharts
|
||||||
{
|
{
|
||||||
internal static class TooltipHelper
|
internal static class TooltipHelper
|
||||||
{
|
{
|
||||||
private const string PH_NN = "\n";
|
|
||||||
private static Regex s_Regex = new Regex(@"{([a-d|.]\d*)(:\d+(-\d+)?)?(:[c-g|x|p|r]\d*)?}", RegexOptions.IgnoreCase);
|
|
||||||
private static Regex s_RegexSub = new Regex(@"(\w?-?\d+)|(\w)|(\.)", RegexOptions.IgnoreCase);
|
|
||||||
private static Regex s_RegexN = new Regex(@"^\d+", RegexOptions.IgnoreCase);
|
|
||||||
private static Regex s_RegexN_N = new Regex(@"\d+-\d+", RegexOptions.IgnoreCase);
|
|
||||||
private static Regex s_RegexFn = new Regex(@"[c-g|x|p|r]\d*", RegexOptions.IgnoreCase);
|
|
||||||
private static Regex s_RegexNewLine = new Regex(@"[\\|/]+n", RegexOptions.IgnoreCase);
|
|
||||||
|
|
||||||
private static void InitScatterTooltip(ref StringBuilder sb, Tooltip tooltip, Serie serie, int index,
|
private static void InitScatterTooltip(ref StringBuilder sb, Tooltip tooltip, Serie serie, int index,
|
||||||
ThemeInfo themeInfo)
|
ThemeInfo themeInfo)
|
||||||
{
|
{
|
||||||
@@ -28,7 +19,7 @@ namespace XCharts
|
|||||||
var dataIndexList = tooltip.runtimeSerieDataIndex[serie.index];
|
var dataIndexList = tooltip.runtimeSerieDataIndex[serie.index];
|
||||||
if (!string.IsNullOrEmpty(serie.name))
|
if (!string.IsNullOrEmpty(serie.name))
|
||||||
{
|
{
|
||||||
sb.Append(serie.name).Append(PH_NN);
|
sb.Append(serie.name).Append(FormatterHelper.PH_NN);
|
||||||
}
|
}
|
||||||
for (int i = 0; i < dataIndexList.Count; i++)
|
for (int i = 0; i < dataIndexList.Count; i++)
|
||||||
{
|
{
|
||||||
@@ -62,7 +53,7 @@ namespace XCharts
|
|||||||
sb.Length = 0;
|
sb.Length = 0;
|
||||||
if (!string.IsNullOrEmpty(serie.name))
|
if (!string.IsNullOrEmpty(serie.name))
|
||||||
{
|
{
|
||||||
sb.Append(serie.name).Append(PH_NN);
|
sb.Append(serie.name).Append(FormatterHelper.PH_NN);
|
||||||
}
|
}
|
||||||
sb.Append("<color=#").Append(themeInfo.GetColorStr(index)).Append(">● </color>");
|
sb.Append("<color=#").Append(themeInfo.GetColorStr(index)).Append(">● </color>");
|
||||||
if (!string.IsNullOrEmpty(key))
|
if (!string.IsNullOrEmpty(key))
|
||||||
@@ -102,7 +93,7 @@ namespace XCharts
|
|||||||
{
|
{
|
||||||
string key = radar.indicatorList[i].name;
|
string key = radar.indicatorList[i].name;
|
||||||
float value = serieData.GetData(i);
|
float value = serieData.GetData(i);
|
||||||
if ((i == 0 && !string.IsNullOrEmpty(serieData.name)) || i > 0) sb.Append(PH_NN);
|
if ((i == 0 && !string.IsNullOrEmpty(serieData.name)) || i > 0) sb.Append(FormatterHelper.PH_NN);
|
||||||
sb.AppendFormat("{0}: {1}", key, ChartCached.FloatToStr(value, numericFormatter));
|
sb.AppendFormat("{0}: {1}", key, ChartCached.FloatToStr(value, numericFormatter));
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@@ -213,27 +204,27 @@ namespace XCharts
|
|||||||
var numericFormatter = GetItemNumericFormatter(tooltip, serie, null);
|
var numericFormatter = GetItemNumericFormatter(tooltip, serie, null);
|
||||||
if (string.IsNullOrEmpty(itemFormatter))
|
if (string.IsNullOrEmpty(itemFormatter))
|
||||||
{
|
{
|
||||||
if (!first) sb.Append(PH_NN);
|
if (!first) sb.Append(FormatterHelper.PH_NN);
|
||||||
InitDefaultContent(ref sb, tooltip, serie, dataIndex, category, themeInfo, dataZoom, isCartesian);
|
InitDefaultContent(ref sb, tooltip, serie, dataIndex, category, themeInfo, dataZoom);
|
||||||
first = false;
|
first = false;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
var itemTitle = title;
|
var itemTitle = title;
|
||||||
if (!string.IsNullOrEmpty(itemTitle))
|
if (!string.IsNullOrEmpty(itemTitle))
|
||||||
{
|
{
|
||||||
ReplaceContent(ref itemTitle, dataIndex, tooltip, serie, null, themeInfo, category, dataZoom, isCartesian);
|
FormatterHelper.ReplaceContent(ref itemTitle, dataIndex, tooltip.numericFormatter, serie, null, themeInfo, category, dataZoom);
|
||||||
sb.Append(itemTitle).Append(PH_NN);
|
sb.Append(itemTitle).Append(FormatterHelper.PH_NN);
|
||||||
}
|
}
|
||||||
var dataIndexList = tooltip.runtimeSerieDataIndex[serie.index];
|
var dataIndexList = tooltip.runtimeSerieDataIndex[serie.index];
|
||||||
foreach (var tempIndex in dataIndexList)
|
foreach (var tempIndex in dataIndexList)
|
||||||
{
|
{
|
||||||
string content = itemFormatter;
|
string content = itemFormatter;
|
||||||
var foundDot = ReplaceContent(ref content, tempIndex, tooltip, serie, null, themeInfo, category, dataZoom, isCartesian);
|
var foundDot = FormatterHelper.ReplaceContent(ref content, tempIndex, tooltip.numericFormatter, serie, null, themeInfo, category, dataZoom);
|
||||||
if (!foundDot)
|
if (!foundDot)
|
||||||
{
|
{
|
||||||
sb.Append(ChartCached.ColorToDotStr(themeInfo.GetColor(serie.index)));
|
sb.Append(ChartCached.ColorToDotStr(themeInfo.GetColor(serie.index)));
|
||||||
}
|
}
|
||||||
sb.Append(content).Append(PH_NN);
|
sb.Append(content).Append(FormatterHelper.PH_NN);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -245,20 +236,20 @@ namespace XCharts
|
|||||||
needCategory = needCategory || (serie.type == SerieType.Line || serie.type == SerieType.Bar);
|
needCategory = needCategory || (serie.type == SerieType.Line || serie.type == SerieType.Bar);
|
||||||
if (formatTitle)
|
if (formatTitle)
|
||||||
{
|
{
|
||||||
ReplaceContent(ref title, dataIndex, tooltip, null, series, themeInfo, category, dataZoom, isCartesian);
|
FormatterHelper.ReplaceContent(ref title, dataIndex, tooltip.numericFormatter, null, series, themeInfo, category, dataZoom);
|
||||||
}
|
}
|
||||||
if (serie.show)
|
if (serie.show)
|
||||||
{
|
{
|
||||||
if (string.IsNullOrEmpty(itemFormatter))
|
if (string.IsNullOrEmpty(itemFormatter))
|
||||||
{
|
{
|
||||||
if (!first) sb.Append(PH_NN);
|
if (!first) sb.Append(FormatterHelper.PH_NN);
|
||||||
InitDefaultContent(ref sb, tooltip, serie, dataIndex, category, themeInfo, dataZoom, isCartesian);
|
InitDefaultContent(ref sb, tooltip, serie, dataIndex, category, themeInfo, dataZoom);
|
||||||
first = false;
|
first = false;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
string content = itemFormatter;
|
string content = itemFormatter;
|
||||||
ReplaceContent(ref content, dataIndex, tooltip, serie, null, themeInfo, category, dataZoom, isCartesian);
|
FormatterHelper.ReplaceContent(ref content, dataIndex, tooltip.numericFormatter, serie, null, themeInfo, category, dataZoom);
|
||||||
if (!first) sb.Append(PH_NN);
|
if (!first) sb.Append(FormatterHelper.PH_NN);
|
||||||
sb.Append(ChartCached.ColorToDotStr(themeInfo.GetColor(i)));
|
sb.Append(ChartCached.ColorToDotStr(themeInfo.GetColor(i)));
|
||||||
sb.Append(content);
|
sb.Append(content);
|
||||||
first = false;
|
first = false;
|
||||||
@@ -267,159 +258,27 @@ namespace XCharts
|
|||||||
}
|
}
|
||||||
if (isScatter)
|
if (isScatter)
|
||||||
{
|
{
|
||||||
return TrimAndReplaceLine(sb);
|
return FormatterHelper.TrimAndReplaceLine(sb);
|
||||||
}
|
}
|
||||||
else if (string.IsNullOrEmpty(title))
|
else if (string.IsNullOrEmpty(title))
|
||||||
{
|
{
|
||||||
if (needCategory) return category + PH_NN + TrimAndReplaceLine(sb);
|
if (needCategory) return category + FormatterHelper.PH_NN + FormatterHelper.TrimAndReplaceLine(sb);
|
||||||
else return TrimAndReplaceLine(sb);
|
else return FormatterHelper.TrimAndReplaceLine(sb);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
title = s_RegexNewLine.Replace(title, PH_NN);
|
title = FormatterHelper.TrimAndReplaceLine(title);
|
||||||
return title + PH_NN + TrimAndReplaceLine(sb);
|
return title + FormatterHelper.PH_NN + FormatterHelper.TrimAndReplaceLine(sb);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
string content = tooltip.formatter;
|
string content = tooltip.formatter;
|
||||||
ReplaceContent(ref content, dataIndex, tooltip, null, series, themeInfo, category, dataZoom, isCartesian);
|
FormatterHelper.ReplaceContent(ref content, dataIndex, tooltip.numericFormatter, null, series, themeInfo, category, dataZoom);
|
||||||
return content;
|
return content;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static bool ReplaceContent(ref string content, int dataIndex, Tooltip tooltip, Serie serie, Series series,
|
|
||||||
ThemeInfo themeInfo, string category = null, DataZoom dataZoom = null, bool isCartesian = false)
|
|
||||||
{
|
|
||||||
var foundDot = false;
|
|
||||||
var mc = s_Regex.Matches(content);
|
|
||||||
foreach (var m in mc)
|
|
||||||
{
|
|
||||||
var old = m.ToString();
|
|
||||||
var args = s_RegexSub.Matches(m.ToString());
|
|
||||||
var argsCount = args.Count;
|
|
||||||
if (argsCount <= 0) continue;
|
|
||||||
int targetIndex = 0;
|
|
||||||
char p = GetSerieIndex(args[0].ToString(), ref targetIndex);
|
|
||||||
if (serie == null)
|
|
||||||
{
|
|
||||||
if (targetIndex == -1) continue;
|
|
||||||
serie = series.GetSerie(targetIndex);
|
|
||||||
if (serie == null) continue;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
targetIndex = serie.index;
|
|
||||||
}
|
|
||||||
if (p == '.')
|
|
||||||
{
|
|
||||||
var bIndex = targetIndex;
|
|
||||||
if (argsCount >= 2)
|
|
||||||
{
|
|
||||||
var args1Str = args[1].ToString();
|
|
||||||
if (s_RegexN.IsMatch(args1Str)) bIndex = int.Parse(args1Str);
|
|
||||||
}
|
|
||||||
content = content.Replace(old, ChartCached.ColorToDotStr(themeInfo.GetColor(bIndex)));
|
|
||||||
foundDot = true;
|
|
||||||
}
|
|
||||||
else if (p == 'a' || p == 'A')
|
|
||||||
{
|
|
||||||
if (argsCount == 1)
|
|
||||||
{
|
|
||||||
content = content.Replace(old, serie.name);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else if (p == 'b' || p == 'B')
|
|
||||||
{
|
|
||||||
var bIndex = dataIndex;
|
|
||||||
if (argsCount >= 2)
|
|
||||||
{
|
|
||||||
var args1Str = args[1].ToString();
|
|
||||||
if (s_RegexN.IsMatch(args1Str)) bIndex = int.Parse(args1Str);
|
|
||||||
}
|
|
||||||
var needCategory = serie.type == SerieType.Line || serie.type == SerieType.Bar;
|
|
||||||
if (needCategory)
|
|
||||||
{
|
|
||||||
content = content.Replace(old, category);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
var serieData = serie.GetSerieData(bIndex, dataZoom);
|
|
||||||
content = content.Replace(old, serieData.name);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else if (p == 'c' || p == 'C' || p == 'd' || p == 'D')
|
|
||||||
{
|
|
||||||
var isPercent = p == 'd' || p == 'D';
|
|
||||||
var bIndex = dataIndex;
|
|
||||||
var dimensionIndex = -1;
|
|
||||||
var numericFormatter = string.Empty;
|
|
||||||
if (argsCount >= 2)
|
|
||||||
{
|
|
||||||
var args1Str = args[1].ToString();
|
|
||||||
if (s_RegexFn.IsMatch(args1Str))
|
|
||||||
{
|
|
||||||
numericFormatter = args1Str;
|
|
||||||
}
|
|
||||||
else if (s_RegexN_N.IsMatch(args1Str))
|
|
||||||
{
|
|
||||||
var temp = args1Str.Split('-');
|
|
||||||
bIndex = int.Parse(temp[0]);
|
|
||||||
dimensionIndex = int.Parse(temp[1]);
|
|
||||||
}
|
|
||||||
else if (s_RegexN.IsMatch(args1Str))
|
|
||||||
{
|
|
||||||
dimensionIndex = int.Parse(args1Str);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
Debug.LogError("unmatch:" + args1Str);
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (argsCount >= 3)
|
|
||||||
{
|
|
||||||
numericFormatter = args[2].ToString();
|
|
||||||
}
|
|
||||||
if (dimensionIndex == -1) dimensionIndex = 1;
|
|
||||||
if (numericFormatter == string.Empty)
|
|
||||||
{
|
|
||||||
numericFormatter = GetItemNumericFormatter(tooltip, serie, serie.GetSerieData(bIndex));
|
|
||||||
}
|
|
||||||
var value = serie.GetData(bIndex, dimensionIndex, dataZoom);
|
|
||||||
if (isPercent)
|
|
||||||
{
|
|
||||||
var percent = value / serie.yTotal * 100;
|
|
||||||
content = content.Replace(old, ChartCached.FloatToStr(percent, numericFormatter));
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
content = content.Replace(old, ChartCached.FloatToStr(value, numericFormatter));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
content = s_RegexNewLine.Replace(content, PH_NN);
|
|
||||||
return foundDot;
|
|
||||||
}
|
|
||||||
|
|
||||||
private static char GetSerieIndex(string strType, ref int index)
|
|
||||||
{
|
|
||||||
index = 0;
|
|
||||||
if (strType.Length > 1)
|
|
||||||
{
|
|
||||||
if (!int.TryParse(strType.Substring(1), out index))
|
|
||||||
{
|
|
||||||
index = -1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return strType.ElementAt(0);
|
|
||||||
}
|
|
||||||
|
|
||||||
private static string TrimAndReplaceLine(StringBuilder sb)
|
|
||||||
{
|
|
||||||
return s_RegexNewLine.Replace(sb.ToString().Trim(), PH_NN);
|
|
||||||
}
|
|
||||||
|
|
||||||
private static bool IsSelectedSerie(Tooltip tooltip, int serieIndex)
|
private static bool IsSelectedSerie(Tooltip tooltip, int serieIndex)
|
||||||
{
|
{
|
||||||
if (tooltip.runtimeSerieDataIndex.ContainsKey(serieIndex))
|
if (tooltip.runtimeSerieDataIndex.ContainsKey(serieIndex))
|
||||||
|
|||||||
@@ -79,12 +79,19 @@ namespace XCharts
|
|||||||
}
|
}
|
||||||
bool dataChanging = false;
|
bool dataChanging = false;
|
||||||
float dataChangeDuration = serie.animation.GetUpdateAnimationDuration();
|
float dataChangeDuration = serie.animation.GetUpdateAnimationDuration();
|
||||||
|
bool isAllZeroValue = SerieHelper.IsAllZeroValue(serie, 1);
|
||||||
|
float zeroReplaceValue = 360f / data.Count;
|
||||||
|
if (isAllZeroValue)
|
||||||
|
{
|
||||||
|
serie.runtimeDataMax = zeroReplaceValue;
|
||||||
|
serie.runtimePieDataTotal = 360f;
|
||||||
|
}
|
||||||
for (int n = 0; n < data.Count; n++)
|
for (int n = 0; n < data.Count; n++)
|
||||||
{
|
{
|
||||||
var serieData = data[n];
|
var serieData = data[n];
|
||||||
var itemStyle = SerieHelper.GetItemStyle(serie, serieData, serieData.highlighted);
|
var itemStyle = SerieHelper.GetItemStyle(serie, serieData, serieData.highlighted);
|
||||||
serieData.index = n;
|
serieData.index = n;
|
||||||
float value = serieData.GetCurrData(1, dataChangeDuration);
|
float value = isAllZeroValue ? zeroReplaceValue : serieData.GetCurrData(1, dataChangeDuration);
|
||||||
if (serieData.IsDataChanged()) dataChanging = true;
|
if (serieData.IsDataChanged()) dataChanging = true;
|
||||||
serieNameCount = m_LegendRealShowName.IndexOf(serieData.legendName);
|
serieNameCount = m_LegendRealShowName.IndexOf(serieData.legendName);
|
||||||
var color = SerieHelper.GetItemColor(serie, serieData, m_ThemeInfo, serieNameCount, serieData.highlighted);
|
var color = SerieHelper.GetItemColor(serie, serieData, m_ThemeInfo, serieNameCount, serieData.highlighted);
|
||||||
@@ -152,7 +159,7 @@ namespace XCharts
|
|||||||
serieData.runtimePieOutsideRadius, color, toColor, Color.clear, startDegree, drawEndDegree,
|
serieData.runtimePieOutsideRadius, color, toColor, Color.clear, startDegree, drawEndDegree,
|
||||||
borderWidth, borderColor, serie.pieSpace / 2, m_Settings.cicleSmoothness, needRoundCap, serie.clockwise);
|
borderWidth, borderColor, serie.pieSpace / 2, m_Settings.cicleSmoothness, needRoundCap, serie.clockwise);
|
||||||
}
|
}
|
||||||
else //if(n==0)
|
else
|
||||||
{
|
{
|
||||||
var drawEndDegree = serieData.runtimePieCurrAngle;
|
var drawEndDegree = serieData.runtimePieCurrAngle;
|
||||||
var needRoundCap = serie.roundCap && serieData.runtimePieInsideRadius > 0;
|
var needRoundCap = serie.roundCap && serieData.runtimePieInsideRadius > 0;
|
||||||
@@ -331,14 +338,6 @@ namespace XCharts
|
|||||||
if (!serie.show) continue;
|
if (!serie.show) continue;
|
||||||
var data = serie.data;
|
var data = serie.data;
|
||||||
|
|
||||||
int showdataCount = 0;
|
|
||||||
if (serie.pieRoseType == RoseType.Area)
|
|
||||||
{
|
|
||||||
foreach (var sd in serie.data)
|
|
||||||
{
|
|
||||||
if (sd.show) showdataCount++;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
for (int n = 0; n < data.Count; n++)
|
for (int n = 0; n < data.Count; n++)
|
||||||
{
|
{
|
||||||
var serieData = data[n];
|
var serieData = data[n];
|
||||||
|
|||||||
Reference in New Issue
Block a user