i am trying to add the currency symbol to totalvalue by using following code
using System.Globalization;
double value;
double totalValue = 0.0;
foreach (DataRow row in reportData.Rows)
{
if (double.TryParse(row["value"].ToString(), out value))
{
totalValue += value;
RegionInfo rgi = new RegionInfo("en-UK");
totalValue += Convert.ToString(string.Format(" CurrencySymbol: {0}\n", rgi.CurrencySymbol));
}
}
it was giving error can not convert type string to double
would any one pls help me
Modified CODE:
int count;
int total = 0;
double value;
double totalValue = 0.0;
foreach (DataRow row in reportData.Rows)
{
if (double.TryParse(row["value"].ToString(), out value))
{
totalValue += value;
}
if (!Overview && int.TryParse(row["mshipssold"].ToString(), out count))
{
total += count;
}
}
DataRow totalRow = reportData.NewRow();
totalRow["mshipType_Name"] = "Total";
totalRow["mshipssold"] = total;
totalRow["value"] = totalValue;
reportData.Rows.Add(totalRow);
targetChartControl.Series["Value"].Points.DataBindXY(reportData.Rows, "mshipType_Name", reportData.Rows, "value");
if (!Overview)
{
targetChartControl.Series["Quantity"].Points.DataBindXY(reportData.Rows, "mshipType_Name", reportData.Rows, "mshipssold");
}
}
Modified code :1
graph
I want to show like this £3830 , £2070 , £5090 on the blue bars
and this is my code
try
{
DataTable reportData = KPIData.MembershipSales(StartDate, EndDate, mf);
Series quantitySeries;
Series valueSeries = null;
Title title;
string area;
targetChartControl.ChartAreas.Clear();
targetChartControl.Series.Clear();
targetChartControl.Titles.Clear();
area = "Value";
targetChartControl.ChartAreas.Add(area);
quantitySeries = targetChartControl.Series.Add(area);
quantitySeries.ChartArea = area;
if (!Overview)
{
title = targetChartControl.Titles.Add("Membership Sales by Total Contract Value by Type");
title.Font = new Font(FontFamily.GenericSansSerif, 10, FontStyle.Bold);
title.Alignment = ContentAlignment.TopLeft;
title.DockedToChartArea = area;
targetChartControl.Titles.Add("").DockedToChartArea = area;
}
targetChartControl.Titles.Add("Membership sale values").DockedToChartArea = area;
if (!Overview)
{
area = "Quantity";
targetChartControl.ChartAreas.Add(area);
quantitySeries = targetChartControl.Series.Add(area);
quantitySeries.ChartArea = area;
title = targetChartControl.Titles.Add("Membership Sales by Quantity");
title.Font = new Font(FontFamily.GenericSansSerif, 10, FontStyle.Bold);
title.Alignment = ContentAlignment.TopLeft;
title.DockedToChartArea = area;
targetChartControl.Titles.Add("").DockedToChartArea = area;
targetChartControl.Titles.Add("Membership sale quantities").DockedToChartArea = area;
}
foreach (Title chartTitle in targetChartControl.Titles)
{
chartTitle.IsDockedInsideChartArea = false;
}
foreach (ChartArea chartArea in targetChartControl.ChartAreas)
{
chartArea.Area3DStyle.Enable3D = true;
chartArea.AxisX.LabelStyle.IsEndLabelVisible = true;
}
foreach (Series series in targetChartControl.Series)
{
series.ChartType = SeriesChartType.StackedColumn;
series["ColumnDrawingStyle"] = "SoftEdge";
series["LabelStyle"] = "Top";
series.IsValueShownAsLabel = true;
// series.CustomProperties = "DrawingStyle=Cylinder";
series.BackGradientStyle = GradientStyle.DiagonalLeft;
}
foreach (Legend legend in targetChartControl.Legends)
{
legend.Enabled = false;
}
if (reportData == null)
{
valueSeries.Points.Clear();
valueSeries.Points.AddXY("No sales for this time period", 0);
if (!Overview)
{
quantitySeries.Points.Clear();
quantitySeries.Points.AddXY("No sales for this time period", 0);
}
}
else
{
int count;
int total = 0;
double value;
double totalValue = 0.0;
foreach (DataRow row in reportData.Rows)
{
if (double.TryParse(row["value"].ToString(), out value))
{
totalValue += value;
}
if (!Overview && int.TryParse(row["mshipssold"].ToString(), out count))
{
total += count;
}
}
CultureInfo rgi = new CultureInfo("en-GB");
string totalcurrency = string.Format(rgi, "{0:C}", totalValue);
DataRow totalRow = reportData.NewRow();
totalRow["mshipType_Name"] = "Total";
totalRow["mshipssold"] = total;
totalRow["value"] = totalcurrency;
reportData.Rows.Add(totalRow);
targetChartControl.Series["Value"].Points.DataBindXY(reportData.Rows, "mshipType_Name", reportData.Rows, "value");
if (!Overview)
{
targetChartControl.Series["Quantity"].Points.DataBindXY(reportData.Rows, "mshipType_Name", reportData.Rows, "mshipssold");
}
}
}
catch
{
}
You need to do your totalling and then convert it to a string.
In answer to your modified question:
before before
DataRow totalRow = reportData.NewRow();insert the two linesand then change
to read
However this might go horribly wrong if the datatype of your column is not string. You may be better of changing your report to do the formatting for you.
If you are using Microsoft Chart Control you may want this instead:
Modify this section of code