¿Puede hacer que el tamaño del texto dependa dinámicamente del tamaño de un cuadro en una etiqueta de mapa de árbol?
todo lo que puedo encontrar en los documentos es cómo codificarlo
https://echarts.apache.org/en/option.html#series-treemap.label.fontFamily
label: { fontSize: 16 }
La idea es que cuanto más pequeña sea la caja, más pequeña será la fuente.
Hay un par de maneras de lograr esto. Probablemente la mejor manera sería agregar una función labelLayout
a la serie. Hay un ejemplo en el repositorio de GitHub de eCharts aquí . Entonces, la serie en el ejemplo provisto terminaría luciendo así:
series: [ { name: 'Disk Usage', type: 'treemap', visibleMin: 300, label: { show: true, formatter: '{b}' }, labelLayout: function (params) { if (params.rect.width < 5 || params.rect.height < 5) { return { fontSize: 0 }; } return { fontSize: Math.min(Math.sqrt(params.rect.width * params.rect.height) / 10, 20) }; }, itemStyle: { borderColor: '#fff' }, levels: getLevelOption(), data: diskData } ]
alternativamente, puede modificar la label
y agregar un formatter
para que sea una función y que se canalice a través del formato rich
. En el ejemplo, envíe el objeto Parámetros y tomamos el valor del elemento raíz (Uso de disco general total del ejemplo proporcionado), luego encontramos una relación entre el valor actual y el valor total.
label: { show: true, formatter: function (params) { let totSize= params.treePathInfo[0].value; let size=(params.value/totSize)*100; if (size>8) { return `{l|${params.name}}` } if (size>2) { return `{m|${params.name}}` } return `{s|${params.name}}` }, rich: { l: { fontSize: 20, }, m: { fontSize: 15, }, s: { fontSize: 10, } }, },