では、前回の「凡例+グリッド線付き折れ線グラフ」をさらに発展させて、X軸ラベル(例えば「時間」「カテゴリ」など)を追加するサンプルを紹介します。
サンプルコード:X軸ラベル付き折れ線グラフ
import javax.swing.*;
import java.awt.*;
import java.util.*;
public class MultiLineChartWithXAxisLabel extends JPanel {
private List<Map<Integer, Integer>> datasets;
private List<String> labels;
private String xAxisLabel = "カテゴリ"; // X軸ラベル
private String yAxisLabel = "値"; // Y軸ラベル
private List<Color> colors = Arrays.asList(Color.RED, Color.BLUE, Color.GREEN, Color.ORANGE);
public MultiLineChartWithXAxisLabel(List<Map<Integer, Integer>> datasets, List<String> labels) {
this.datasets = datasets;
this.labels = labels;
setPreferredSize(new Dimension(600, 400));
}
@Override
protected void paintComponent(Graphics g) {
super.paintComponent(g);
if (datasets == null || datasets.isEmpty()) return;
int width = getWidth();
int height = getHeight();
// 軸
g.setColor(Color.BLACK);
g.drawLine(50, height - 50, width - 20, height - 50); // X軸
g.drawLine(50, 30, 50, height - 50); // Y軸
// 軸ラベル
g.drawString(xAxisLabel, width / 2 - 20, height - 10);
g.drawString(yAxisLabel, 10, height / 2);
// 最大値を求める
int maxCount = 0;
for (Map<Integer, Integer> data : datasets) {
if (!data.isEmpty()) {
maxCount = Math.max(maxCount, Collections.max(data.values()));
}
}
// --- グリッド線(横方向) ---
g.setColor(Color.LIGHT_GRAY);
int gridLines = 5;
for (int i = 1; i <= gridLines; i++) {
int y = height - 50 - (i * (height - 80) / gridLines);
g.drawLine(50, y, width - 20, y);
int labelValue = (int) ((double) maxCount * i / gridLines);
g.setColor(Color.BLACK);
g.drawString(String.valueOf(labelValue), 20, y + 5);
g.setColor(Color.LIGHT_GRAY);
}
// データセットごとに折れ線を描画
int datasetIndex = 0;
for (Map<Integer, Integer> data : datasets) {
g.setColor(colors.get(datasetIndex % colors.size()));
List<Integer> keys = new ArrayList<>(data.keySet());
Collections.sort(keys);
int prevX = -1, prevY = -1;
int i = 0;
for (int key : keys) {
int count = data.get(key);
int x = 50 + (i * (width - 100) / (keys.size() - 1));
int y = height - 50 - (int) ((double) count / maxCount * (height - 100));
g.fillOval(x - 3, y - 3, 6, 6);
if (prevX != -1) {
g.drawLine(prevX, prevY, x, y);
}
// X軸のカテゴリラベル
g.setColor(Color.BLACK);
g.drawString(String.valueOf(key), x - 5, height - 35);
prevX = x;
prevY = y;
i++;
}
datasetIndex++;
}
// --- 凡例 ---
int legendX = width - 150;
int legendY = 40;
g.setColor(Color.BLACK);
g.drawString("凡例:", legendX, legendY);
for (int i = 0; i < datasets.size(); i++) {
g.setColor(colors.get(i % colors.size()));
g.fillRect(legendX, legendY + 15 + i * 20, 15, 15);
g.setColor(Color.BLACK);
g.drawString(labels.get(i), legendX + 20, legendY + 27 + i * 20);
}
}
public static void main(String[] args) {
// ダミーデータセット
Map<Integer, Integer> dataset1 = new LinkedHashMap<>();
dataset1.put(1, 3);
dataset1.put(2, 5);
dataset1.put(3, 2);
dataset1.put(4, 7);
Map<Integer, Integer> dataset2 = new LinkedHashMap<>();
dataset2.put(1, 2);
dataset2.put(2, 4);
dataset2.put(3, 6);
dataset2.put(4, 5);
List<Map<Integer, Integer>> datasets = Arrays.asList(dataset1, dataset2);
List<String> labels = Arrays.asList("データセット1", "データセット2");
JFrame frame = new JFrame("X軸ラベル付き折れ線グラフ");
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
frame.add(new MultiLineChartWithXAxisLabel(datasets, labels));
frame.pack();
frame.setVisible(true);
}
}
Java✅ 実行イメージ
- グラフ下部に X軸ラベル(カテゴリ番号や時間など) が表示されます
- 左側に Y軸ラベル(値) が表示され、縦軸の意味が明確になります
- 凡例とグリッド線も引き続き表示され、見やすさが向上
ポイント
g.drawString(xAxisLabel, width/2, height-10)でX軸ラベルを中央に描画g.drawString(yAxisLabel, 10, height/2)でY軸ラベルを縦軸に追加(簡易的に横書き)- 各データ点の下に
keyを描画してカテゴリを明示
👉 これで「凡例+グリッド線+X軸ラベル付き折れ線グラフ」が完成しました。

