Skip to content

085_option_array_func

FVANCOP edited this page Dec 27, 2014 · 11 revisions

Previous Chapter          Previous Page          Next Page          Table of content

Array / Function parameter

Several options and datasets/data elements can now have an array or a function as value. This enhancement (introduced in ChartNew.js version 2) make possible the creation of more flexible charts.

This possibility has not been implemented for all options; It has only be implemented for options where it could be useful. If you have to implement it to an additional option, minor changes in the code of ChartNew.js are necessary.

Through an example (code in Samples/issue_205.html), you will understand how to use it !

If you have a stacked chart with two values on each stack ; the second value on the stack is small. If you want to get the values in the graph, you specify following options :

  var opts1= {
animation : false,
legend : true,
inGraphDataShow : true, 
datasetFill : false,
inGraphDataYPosition: 3,
inGraphDataVAlign: "top",
inGraphDataPaddingY: -3,
graphTitleFontSize: 18,
graphTitle : "With default value for inGraphData options" 
};  

graph1

As you can see, small values from the second values overlap the values of the first ones.

Array

Since version 2.0, you can now specify an array for several options among which inGraphDataYPosition, inGraphDataVAlign and inGraphDataPaddingY :

  var opts2= {
animation : false,
legend : true,
inGraphDataShow : true, 
datasetFill : false,
inGraphDataYPosition: [3,3],
inGraphDataVAlign: ["top","bottom"],
inGraphDataPaddingY: [-3,3],
graphTitle : "Solution 1" 
};  

graph2

Much better !

So when you are allowed to specify an array for an options, the first value of the array will be for the first dataset/data element; The second one will be for the second dataset/data element; etc...

If there are more datasets/data elements than entries in the array, the last entry will be used for the missing values.

If for a specific option, ChartNew.js is does not allow an array value, it should not be difficult to update the code in order to allow an array value. Just open an issue and ask it !

Function

Instead of defining an array, you can associate a function to an option. Using a function is much more flexible but ... you have to write the function yourself.

In previous sample, the bar under "25" is big enough to write the value inside the bar.

With following definitions, you can produce a graph where the value 25 is written inside the bar.

 function computeInGraphVAlign(area, ctx, data,statData, posi,posj,othervars) {
if(posi==1 && 1*data.datasets[posi].data[posj]<6) return("bottom");
else return("top");
 }

 function computeInGraphPaddingY(area, ctx, data,statData, posi,posj,othervars) {
if(posi==1 && 1*data.datasets[posi].data[posj]<6) return(3);
else return(-3);
 }

  var opts4= {
animation : false,
legend : true,
inGraphDataShow : true, 
datasetFill : false,
inGraphDataYPosition: 3,
inGraphDataVAlign: computeInGraphVAlign,
inGraphDataPaddingY: computeInGraphPaddingY,
inGraphDataTmpl: "<%=(v3 > 0 ? v3 : '')%>",
graphTitleFontSize: 18,
graphTitle : "Solution 3 - some options through a function" 
};  

graph3

A separate chapter describes how to write a function and the parameters passed to the function. see Option functions

Previous Chapter          Previous Page          Next Page          Top of Page

Clone this wiki locally