How can I use HighCharts SvgRenderer class in an angular 4 typescript project to render images inside a high chart?
Asked
Active
Viewed 1,010 times
2 Answers
0
Just like in regular Highcharts:
var chart = this.chart = Highcharts.chart(this.container.nativeElement, {
series: [{
data: [1,2,3,4,5]
}]
})
chart.renderer.image('https://www.highcharts.com/samples/graphics/sun.png', 100, 100, 30, 30)
.add();
Here's a live working example of using SVGRenderer
in Angular 4 project: http://plnkr.co/edit/tZIGkSXoogeCyUReARaP?p=preview

Kamil Kulig
- 5,756
- 1
- 8
- 12
0
Using angular2-highcharts you have to update chart-events
import { platformBrowserDynamic } from '@angular/platform-browser-dynamic';
import { NgModule, Component } from '@angular/core';
import { BrowserModule } from '@angular/platform-browser';
import { ChartModule } from 'angular2-highcharts';
@Component({
selector: 'my-app',
styles: [`
chart {
display: block;
}
`],
template: `<chart [options]="options" (load)="onChartload($event)"></chart>`
})
class AppComponent {
constructor() {
this.options = {
title : { text : 'simple chart' },
series: [{
data: [29.9, 71.5, 106.4, 129],
}]
};
}
options: Object;
onChartload (e) {
e.context.renderer.image('https://www.highcharts.com/samples/graphics/sun.png', 100, 100, 30, 30)
.add();
}
}
@NgModule({
imports: [BrowserModule, ChartModule.forRoot(require('highcharts'))],
declarations: [AppComponent],
bootstrap: [AppComponent]
})
class AppModule { }
platformBrowserDynamic().bootstrapModule(AppModule);
Plunker demo

Deep 3015
- 9,929
- 5
- 30
- 54