Hi,
If I use a custom markerTemplate to modify the default size/appearance of markers, taking a scatter chart as an example, the legend for a multi series chart will not show a marker next to the legend entries? See here for a screenshot - http://sdrv.ms/VFmCQW
Can you tell me if this is a bug and if not then how I get the legend to show the correct marker. My JS code for generating the chart series is below:
chartSeries.push({ name: 'Series0', title: 'Series0', dataSource: FormatScatterData(data, ''), type: 'scatter', markerType: 'circle', markerTemplate: new CircleMarker(markerSize, markerThickness), brush: getBrush(seriesCount), markerBush: getBrush(seriesCount), xAxis: 'xAxis0', yAxis: 'yAxis0', xMemberPath: 'DataPoint2', yMemberPath: 'DataPoint1', showTooltip: false, thickness: 0 });
Many thanks,
Chris
Thank you Maya, handling the legend pass of the render method appropriately resolved the issue.
Hello newc1,
Thank you for the code snippet with the creating of the marker template. I’ve found out why this happens.
You seem to cancel the rendering of the marker in some cases:
…
if (!renderInfo.data || !renderInfo.data.item() || !renderInfo.data.actualItemBrush()) {
return;
}
Usually first the makers for the legend are created and they don’t have a related data item so: renderInfo.data.item() is null for them. So in this case you cancel the drawing of the markers for all items in your legend with this code. If you remove this check you should be able to see them.
Let me know if you have any questions.
Best Regards,
Maya Kirova
Developer Support Engineer
Infragistics, Inc.
http://es.infragistics.com/support
FYI - Here is the CircleMarker() function referenced above, which highlights the shape if it has been selected by the user:
function CircleMarker(size, thickness) { var markerSize = size; var markerThickness = thickness; this.measure = function(measureInfo) { measureInfo.width = markerSize; measureInfo.height = markerSize; }; this.render = function(renderInfo) { var ctx = renderInfo.context, x = renderInfo.xPosition, y = renderInfo.yPosition; if (!renderInfo.data || !renderInfo.data.item() || !renderInfo.data.actualItemBrush()) { return; } // Set style properties for bubble (fill + white outline) ctx.fillStyle = renderInfo.data.item().selected ? '#119eda' : renderInfo.data.actualItemBrush().fill(); ctx.strokeStyle = markerThickness > 0 ? '#fff' : 'transparent'; ctx.lineWidth = markerThickness; ctx.save(); // Draw the bubble using a filled arc ctx.beginPath(); ctx.arc(x, y, markerSize / 2, 0, 2.0 * Math.PI, false); ctx.fill(); ctx.stroke(); ctx.restore(); }; }
Hi Maya,
The chart series are being added at runtime (see code below where the chartSeries variable above is used to set the series property of the chart). We support a number of different chart types and visualisation options, which are all handled at runtime. The code above builds up the series for the chart prior to chart initialisation.
The issue, as mentioned above concerns the legend and the fact that with a custom marker template the legend entries do not show the correct marker next to them:
// Build the chart $('#single-analysis').igDataChart({ width: self.vars.paneWidth + 'px', height: analysisHeight + 'px', theme: 'metro', axes: chartDef.chartAxes, series: chartSeries, horizontalZoomable: true, verticalZoomable: true, showTooltips: false, windowResponse: 'immediate', crosshairVisibility: 'hidden', topMargin: 6, bottomMargin: 6, leftMargin: 6, rightMargin: 6, syncChannel: 'singleAnalysisChart', synchronizeVertically: true, syncrhonizeHorizontally: true, seriesMouseLeftButtonDown: function(evt, ui) { self.seriesMouseLeftButtonDown(evt, ui); } });
Hello newc1 ,
Thank you for posting in our forum.
Are you adding that series runtime or on the initial load?
If you’re adding an additional series runtime you would need to add it to the series using the series option. For example:
$("#chart").igDataChart("option", "series", [{
name: "series2",
dataSource: generateRandomData(),
type: "scatter",
xAxis: "xAxis",
yAxis: "yAxis",
xMemberPath: "Index",
yMemberPath: "Value1",
markerTemplate: {
render: function (renderInfo) {
}]);
This would add a new series to the current chart with the specified marker template.
I’ve attached a sample for your reference. Let me know if I’m missing anything from your scenario.