.NET のプレゼンテーションでチャート軸をカスタマイズする
チャートの縦軸の最大値を取得する
Aspose.Slides for .NET を使用すると、縦軸の最小値と最大値を取得できます。以下の手順を実行してください。
- Presentation クラスのインスタンスを作成します。
- 最初のスライドにアクセスします。
- デフォルト データでチャートを追加します。
- 軸上の実際の最大値を取得します。
- 軸上の実際の最小値を取得します。
- 軸の実際の主単位を取得します。
- 軸の実際の副単位を取得します。
- 軸の実際の主単位スケールを取得します。
- 軸の実際の副単位スケールを取得します。
以下のサンプル コードは、上記手順の実装例で、C# で必要な値を取得する方法を示しています。
using (Presentation pres = new Presentation())
{
Chart chart = (Chart)pres.Slides[0].Shapes.AddChart(ChartType.Area, 100, 100, 500, 350);
chart.ValidateChartLayout();
double maxValue = chart.Axes.VerticalAxis.ActualMaxValue;
double minValue = chart.Axes.VerticalAxis.ActualMinValue;
double majorUnit = chart.Axes.HorizontalAxis.ActualMajorUnit;
double minorUnit = chart.Axes.HorizontalAxis.ActualMinorUnit;
// プレゼンテーションを保存します
presentation.Save("ErrorBars_out.pptx", SaveFormat.Pptx);
}
軸間のデータを入れ替える
Aspose.Slides を使用すると、軸間のデータをすばやく入れ替えることができます。縦軸(y 軸)のデータが横軸(x 軸)に、横軸のデータが縦軸に移動します。
この C# コードは、チャートの軸間でデータを入れ替える方法を示しています。
// 空のプレゼンテーションを作成します
using (Presentation pres = new Presentation())
{
IChart chart = pres.Slides[0].Shapes.AddChart(ChartType.ClusteredColumn, 100, 100, 400, 300);
//行と列を入れ替えます
chart.ChartData.SwitchRowColumn();
// プレゼンテーションを保存します
pres.Save("SwitchChartRowColumns_out.pptx", SaveFormat.Pptx);
}
折れ線グラフの縦軸を非表示にする
この C# コードは、折れ線グラフの縦軸を非表示にする方法を示しています。
using (Presentation pres = new Presentation())
{
IChart chart = pres.Slides[0].Shapes.AddChart(ChartType.Line, 100, 100, 400, 300);
chart.Axes.VerticalAxis.IsVisible = false;
pres.Save("chart.pptx", SaveFormat.Pptx);
}
折れ線グラフの横軸を非表示にする
このコードは、折れ線グラフの横軸を非表示にする方法を示しています。
using (Presentation pres = new Presentation())
{
IChart chart = pres.Slides[0].Shapes.AddChart(ChartType.Line, 100, 100, 400, 300);
chart.Axes.HorizontalAxis.IsVisible = false;
pres.Save("chart.pptx", SaveFormat.Pptx);
}
カテゴリ軸を変更する
CategoryAxisType プロパティを使用すると、希望するカテゴリ軸のタイプ(date または text)を指定できます。この C# のコードは、その操作をデモンストレーションしています。
using (Presentation presentation = new Presentation("ExistingChart.pptx"))
{
IChart chart = presentation.Slides[0].Shapes[0] as IChart;
chart.Axes.HorizontalAxis.CategoryAxisType = CategoryAxisType.Date;
chart.Axes.HorizontalAxis.IsAutomaticMajorUnit = false;
chart.Axes.HorizontalAxis.MajorUnit = 1;
chart.Axes.HorizontalAxis.MajorUnitScale = TimeUnitType.Months;
presentation.Save("ChangeChartCategoryAxis_out.pptx", SaveFormat.Pptx);
}
カテゴリ軸値の日付書式を設定する
Aspose.Slides for .NET を使用すると、カテゴリ軸値の日付書式を設定できます。操作は次の C# コードで示されています。
using (Presentation pres = new Presentation())
{
IChart chart = pres.Slides[0].Shapes.AddChart(ChartType.Area, 50, 50, 450, 300);
IChartDataWorkbook wb = chart.ChartData.ChartDataWorkbook;
wb.Clear(0);
chart.ChartData.Categories.Clear();
chart.ChartData.Series.Clear();
chart.ChartData.Categories.Add(wb.GetCell(0, "A2", new DateTime(2015, 1, 1).ToOADate()));
chart.ChartData.Categories.Add(wb.GetCell(0, "A3", new DateTime(2016, 1, 1).ToOADate()));
chart.ChartData.Categories.Add(wb.GetCell(0, "A4", new DateTime(2017, 1, 1).ToOADate()));
chart.ChartData.Categories.Add(wb.GetCell(0, "A5", new DateTime(2018, 1, 1).ToOADate()));
IChartSeries series = chart.ChartData.Series.Add(ChartType.Line);
series.DataPoints.AddDataPointForLineSeries(wb.GetCell(0, "B2", 1));
series.DataPoints.AddDataPointForLineSeries(wb.GetCell(0, "B3", 2));
series.DataPoints.AddDataPointForLineSeries(wb.GetCell(0, "B4", 3));
series.DataPoints.AddDataPointForLineSeries(wb.GetCell(0, "B5", 4));
chart.Axes.HorizontalAxis.CategoryAxisType = CategoryAxisType.Date;
chart.Axes.HorizontalAxis.IsNumberFormatLinkedToSource = false;
chart.Axes.HorizontalAxis.NumberFormat = "yyyy";
pres.Save("test.pptx", SaveFormat.Pptx);
}
チャート軸タイトルの回転角度を設定する
Aspose.Slides for .NET を使用すると、チャート軸タイトルの回転角度を設定できます。この C# コードはその操作を示しています。
using (Presentation pres = new Presentation())
{
IChart chart = pres.Slides[0].Shapes.AddChart(ChartType.ClusteredColumn, 50, 50, 450, 300);
chart.Axes.VerticalAxis.HasTitle = true;
chart.Axes.VerticalAxis.Title.TextFormat.TextBlockFormat.RotationAngle = 90;
pres.Save("test.pptx", SaveFormat.Pptx);
}
カテゴリ軸または値軸の軸位置を設定する
Aspose.Slides for .NET を使用すると、カテゴリ軸または値軸の位置を設定できます。この C# コードはタスクの実行方法を示しています。
using (Presentation pres = new Presentation())
{
IChart chart = pres.Slides[0].Shapes.AddChart(ChartType.ClusteredColumn, 50, 50, 450, 300);
chart.Axes.HorizontalAxis.AxisBetweenCategories = true;
pres.Save("AsposeScatterChart.pptx", SaveFormat.Pptx);
}
チャート値軸に表示単位ラベルを有効にする
Aspose.Slides for .NET を使用すると、チャートの値軸に単位ラベルを表示するよう構成できます。この C# コードは操作をデモンストレーションしています。
using (Presentation pres = new Presentation(dataDir+"Test.pptx"))
{
IChart chart = pres.Slides[0].Shapes.AddChart(ChartType.ClusteredColumn, 50, 50, 450, 300);
chart.Axes.VerticalAxis.DisplayUnit = DisplayUnitType.Millions;
pres.Save("Result.pptx", SaveFormat.Pptx);
}
FAQ
軸が他の軸と交差する位置(軸交差)をどのように設定しますか?
軸には crossing setting があり、ゼロ、最大カテゴリ/値、または特定の数値で交差させるか選択できます。これにより、X 軸を上下にシフトしたり、ベースラインを強調したりできます。
目盛りラベルを軸に対してどの位置に配置できますか(側面、外側、内側)?
label position を “cross”、“outside”、“inside” に設定します。これにより可読性が向上し、特に小さなチャートでスペースを有効に活用できます。