положение метки контрольного значения диаграммы asp.net - PullRequest
4 голосов
/ 10 ноября 2011

Я отображаю данные в элементе управления диаграммой asp.net. Используя 3D гистограмму. Я показываю значения рядом с барами. (seriesCount.IsValueShownAsLabel = true;). Элемент управления диаграммы отображает метку значения по-прежнему в верхней части панели и затрудняет чтение значения. Я пытаюсь расположить этот ярлык вправо, но пока не нашел способа сделать это. Я также пытался включить Smart label, надеясь и поместив маркер на планку, чтобы оттолкнуть значение, но у меня не получилось. Любые предложения приветствуются.

Пример кода:

Chart chartSubjects = new Chart();
chartSubjects.Width = Unit.Pixel(800);
chartSubjects.Height = Unit.Pixel(300);
chartSubjects.AntiAliasing = AntiAliasingStyles.All;

Series seriesCount = new Series("subjectsCountSeries");
seriesCount.YValueType = ChartValueType.Int32;
seriesCount.ChartType = SeriesChartType.Bar;
seriesCount.IsValueShownAsLabel = true;
seriesCount.ChartArea = "subjectsCountArea";
chartSubjects.Series.Add(seriesCount);

ChartArea areaCount = new ChartArea("subjectsCountArea");
LabelStyle yAxisStyle = new LabelStyle();
yAxisStyle.ForeColor = System.Drawing.ColorTranslator.FromHtml("#444444");
yAxisStyle.Font = new System.Drawing.Font("Arial", 11, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Pixel);
areaCount.AxisY.LabelStyle = yAxisStyle;
areaCount.AxisY.IsLabelAutoFit = false;
areaCount.Position.Width = 50;
areaCount.Position.Height = 100;
areaCount.Position.X = 0;
areaCount.Position.Y = 0;
areaCount.Area3DStyle.Enable3D = true;
areaCount.Area3DStyle.LightStyle = LightStyle.Realistic;
areaCount.Area3DStyle.WallWidth = 4;
areaCount.Area3DStyle.Inclination = 10;
areaCount.Area3DStyle.Perspective = 10;
areaCount.Area3DStyle.Rotation = 20;
areaCount.Area3DStyle.PointDepth = 90;
chartSubjects.ChartAreas.Add(areaCount);

int[] pointsToAdd = new int[] { 1434, 712, 601, 204, 173, 168, 64, 35, 22, 8, 2 };
foreach (int point in pointsToAdd)
{
    DataPoint dataPoint = new DataPoint();
    dataPoint.SetValueY(point);
    seriesCount.Points.Add(dataPoint);
}

enter image description here

Ответы [ 2 ]

2 голосов
/ 24 июля 2013

Это то, что вы ищете?

<asp:Series Name="Series1" ChartType="Bar" 
            CustomProperties="BarLabelStyle=Right" IsValueShownAsLabel="True" 
            Palette="EarthTones" XValueMember="xvalue" YValueMembers="yvalue">
</asp:Series>

CustomProperties="BarLabelStyle=Right" сделал это для меня.

0 голосов
/ 24 июля 2013

В вашем случае я бы использовал:

chartSubjects.Series["seriesCount"]["LabelStyle"] = "Right";
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...