Example shows Angular Stacked Column 100% Chart with indexlabels for all the datapoints.
/* app.component.ts */ import { Component } from '@angular/core'; import { CommonModule } from '@angular/common'; import { RouterOutlet } from '@angular/router'; import { CanvasJSAngularChartsModule } from '@canvasjs/angular-charts'; @Component({ selector: 'app-root', standalone: true, imports: [CommonModule, RouterOutlet, CanvasJSAngularChartsModule], templateUrl: './app.component.html', styleUrls: ['./app.component.css'] }) export class AppComponent { chartOptions = { animationEnabled: true, exportEnabled: true, title:{ text: "Number of Students in Each Room" }, axisX:{ title: "Rooms" }, axisY:{ title: "Percentage" }, toolTip: { shared: true }, legend: { horizontalAlign: "right", verticalAlign: "center", reversed: true }, data: [{ type: "stackedColumn100", name: "Boys", showInLegend: "true", indexLabel: "#percent %", indexLabelPlacement: "inside", indexLabelFontColor: "white", dataPoints: [ { y: 45, label: "Cafeteria"}, { y: 24, label: "Lounge" }, { y: 68, label: "Games Room" }, { y: 24, label: "Lecture Hall" }, { y: 15, label: "Library"} ] }, { type: "stackedColumn100", name: "Girls", showInLegend: "true", indexLabel: "#percent %", indexLabelPlacement: "inside", indexLabelFontColor: "white", dataPoints: [ { y: 22, label: "Cafeteria"}, { y: 17, label: "Lounge" }, { y: 32, label: "Games Room" }, { y: 48, label: "Lecture Hall" }, { y: 25, label: "Library"} ] }] } }
/* app.component.html */ <div> <canvasjs-chart [options]="chartOptions" [styles]="{width: '100%', height:'360px'}"></canvasjs-chart> </div>
In the above example legends are placed to right of the plot-are using verticalAlign and horizontalAlign properties. Shared tooltip is a useful feature in stacked charts.