You can pass the pie1, pie2,… values to respective dataPoints of the scatter chart and on displaying the tooltip, you can get the values for pie chart using e.entries[0].dataPoints
object. Please take a look at the code snippet below for the same.
.
.
toolTip: {
updated: function(e) {
typeof pieChart.destroy === "function" && pieChart.destroy();
pieChart = new CanvasJS.Chart('pie-chart', chartOptions);
pieChart.options.title.text = e.entries[0].dataPoint.name;
pieChart.options.data[0].dataPoints = [];
pieChart.options.data[0].dataPoints.push({y: e.entries[0].dataPoint.pie1});
pieChart.options.data[0].dataPoints.push({y: e.entries[0].dataPoint.pie2});
pieChart.options.data[0].dataPoints.push({y: e.entries[0].dataPoint.pie3});
pieChart.render();
},
contentFormatter: function() {
return "<div id='pie-chart' style='width:200px; height:200px;'></div>";
},
hidden: function() {
typeof pieChart.destroy === "function" && pieChart.destroy();
}
}
.
.
dataPoints: [
{ y: 219960, name: "First", pie1: 20, pie2: 30, pie3: 50},
{ y: 363040, name: "Second", pie1: 60, pie2: 20, pie3: 40}
]
.
.
Please take a look at this JSFiddle for complete working code.
—-
Manoj Mohan
Team CanvasJS
You can use unicode characters in labelFormatter to display power (subscript) values in the axis labels. Please check out the code snippet for the same.
var unicodeStringForSubscript = ["\u2070", "\u00B9", "\u00B2", "\u00B3", "\u2074", "\u2075", "\u2076", "\u2077", "\u2078", "\u2079"]
.
.
axisX:{
title: "Logarithmic Axis",
logarithmic: true,
logarithmBase: 10,
labelFormatter: function(e) {
return 10 + unicodeStringForSubscript[Math.ceil(Math.log(e.value)/Math.log(10))] ;
}
.
.
Also, take a look at this JSFiddle for a complete working code.
—-
Manoj Mohan
Team CanvasJS
I need to be able to get a charts.axisY2[0].bounds property calculated BEFORE I render it. How can I do that?
Sorry, it’s not possible to access bounds of the axis before rendering the chart. However after rendering it once, you get access to all the properties. Please refer to the Methods & Properties documentation for more info.
how can I use offscreenCanvas with my chart too?
offscreenCanvas is not supported in CanvasJS as of now.
—
Manoj Mohan
Team CanvasJS
Sorry, there is no official TypeScript type definition for CanvasJS as of now. However, this feature is there in our roadmap but no definite timeline yet as we are working on some other important features at this point in time.
You really shouldn’t include node_modules in zips like that.
Thanks for the suggestion. We have provided node_modules for the ease of the user to run the sample.
—-
Manoj Mohan
Team CanvasJS
To display a chart inside tooltip, you can create a DOM required for the chart within tooltip using contentFormatter and render the chart on updated event of toolTip. Please take a look at this below code snippet for the same.
toolTip: {
updated: function(e) {
typeof pieChart.destroy === "function" && pieChart.destroy();
pieChart = new CanvasJS.Chart('pie-chart', chartOptions[e.entries[0].dataPoint.label]);
pieChart.render();
},
contentFormatter: function() {
return "<div id='pie-chart' style='width:200px; height:200px;'></div>";
},
}
Also, check out this JSFiddle for complete sample code for rendering the chart within tooltip.
—-
Manoj Mohan
Team CanvasJS
Yes, you can use datetime in x-axis. In order to use datetime in x-axis, you need to first convert PHP date to timestamp using strtotime and then convert PHP timestamp to JavaScript timestamp by multiplying it with 1000.
$phpDate = date("Y-m-d h:i:sa");
$phpTimestamp = strtotime($phpDate);
$javaScriptTimestamp = $phpTimestamp * 1000;
You can refer to this thread for more information on using datetime on x-axis in PHP. Also, you can check out this gallery page for an example on using JavaScript timestamp in x-axis in PHP.
—-
Manoj Mohan
Team CanvasJS
One of our sales representative will get in touch with you over email. For any license related query, please contact sales@canvasjs.com.
—-
Manoj Mohan
Team CanvasJS
The use case you mentioned of indexLabel not being shown when y value is 0 was a bug and it has been fixed in the releases prior to 3.0. In order to hide indexlabel when y value is 0, you need to use indexLabelFormatter property.
So, can anyone please suggest global fix for it, to hide 0 0 0 0 from all charts of my website?
Sorry, as of now you cannot revert this behaviour globally. However, you can create a global function which takes chart object as parameter and set the indexLabelFormatter in the chart options and render it as shown in this code snippet.
addIndexLabelFormatterToChart(chart);
function hideIndexLabelOnZero(e) {
return e.dataPoint.y !== 0 ? e.dataPoint.label + " " + e.dataPoint.y + " " + "kg": "" ;
}
function addIndexLabelFormatterToChart(chart) {
chart.data[0].set("indexLabelFormatter", hideIndexLabelOnZero);
}
Also, check out this JSFiddle for complete working code.
—-
Manoj Mohan
Team CanvasJS
Neha,
We don’t support setting fontColor, fontSize and fontWeight for each individual legend items as of now.
—-
Manoj Mohan
Team CanvasJS
Neha Mahanjan,
Highlighting legend on hover over chart series is not available as an inbuilt as of now. However you can achieve this functionality by updating legendMarkerColor within mousemove & mouseout events of dataseries as shown in this below codesnippet
for(var i=0; i<chart.options.data.length; i++) {
chart.options.data[i].mouseover = highlightLegend;
chart.options.data[i].mouseout = dimLegend;
}
chart.render();
function highlightLegend(e) {
for(var i=0; i<e.chart.options.data.length; i++) {
if(i !== e.dataSeriesIndex)
e.chart.options.data[i].legendMarkerColor = "grey";
}
e.chart.render();
}
function dimLegend(e) {
for(var i=0; i<e.chart.options.data.length; i++) {
e.chart.options.data[i].legendMarkerColor = undefined;
}
e.chart.render();
}
Also, check out this JSFiddle for complete working code.
—
Manoj Mohan
Team CanvasJS
We are sorry for the inconvenience caused, we will address this issue in our future releases as currently we are working on some important features. However, if interactivity is not required in your use-case you can extract the image of chart, destroy the chart and use the image in place of chart. Please take a look at this JSFiddle for an example.
—-
Manoj Mohan
Team CanvasJS
Chart seems to be working fine across different browsers like Chrome, Safari, Edge, Firefox, etc.
In order to reproduce the issue at our end, can you kindly create a sample project and share it with us over Google-Drive or OneDrive along with sample data so that we can run it locally, understand the scenario better and help you out?
—-
Manoj Mohan
Team CanvasJS
You can set the interval of the axis based on your dataset to fix number of graduations of axis. Please check out this documentation page for more information on setting interval of axisX.
—-
Manoj Mohan
Team CanvasJS
Wolfgang,
It is not possible to show/position stripline label on the right side of the line as of now. However, you can place stripline label to near, far and center from axis line using labelAlign property.
—-
Manoj Mohan
Team CanvasJS
As of now, CanvasJS doesn’t have the option to add equations / technical indicators as an inbuilt feature. However, you can generate datapoints as per the equation & add a spline dataseries to the chart with few lines of code. Please take a look at this JSFiddle for an example on the same.
Also, you can check out this forum thread for more info on adding technical indicators (SMA & EMA).
—-
Manoj Mohan
Team CanvasJS