我有一些与每个数字关联的字符串标签。
我创建了一个Chart
元素,其中一个ChartArea
和一个Series
使用SeriesChartType.Bar
类型在x轴上显示我的标签(令人困惑的是使用Bar
类型(但无论如何...)时的垂直轴,并在旁边显示一个数字。
由于我有很多标签无法同时显示在屏幕上,因此我在Zoom
事件处理程序中使用Paint
方法“启用”了滚动条,如下所示:
private void chart1_Paint(object sender, PaintEventArgs e)
{
var scaleView = chart1.ChartAreas.First().AxisX.ScaleView;
var pos = double.IsNaN(scaleView.Position) ? 0.0 : scaleView.Position;
scaleView.Zoom(pos, pos + chart1.Height / 22.0);
}
我不知道这是否是正确的方法,但它(几乎)确实满足我的要求:
只有一件烦人的事情:如果由于滚动而使长标签出现在可见区域中或消失,则将标签占据的区域调整为最长可见标签。我希望这些屏幕截图可以解释我的意思:
这在滚动过程中非常烦人,因为只要长标签出现或消失,所有内容都会重新缩放。
如何固定标签占用的区域以始终适合系列中最长的标签,无论当前是否可见?我在x轴和y轴上都尝试了IsLabelAutoFit = false
,但这无济于事。
答案 0 :(得分:0)
好的,我知道了。我用过
chartArea.InnerPlotPosition.Auto = false;
InnerPlotPosition.X = 33.333;
将图表区域的三分之一分配给标签,将其他三分之二分配给条形图。
InnerPlotPosition.Auto = false
对此进行了修复,以使其在滚动时不会更新。