Nevron .NET Vision Documentation
Panel Selector Tool

The panel selector tool is used to dynamically select the active panel, which then becomes the target of tools that require such panel (like trackball, data zoom, panning etc). In order to create a panel selector tool you need to create an instance of the NPanelSelectorTool class and add it to the control tools collection:

C#
Copy Code

NThinChartControl1.Controller.Tools.Add(new NPanelSelectorTool());

Visual Basic
Copy Code

NThinChartControl1.Controller.Tools.Add(new NPanelSelectorTool())

This tool is useful when you have multiple charts in a single control and want to give the user the ability to dynamically switch between them. The following code snippet creates two pie charts that can be rotated with the mouse - note that the code also intercepts the panel selector tool callback and provides some visual feedback of the currently selected chart.

C#
Copy Code

protected void Page_Load(object sender, EventArgs e)

{

if (!NThinChartControl1.Initialized)
{

// get the default chart
NThinChartControl1.Panels.Clear();

// create the first pie chart
NPieChart pieChart1 = CreatePieChart();
pieChart1.Location =
new NPointL(0, 0);
pieChart1.Size =
new NSizeL(new NLength(50, NRelativeUnit.ParentPercentage), new NLength(100, NRelativeUnit.ParentPercentage));
NThinChartControl1.Panels.Add(pieChart1);

// create the second pie chart
NPieChart pieChart2 = CreatePieChart();
pieChart2.Location =
new NPointL(new NLength(50, NRelativeUnit.ParentPercentage), new NLength(0));
pieChart2.Size =
new NSizeL(new NLength(50, NRelativeUnit.ParentPercentage), new NLength(100, NRelativeUnit.ParentPercentage));
NThinChartControl1.Panels.Add(pieChart2);

// apply style sheet
NStyleSheet styleSheet = NStyleSheet.CreatePredefinedStyleSheet(PredefinedStyleSheet.NevronMultiColor);
styleSheet.Apply(NThinChartControl1.Document);

// add panel selector and trackball tools
NPanelSelectorTool panelSelector = new NPanelSelectorTool();
panelSelector.ActivatePanelCallback =
new ActivatePanelCallback();
NThinChartControl1.Controller.Tools.Add(panelSelector);
NThinChartControl1.Controller.Tools.Add(
new NTrackballTool());

}

}

private NPieChart CreatePieChart()

{

NPieChart pieChart = new NPieChart();
pieChart.Enable3D =
true;
pieChart.Margins =
new NMarginsL(10, 10, 10, 10);
NPieSeries pieSeries = new NPieSeries();
pieSeries.DataLabelStyle.Visible =
false;
pieChart.Series.Add(pieSeries);
pieSeries.Values.Add(10);
pieSeries.Values.Add(20);
pieSeries.Values.Add(30);
return pieChart;

}

[Serializable]

class ActivatePanelCallback : INActivatePanelCallback

{

#region INActivatePanelCallback Members

void INActivatePanelCallback.OnActivatePanel(NThinChartControl control, NContentPanel newActivePanel, NContentPanel oldActivePanel)
{
// when the currently active panel changes, change its border to prompt the user
if (oldActivePanel != null)
{
oldActivePanel.BorderStyle =
null;
}
if (newActivePanel != null)
{

newActivePanel.BorderStyle = new NStrokeBorderStyle();
}

control.UpdateView();
}

#endregion
}
}

In some cases you may want to have only one active panel in the control regardless of whether you have multiple charts or not. In this case you can manually set the currently active panel trough code - for example:

C#
Copy Code

NThinChartControl1.Controller.SetActivePanel(NThinChartControl1.Charts[0]);

Visual Basic
Copy Code

NThinChartControl1.Controller.SetActivePanel(NThinChartControl1.Charts(0))

The code above sets the active panel to be the first chart in the control charts collection.

Related Examples
Web Forms\ThinWeb\Panel Selector Tool
Mvc\ThinWeb\Panel Selector Tool

 

 


©2017. Nevron Software LLC.

Send Feedback