Pembuatan Bagan Radar di Slide Java

Pengantar Membuat Bagan Radar di Slide Java

Dalam tutorial ini, kami akan memandu Anda melalui proses pembuatan Radar Chart menggunakan Aspose.Slides for Java API. Bagan radar berguna untuk memvisualisasikan data dalam pola melingkar, sehingga memudahkan untuk membandingkan beberapa rangkaian data. Kami akan memberikan petunjuk langkah demi langkah beserta kode sumber Java.

Prasyarat

Sebelum kita mulai, pastikan Anda memiliki perpustakaan Aspose.Slides untuk Java yang terintegrasi ke dalam proyek Anda. Anda dapat mengunduh perpustakaan dariDi Sini.

Langkah 1: Menyiapkan Presentasi

Mari kita mulai dengan menyiapkan presentasi PowerPoint baru dan menambahkan slide ke dalamnya.

String outPath = "Your Output Directory" + File.separator + "RadarChart_Out.pptx";
Presentation pres = new Presentation();

Langkah 2: Menambahkan Bagan Radar

Selanjutnya, kita akan menambahkan grafik radar ke slide. Kami akan menentukan posisi dan dimensi bagan.

ISlide sld = pres.getSlides().get_Item(0);
IChart ichart = sld.getShapes().addChart(ChartType.Radar, 0, 0, 400, 400);

Langkah 3: Mengatur Data Bagan

Kami sekarang akan mengatur data grafik. Ini melibatkan pembuatan buku kerja data, penambahan kategori, dan penambahan seri.

int defaultWorksheetIndex = 0;
IChartDataWorkbook fact = ichart.getChartData().getChartDataWorkbook();

// Tetapkan judul bagan
ichart.getChartTitle().addTextFrameForOverriding("Radar Chart");

// Hapus seri dan kategori yang dihasilkan secara default
ichart.getChartData().getCategories().clear();
ichart.getChartData().getSeries().clear();

// Menambahkan kategori baru
ichart.getChartData().getCategories().add(fact.getCell(defaultWorksheetIndex, 1, 0, "Category 1"));
ichart.getChartData().getCategories().add(fact.getCell(defaultWorksheetIndex, 2, 0, "Category 3"));
ichart.getChartData().getCategories().add(fact.getCell(defaultWorksheetIndex, 3, 0, "Category 5"));
ichart.getChartData().getCategories().add(fact.getCell(defaultWorksheetIndex, 4, 0, "Category 7"));
ichart.getChartData().getCategories().add(fact.getCell(defaultWorksheetIndex, 5, 0, "Category 9"));
ichart.getChartData().getCategories().add(fact.getCell(defaultWorksheetIndex, 6, 0, "Category 11"));

// Menambahkan seri baru
ichart.getChartData().getSeries().add(fact.getCell(defaultWorksheetIndex, 0, 1, "Series 1"), ichart.getType());
ichart.getChartData().getSeries().add(fact.getCell(defaultWorksheetIndex, 0, 2, "Series 2"), ichart.getType());

Langkah 4: Mengisi Data Seri

Sekarang, kita akan mengisi data seri untuk bagan radar kita.

// Isi data seri untuk Seri 1
IChartSeries series = ichart.getChartData().getSeries().get_Item(0);
series.getDataPoints().addDataPointForRadarSeries(fact.getCell(defaultWorksheetIndex, 1, 1, 2.7));
series.getDataPoints().addDataPointForRadarSeries(fact.getCell(defaultWorksheetIndex, 2, 1, 2.4));
series.getDataPoints().addDataPointForRadarSeries(fact.getCell(defaultWorksheetIndex, 3, 1, 1.5));
series.getDataPoints().addDataPointForRadarSeries(fact.getCell(defaultWorksheetIndex, 4, 1, 3.5));
series.getDataPoints().addDataPointForRadarSeries(fact.getCell(defaultWorksheetIndex, 5, 1, 5));
series.getDataPoints().addDataPointForRadarSeries(fact.getCell(defaultWorksheetIndex, 6, 1, 3.5));

// Atur warna seri
series.getFormat().getLine().getFillFormat().setFillType(FillType.Solid);
series.getFormat().getLine().getFillFormat().getSolidFillColor().setColor(Color.RED);

// Isi data seri untuk Seri 2
series = ichart.getChartData().getSeries().get_Item(1);
series.getDataPoints().addDataPointForRadarSeries(fact.getCell(defaultWorksheetIndex, 1, 2, 2.5));
series.getDataPoints().addDataPointForRadarSeries(fact.getCell(defaultWorksheetIndex, 2, 2, 2.4));
series.getDataPoints().addDataPointForRadarSeries(fact.getCell(defaultWorksheetIndex, 3, 2, 1.6));
series.getDataPoints().addDataPointForRadarSeries(fact.getCell(defaultWorksheetIndex, 4, 2, 3.5));
series.getDataPoints().addDataPointForRadarSeries(fact.getCell(defaultWorksheetIndex, 5, 2, 4));
series.getDataPoints().addDataPointForRadarSeries(fact.getCell(defaultWorksheetIndex, 6, 2, 3.6));

// Atur warna seri
series.getFormat().getLine().getFillFormat().setFillType(FillType.Solid);
series.getFormat().getLine().getFillFormat().getSolidFillColor().setColor(Color.ORANGE);

Langkah 5: Menyesuaikan Sumbu dan Legenda

Mari sesuaikan sumbu dan legenda untuk bagan radar kita.

// Tetapkan posisi legenda
ichart.getLegend().setPosition(LegendPositionType.Bottom);

// Mengatur Properti Teks Sumbu Kategori
IChartPortionFormat txtCat = ichart.getAxes().getHorizontalAxis().getTextFormat().getPortionFormat();
txtCat.setFontBold(NullableBool.True);
txtCat.setFontHeight(10);
txtCat.getFillFormat().setFillType(FillType.Solid);
txtCat.getFillFormat().getSolidFillColor().setColor(new Color(PresetColor.DimGray));
txtCat.setLatinFont(new FontData("Calibri"));

// Mengatur Properti Teks Legenda
IChartPortionFormat txtleg = ichart.getLegend().getTextFormat().getPortionFormat();
txtleg.setFontBold(NullableBool.True);
txtleg.setFontHeight(10);
txtleg.getFillFormat().setFillType(FillType.Solid);
txtleg.getFillFormat().getSolidFillColor().setColor(new Color(PresetColor.DimGray));
txtleg.setLatinFont(new FontData("Calibri"));

// Menetapkan Properti Teks Sumbu Nilai
IChartPortionFormat txtVal = ichart.getAxes().getVerticalAxis().getTextFormat().getPortionFormat();
txtVal.setFontBold(NullableBool.True);
txtVal.setFontHeight(10);
txtVal.getFillFormat().setFillType(FillType.Solid);
txtVal.getFillFormat().getSolidFillColor().setColor(new Color(PresetColor.DimGray));
txtVal.setLatinFont(new FontData("Calibri"));

// Menetapkan format angka sumbu nilai
ichart.getAxes().getVerticalAxis().setNumberFormatLinkedToSource(false);
ichart.getAxes().getVerticalAxis().setNumberFormat("\"$\"#,##0.00");

// Menetapkan nilai satuan utama bagan
ichart.getAxes().getVerticalAxis().setAutomaticMajorUnit(false);
ichart.getAxes().getVerticalAxis().setMajorUnit(1.25f);

Langkah 6: Menyimpan Presentasi

Terakhir, simpan presentasi yang dihasilkan dengan bagan radar

.

pres.save(outPath, SaveFormat.Pptx);

Itu dia! Anda telah berhasil membuat bagan radar dalam presentasi PowerPoint menggunakan Aspose.Slides untuk Java. Anda sekarang dapat menyesuaikan contoh ini lebih lanjut agar sesuai dengan kebutuhan spesifik Anda.

Kode Sumber Lengkap Untuk Pembuatan Bagan Radar di Slide Java

String outPath = "Your Output Directory" + File.separator + "RadarChart_Out.pptx";
Presentation pres = new Presentation();
try
{
	// Akses slide pertama
	ISlide sld = pres.getSlides().get_Item(0);
	// Tambahkan bagan Radar
	IChart ichart = sld.getShapes().addChart(ChartType.Radar, 0, 0, 400, 400);
	// Mengatur indeks lembar data grafik
	int defaultWorksheetIndex = 0;
	// Mendapatkan data grafik Lembar Kerja
	IChartDataWorkbook fact = ichart.getChartData().getChartDataWorkbook();
	// Tetapkan judul bagan
	ichart.getChartTitle().addTextFrameForOverriding("Radar Chart");
	// Hapus seri dan kategori yang dihasilkan secara default
	ichart.getChartData().getCategories().clear();
	ichart.getChartData().getSeries().clear();
	// Menambahkan kategori baru
	ichart.getChartData().getCategories().add(fact.getCell(defaultWorksheetIndex, 1, 0, "Caetegoty 1"));
	ichart.getChartData().getCategories().add(fact.getCell(defaultWorksheetIndex, 2, 0, "Caetegoty 3"));
	ichart.getChartData().getCategories().add(fact.getCell(defaultWorksheetIndex, 3, 0, "Caetegoty 5"));
	ichart.getChartData().getCategories().add(fact.getCell(defaultWorksheetIndex, 4, 0, "Caetegoty 7"));
	ichart.getChartData().getCategories().add(fact.getCell(defaultWorksheetIndex, 5, 0, "Caetegoty 9"));
	ichart.getChartData().getCategories().add(fact.getCell(defaultWorksheetIndex, 6, 0, "Caetegoty 11"));
	// Menambahkan seri baru
	ichart.getChartData().getSeries().add(fact.getCell(defaultWorksheetIndex, 0, 1, "Series 1"), ichart.getType());
	ichart.getChartData().getSeries().add(fact.getCell(defaultWorksheetIndex, 0, 2, "Series 2"), ichart.getType());
	// Sekarang mengisi data seri
	IChartSeries series = ichart.getChartData().getSeries().get_Item(0);
	series.getDataPoints().addDataPointForRadarSeries(fact.getCell(defaultWorksheetIndex, 1, 1, 2.7));
	series.getDataPoints().addDataPointForRadarSeries(fact.getCell(defaultWorksheetIndex, 2, 1, 2.4));
	series.getDataPoints().addDataPointForRadarSeries(fact.getCell(defaultWorksheetIndex, 3, 1, 1.5));
	series.getDataPoints().addDataPointForRadarSeries(fact.getCell(defaultWorksheetIndex, 4, 1, 3.5));
	series.getDataPoints().addDataPointForRadarSeries(fact.getCell(defaultWorksheetIndex, 5, 1, 5));
	series.getDataPoints().addDataPointForRadarSeries(fact.getCell(defaultWorksheetIndex, 6, 1, 3.5));
	// Atur warna seri
	series.getFormat().getLine().getFillFormat().setFillType(FillType.Solid);
	series.getFormat().getLine().getFillFormat().getSolidFillColor().setColor(Color.RED);
	//Sekarang mengisi data seri lainnya
	series = ichart.getChartData().getSeries().get_Item(1);
	series.getDataPoints().addDataPointForRadarSeries(fact.getCell(defaultWorksheetIndex, 1, 2, 2.5));
	series.getDataPoints().addDataPointForRadarSeries(fact.getCell(defaultWorksheetIndex, 2, 2, 2.4));
	series.getDataPoints().addDataPointForRadarSeries(fact.getCell(defaultWorksheetIndex, 3, 2, 1.6));
	series.getDataPoints().addDataPointForRadarSeries(fact.getCell(defaultWorksheetIndex, 4, 2, 3.5));
	series.getDataPoints().addDataPointForRadarSeries(fact.getCell(defaultWorksheetIndex, 5, 2, 4));
	series.getDataPoints().addDataPointForRadarSeries(fact.getCell(defaultWorksheetIndex, 6, 2, 3.6));
	// Atur warna seri
	series.getFormat().getLine().getFillFormat().setFillType(FillType.Solid);
	series.getFormat().getLine().getFillFormat().getSolidFillColor().setColor(Color.ORANGE);
	// Tetapkan posisi legenda
	ichart.getLegend().setPosition(LegendPositionType.Bottom);
	// Mengatur Properti Teks Sumbu Kategori
	IChartPortionFormat txtCat = ichart.getAxes().getHorizontalAxis().getTextFormat().getPortionFormat();
	txtCat.setFontBold(NullableBool.True);
	txtCat.setFontHeight(10);
	txtCat.getFillFormat().setFillType(FillType.Solid);
	txtCat.getFillFormat().getSolidFillColor().setColor(new Color(PresetColor.DimGray));
	txtCat.setLatinFont(new FontData("Calibri"));
	// Mengatur Properti Teks Legenda
	IChartPortionFormat txtleg = ichart.getLegend().getTextFormat().getPortionFormat();
	txtleg.setFontBold(NullableBool.True);
	txtleg.setFontHeight(10);
	txtleg.getFillFormat().setFillType(FillType.Solid);
	txtleg.getFillFormat().getSolidFillColor().setColor(new Color(PresetColor.DimGray));
	txtCat.setLatinFont(new FontData("Calibri"));
	// Menetapkan Properti Teks Sumbu Nilai
	IChartPortionFormat txtVal = ichart.getAxes().getVerticalAxis().getTextFormat().getPortionFormat();
	txtVal.setFontBold(NullableBool.True);
	txtVal.setFontHeight(10);
	txtVal.getFillFormat().setFillType(FillType.Solid);
	txtVal.getFillFormat().getSolidFillColor().setColor(new Color(PresetColor.DimGray));
	txtVal.setLatinFont(new FontData("Calibri"));
	// Menetapkan format angka sumbu nilai
	ichart.getAxes().getVerticalAxis().setNumberFormatLinkedToSource(false);
	ichart.getAxes().getVerticalAxis().setNumberFormat("\"$\"#,##0.00");
	// Menetapkan nilai satuan utama bagan
	ichart.getAxes().getVerticalAxis().setAutomaticMajorUnit(false);
	ichart.getAxes().getVerticalAxis().setMajorUnit(1.25f);
	// Simpan presentasi yang dihasilkan
	pres.save(outPath, SaveFormat.Pptx);
}
finally
{
	if (pres != null) pres.dispose();
}

Kesimpulan

Dalam tutorial ini, Anda telah mempelajari cara membuat bagan radar dalam presentasi PowerPoint menggunakan Aspose.Slides untuk Java. Anda dapat menerapkan konsep ini untuk memvisualisasikan dan menyajikan data secara efektif dalam aplikasi Java Anda.

FAQ

Bagaimana cara mengubah judul grafik?

Untuk mengubah judul grafik, ubah baris berikut:

ichart.getChartTitle().addTextFrameForOverriding("Radar Chart");

Bisakah saya menambahkan lebih banyak rangkaian data ke bagan radar?

Ya, Anda dapat menambahkan lebih banyak rangkaian data dengan mengikuti langkah-langkah di “Langkah 3” dan “Langkah 4” untuk setiap rangkaian data tambahan yang ingin Anda sertakan.

Bagaimana cara menyesuaikan warna grafik?

Anda dapat menyesuaikan warna rangkaian dengan memodifikasi garis yang mengaturnyaSolidFillColor properti untuk setiap seri. Misalnya:

series.getFormat().getLine().getFillFormat().getSolidFillColor().setColor(Color.RED);

Bagaimana cara mengubah label dan format sumbu?

Lihat “Langkah 5” untuk menyesuaikan label dan format sumbu, termasuk ukuran dan warna font.

Bagaimana cara menyimpan grafik ke format file lain?

Anda dapat mengubah format keluaran dengan memodifikasi ekstensi file dioutPath variabel dan menggunakan yang sesuaiSaveFormat . Misalnya, untuk menyimpan sebagai PDF, gunakanSaveFormat.Pdf.