在WPF C#设计问题中绘制图表

我一个月前有一个项目,我在使用Windows Forms的应用程序中绘制了一个股票图表.我这样做是通过创建一个可以拉伸到窗口尺寸的位图.这将允许我的图表使用窗口调整大小.

我现在正在使用WPF扩展项目.我一直在努力为我的项目设计工作,但我似乎无法了解做同样图表的最佳方法.我看过画布,网格和其他一些控件.我以为我在画布的正确轨道上,但是当我调整窗口大小时,我的绘图将保持在同一个位置.我想我今晚发表的观点是为了帮助我为我的项目集思广益.

所有建议和问题都表示赞赏.

谢谢,
约瑟夫

解决方法:

(实现这个地址充其量只是这个相当古老的问题的一个子集,因为它只是一种图表类型…)

只需fwiw,在网格中创建条形图为Ed suggests非常简单.这是一个快速而又脏的版本:

将一个网格添加到Window的XAML中.只是为了测试,这里完全填满了Window.

<Grid>
    <Grid
        Name="myGrid"
        HorizontalAlignment="Stretch"
        VerticalAlignment="Stretch"
        Width="auto"
        Height="auto"
        Margin="10,10,10,10"
    />
</Grid>

现在在项目的某处插入这两个实用程序函数.它们为x轴提供简单的单色列和无样式但居中的标签文本.

我认为唯一令人讨厌的问题是_placeSingleColorColumn调用中的maxHeight.

Worth mentioning: I don’t have labels for the y-axis in this quick & dirty version.

private void _placeSingleColorColumn(Grid grid, Color color, int height, int colNum, int maxHeight)
{
    Brush brush = new SolidColorBrush(color);

    Rectangle rect = new Rectangle();
    rect.Fill = brush;
    Grid.SetColumn(rect, colNum);
    Grid.SetRow(rect, maxHeight - height);
    Grid.SetRowSpan(rect, height);

    grid.Children.Add(rect);
}

private void _createLabels(Grid grid, string[] labels)
{
    RowDefinition rowDefnLabels = new RowDefinition();
    grid.RowDefinitions.Add(rowDefnLabels);

    for (int i = 0; i < labels.Length; i++)
    {
        TextBlock block = new TextBlock();
        block.Text = labels[i];
        block.HorizontalAlignment = System.Windows.HorizontalAlignment.Center;
        Grid.SetColumn(block, i);
        Grid.SetRow(block, grid.RowDefinitions.Count);
        grid.Children.Add(block);
    }
}

真的是这样的.这里有一些疯狂的快速和脏的示例代码,用于创建带有一些示例数据的10 x 10网格.

public void createGrid10x10()
{
    Random random = new Random();

    for (int i=0; i<10; i++)
    {
        ColumnDefinition colDef = new ColumnDefinition();
        myGrid.ColumnDefinitions.Add(colDef);

        RowDefinition rowDef = new RowDefinition();
        myGrid.RowDefinitions.Add(rowDef);

        Color color = i % 2 == 0 ? Colors.Red : Colors.Blue;

        _placeSingleColorColumn(this.myGrid, color, random.Next(1,11), i, 10);
    }
    string[] aLabels = "Dogs,Cats,Birds,Snakes,Rabbits,Hamsters,Horses,Rats,Bats,Unicorns".Split(',');
    _createLabels(this.myGrid, aLabels);
}

在MainWindow构造函数中添加一行,然后就完成了.

public MainWindow()
{
    InitializeComponent();
    this.createGrid10x10();
}

现在你已经有了一个条形图,当窗口调整大小时,它会调整大小并保持比例.

如果您了解上述内容,添加更多标签(顶部的条形值,y轴标签等)应该非常简单.只需抛出另一列和/或行,创建TextBlock,然后将它们放在正确的位置.

上一篇:新手学C++/CLI及C#


下一篇:c# – Polygon找到从开始到结束的最短路径