チェックボックスをクリックした後にのみ(htmlがロードされたときではなく)、jqplotのオーバーレイでトリガーするにはどうすればよいですか。オーバーレイ オプションの表示を最初に false に設定すると、最初にオーバーレイがプロットに表示されず、トリガー関数を使用したときにオーバーレイが表示されません。プロットに使用するコードは次のとおりです。
<div id="fastest" style="margin-top:20px; margin-left:20px; margin-right:200px; width:800px; height:400px;">
<script class="code" type="text/javascript">
$(document).ready(function(){
var dataset="too long to be displayed here"
plot1 = $.jqplot('fastest', dataset, {
title: 'Test_figs',
legend: {show:false},
series: [{
showMarker: false,
color: '#ED0E0E',
label: 'R spectrum',
neighborThreshold: -1
}],
axes:{
xaxis:{
label:'Restframe Wavelength'
},
yaxis:{
label:'Flux',
tickOptions:{formatString:'%.3e'}
}
},
cursor:{
show:true,
zoom:true,
tooltipLocation:'sw'
},
Canvasoverlay: {
show: false,
objects: [
{verticalLine: {
name: 'Na-ID',
x: 5893.000000,
lineWidth: 2,
color: '#F0630C',
lineCap:'butt',
yOffset:0,
shadow: true
}}
]
}
});
});
function NaID_trigger() {
var co = plot1.plugins.canvasOverlay;
var line = co.get('Na-ID');
if (line.options.show==false) line.options.show = true;
else line.options.show = false;
co.draw(plot1);
}
</script>
次に使用します:
<button onclick="NaID_trigger()">Na-ID</button>
たとえば、オーバーレイのオンまたはオフをトリガーします。
PS: オーバーレイ オプションで show=false の場合、アドバイスどおりに描画を replot に置き換えようとしましたが、機能しませんでした。