用于自定义图例的 Angular ngx-charts 选项?

标签 angular legend ngx-charts

我目前正在为 Angular2 使用 ngx-charts,我想自定义一些图例,例如将图例放在图表下方,或重命名图例字段,或使图例更宽(部分文本被截断......)等。

有什么好的选项可以自定义图例吗?或者这通常是不可能的,或者最好的方法是什么? 目前,我的图表图例如下所示:

enter image description here

有些图例太宽,有些被截断了,我想将图例放在例如图表下方...

最佳答案

图例位置

要将图例放置在图表下方,您可以使用 legendPosition 输入:

<ngx-charts-chart [legendPosition]="'below'" [results]="chartData" [legend]="true"></ngx-charts-chart>

legendPosition 的唯一选项是“right”(默认)和“below”。

重命名图例字段

似乎没有自定义图例字段的选项(高级饼图中有一个更可自定义的图例,但您的示例是其他类型的图表。)我认为最好的解决方法是传递字段标题将完全按照您希望它们出现在图例中的方式添加到您的 chartData 的 chartData[i].name 值中,然后自定义您的工具提示以在此处显示不同的字段名称。

This answer gives an overview of how to customize tooltips.从那里,我将一个带有折线图的示例放在一起,它看起来像默认的工具提示,只是字段名称不同:

<ngx-charts-line-chart [legendPosition]="'right'" [results]="chartData" [legend]="true">
    <ng-template #tooltipTemplate let-model="model">
        <xhtml:div class="area-tooltip-container">
            <span class="tooltip-label">{{ formatFieldName(model.series) }} • {{ formatXvalue(model.name) }}</span>
            <span class="tooltip-val">{{ formatYvalue(model.value) }}</span>
        </xhtml:div>
    </ng-template>
    <ng-template #seriesTooltipTemplate let-model="model">
        <xhtml:div class="area-tooltip-container">
            <xhtml:div *ngFor="let tooltipItem of model" class="tooltip-item">
                <span class="tooltip-item-color" [style.background-color]="tooltipItem.color">
                </span>
                {{ formatFieldName(tooltipItem.series) }}: {{ formatYvalue(tooltipItem.value) }}
            </xhtml:div>
        </xhtml:div>
    </ng-template>
</ngx-charts-line-chart>

改变图例宽度

图例宽度在其他图表扩展的 ngx-charts-chart 组件中计算。它会将宽度设置为图表容器的大约 1/6 或 1/12,具体取决于您的数据类型。无法为此图例输入不同的宽度,因此最简单的解决方案是在自动宽度对您不起作用时将 legendPosition 设置为“下方”。

但是,您不需要使用图表中内置的图例!这是一个更复杂(但更可微调)的替代方案:在图表中设置 [legend]="false",然后添加一个新的 ngx-charts-legend 图表外的组件。

您可以将宽度和高度输入到这个外部图例中,或者将其包装在一个 div 中以更灵敏地处理大小调整。使用后一种方法时,我必须将图例的宽度设置为其容器的 100%。

要使此解决方案正常运行,您必须将外部图例激活事件绑定(bind)到图表,并在 Init 上设置一些图例输入属性。在包含图表的组件中,您需要这样的东西:

import { ColorHelper } from '@swimlane/ngx-charts';
...
export class ChartContainerComponent implements OnInit {
    public activeEntries: any[];
    public chartData: { name: string, series: { name: string, value?: string | number }[] }[];
    public chartNames: string[];
    public colors: ColorHelper;
    public colorScheme = { domain: ['#0000FF', '#008000'] }; // Custom color scheme in hex

    public legendLabelActivate(item: any): void {
        this.activeEntries = [item];
    }

    public legendLabelDeactivate(item: any): void {
        this.activeEntries = [];
    }

    public ngOnInit(): void {
        // Get chartNames
        this.chartNames = this.chartData.map((d: any) => d.name);
        // Convert hex colors to ColorHelper for consumption by legend
        this.colors = new ColorHelper(this.colorScheme, 'ordinal', this.chartNames, this.colorScheme);
    }

然后我的模板(图表和图例各占一半宽度)如下所示:

<div fxLayout="row">
    <div fxFlex="50%">
        <ngx-charts-line-chart [legend]="false" [activeEntries]="activeEntries" [results]="chartData" [scheme]="colorScheme"></ngx-charts-line-chart>
    </div>
    <div fxFlex="50%">
        <ngx-charts-legend fxFlex="100%" class="chart-legend" [data]="chartNames" [title]="'Legend Title'" [colors]="colors" (labelActivate)="legendLabelActivate($event)" (labelDeactivate)="legendLabelDeactivate($event)"></ngx-charts-legend>
    </div>
</div>

关于用于自定义图例的 Angular ngx-charts 选项?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51946802/

相关文章:

javascript - 我可以在不需要 [formGroup] 的情况下使用 [formControl] 吗?

R - 平滑颜色并向散点图添加图例

matlab - 如何在MATLAB中改变图例的显示格式

angular - 如何防止用户多次提交表单? Angular

angular - 如何设置和获取angular2-localstorage?

Javascript/jQuery 图例小部件

angular - 隐藏 ngx 高级饼图图例

javascript - 图表不反射(reflect)事件条目,除非我在标记中将其设置为 array.slice() - 这将禁用选择点 - Stackblitz inside

Angular 12 - 不可分配给类型 '[number, number]

angular - 以 Angular 2 隐藏父 View