ChartType

ChartType enumeration

Anger typen av ett diagram.

public enum ChartType

Värderingar

namnVärdeBeskrivning
Area0Ytdiagram.
AreaStacked1Stacked area diagram.
AreaPercentStacked2100 % staplade ytdiagram.
Area3D33D Ytdiagram.
Area3DStacked43D Stacked Area diagram.
Area3DPercentStacked53D 100 % staplade områdesdiagram.
Bar6Stapeldiagram.
BarStacked7Staplade stapeldiagram.
BarPercentStacked8100 % staplat stapeldiagram.
Bar3D93D stapeldiagram.
Bar3DStacked103D staplade stapeldiagram.
Bar3DPercentStacked113D 100 % staplade stapeldiagram.
Bubble12Bubbeldiagram.
Bubble3D133D bubbeldiagram.
Column14Kolumndiagram.
ColumnStacked15Staplade kolumndiagram.
ColumnPercentStacked16100 % staplade kolumndiagram.
Column3D173D-kolumndiagram.
Column3DStacked183D staplade kolumndiagram.
Column3DPercentStacked193D 100 % staplade kolumndiagram.
Column3DClustered203D-klustrade kolumndiagram.
Doughnut21Donut diagram.
Line22Linjediagram.
LineStacked23Staplade linjediagram.
LinePercentStacked24100 % staplade linjediagram.
Line3D253D-linjediagram.
Pie26Cirkeldiagram.
Pie3D273D-cirkeldiagram.
PieOfBar28Stapeldiagram.
PieOfPie29Cirkeldiagram.
Radar30Radardiagram.
Scatter31Spridningsdiagram.
Stock32Aktiediagram.
Surface33Ytdiagram.
Surface3D343D Ytdiagram.

Exempel

Visar hur man skapar en lämplig typ av diagramserie för en graftyp.

public void ChartSeriesCollection()
{
    Document doc = new Document();
    DocumentBuilder builder = new DocumentBuilder(doc);

    // Det finns flera sätt att fylla i ett diagrams seriesamling.
    // Olika seriescheman är avsedda för olika diagramtyper.
    // 1 - Kolumndiagram med kolumner grupperade och bandade längs X-axeln efter kategori:
    Chart chart = AppendChart(builder, ChartType.Column, 500, 300);

    string[] categories = { "Category 1", "Category 2", "Category 3" };

    // Infoga två serier av decimalvärden som innehåller ett värde för varje respektive kategori.
    // Detta kolumndiagram kommer att ha tre grupper, var och en med två kolumner.
    chart.Series.Add("Series 1", categories, new [] { 76.6, 82.1, 91.6 });
    chart.Series.Add("Series 2", categories, new [] { 64.2, 79.5, 94.0 });

    // Kategorier är fördelade längs X-axeln, och värden är fördelade längs Y-axeln.
    Assert.AreEqual(ChartAxisType.Category, chart.AxisX.Type);
    Assert.AreEqual(ChartAxisType.Value, chart.AxisY.Type);

    // 2 - Ytdiagram med datum fördelade längs X-axeln:
    chart = AppendChart(builder, ChartType.Area, 500, 300);

    DateTime[] dates = { new DateTime(2014, 3, 31),
        new DateTime(2017, 1, 23),
        new DateTime(2017, 6, 18),
        new DateTime(2019, 11, 22),
        new DateTime(2020, 9, 7)
    };

    // Infoga en serie med ett decimalvärde för respektive datum.
    // Datumen kommer att fördelas längs en linjär X-axel,
    // och värdena som läggs till i denna serie kommer att skapa datapunkter.
    chart.Series.Add("Series 1", dates, new [] { 15.8, 21.5, 22.9, 28.7, 33.1 });

    Assert.AreEqual(ChartAxisType.Category, chart.AxisX.Type);
    Assert.AreEqual(ChartAxisType.Value, chart.AxisY.Type);

    // 3 - 2D spridningsdiagram:
    chart = AppendChart(builder, ChartType.Scatter, 500, 300);

    // Varje serie kommer att behöva två decimalmatriser av samma längd.
    // Den första matrisen innehåller X-värden och den andra innehåller motsvarande Y-värden
    // av datapunkter på diagrammets graf.
    chart.Series.Add("Series 1", 
        new[] { 3.1, 3.5, 6.3, 4.1, 2.2, 8.3, 1.2, 3.6 }, 
        new[] { 3.1, 6.3, 4.6, 0.9, 8.5, 4.2, 2.3, 9.9 });
    chart.Series.Add("Series 2", 
        new[] { 2.6, 7.3, 4.5, 6.6, 2.1, 9.3, 0.7, 3.3 }, 
        new[] { 7.1, 6.6, 3.5, 7.8, 7.7, 9.5, 1.3, 4.6 });

    Assert.AreEqual(ChartAxisType.Value, chart.AxisX.Type);
    Assert.AreEqual(ChartAxisType.Value, chart.AxisY.Type);

    // 4 - Bubbeldiagram:
    chart = AppendChart(builder, ChartType.Bubble, 500, 300);

    // Varje serie kommer att behöva tre decimalmatriser av samma längd.
    // Den första matrisen innehåller X-värden, den andra innehåller motsvarande Y-värden,
    // och den tredje innehåller diametrar för var och en av grafens datapunkter.
    chart.Series.Add("Series 1", 
        new [] { 1.1, 5.0, 9.8 }, 
        new [] { 1.2, 4.9, 9.9 }, 
        new [] { 2.0, 4.0, 8.0 });

    doc.Save(ArtifactsDir + "Charts.ChartSeriesCollection.docx");
}

/// <summary>
/// Infoga ett diagram med hjälp av en dokumentbyggare med en specificerad diagramtyp, bredd och höjd, och ta bort dess demodata.
/// </summary>
private static Chart AppendChart(DocumentBuilder builder, ChartType chartType, double width, double height)
{
    Shape chartShape = builder.InsertChart(chartType, width, height);
    Chart chart = chartShape.Chart;
    chart.Series.Clear();
    return chart;
}

Se även