I Have a function that I would like to run multiple time to reduce the overhaul processing of the function :
function ModifyVAxisChartThreading(){
var nbChart=39;
i++;
for(var j=i;j<nbChart;j+=4)
{
Vmax=rangeMax[j*6];
Vmin=rangeMinId[j*6];
id=rangeMinId[(j*6)+1];
var delta=(Vmax-Vmin)*0.1;
Logger.log("Vmax="+Vmax+"Vmin="+Vmin+"id="+id+"i="+j);
var currChart = chart[id];
if(currChart.getType()!="COLUMN")
{
Vmin-=delta
Vmax=Number(Vmax)+(delta*1.5)//Number() function to avoid Vmax becoming a string for no reason
}
Logger.log("Vmax="+Vmax+"Vmin="+Vmin+"id="+id+"j="+j);
currChart = currChart.modify()
.setOption('vAxes', {0: {textStyle: {fontSize: 10}, titleTextStyle: {fontSize : 8}, viewWindow: {min: Vmin, max:Vmax}}})//adpative vaxis for AREA and COMBO
.build();
sheet.updateChart(currChart);
}
}
I already made a function test()
that create two triggers but the triggers only run the function ModifyVAxisChartThreading()
with the same base value of i (0).
function test(){
//delete all previous trigger
var allTriggers = ScriptApp.getProjectTriggers();
for (var i = 0; i < allTriggers.length; i++) {
ScriptApp.deleteTrigger(allTriggers[i]);
}
i=-1;
var ss=SpreadsheetApp.getActiveSpreadsheet().getSheetByName("Dashboard Data");
var sheet = SpreadsheetApp.getActiveSpreadsheet().getSheetByName("Dashboard");
rangeMax =ss.getRange("O3:O231").getValues();//Range to modify if you add charts
rangeMinId=ss.getRange("P3:P232").getValues();//Range to modify if you add charts
chart = sheet.getCharts();
var nbChart=19;
Logger.log("range Max ="+rangeMax + "autre="+rangeMinId);
//create the trigger to run the function ModifyVAxisChartThreading in parallel
for(var j=0;j<4;j++)
{
Utilities.sleep(1000);
var testTrigger =ScriptApp.newTrigger("ModifyVAxisChartThreading")
.timeBased()
.after((1) * 60 * 1000)
.create();
Logger.log(testTrigger.getUniqueId());
}
}
Here is my global variable :
var sheet = SpreadsheetApp.getActiveSpreadsheet().getSheetByName("Dashboard");
var ss=SpreadsheetApp.getActiveSpreadsheet().getSheetByName("Dashboard Data");
var rangeMax =ss.getRange("O3:O231").getValues();//Range to modify if you add charts
var rangeMinId=ss.getRange("P3:P232").getValues();//Range to modify if you add charts
var i=-1;
var chart = sheet.getCharts();
Alright so I found the solution to run multiple thread for my function. Here it is :
The code to pass the parameters is greatly inspired by the code in this link :How can I pass a parameter to a time-based Google App Script trigger?