Java | 複数の入力をまとめて List に格納するサンプル

Java Java
スポンサーリンク

では、前回の「複数データセットを折れ線グラフで比較」をさらに発展させて、凡例(赤=データ1、青=データ2など)を追加するサンプルを紹介します。

サンプルコード:凡例付き折れ線グラフ

import javax.swing.*;
import java.awt.*;
import java.util.*;

public class MultiLineChartWithLegend extends JPanel {
    private List<Map<Integer, Integer>> datasets;
    private List<String> labels;
    private List<Color> colors = Arrays.asList(Color.RED, Color.BLUE, Color.GREEN, Color.ORANGE);

    public MultiLineChartWithLegend(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軸

        // 最大値を求める
        int maxCount = 0;
        for (Map<Integer, Integer> data : datasets) {
            if (!data.isEmpty()) {
                maxCount = Math.max(maxCount, Collections.max(data.values()));
            }
        }

        // データセットごとに折れ線を描画
        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);
                }

                g.drawString(String.valueOf(count), x - 5, y - 10);

                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("凡例付き折れ線グラフ");
        frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
        frame.add(new MultiLineChartWithLegend(datasets, labels));
        frame.pack();
        frame.setVisible(true);
    }
}
Java

✅ 実行イメージ

  • ウィンドウ右上に「凡例」が表示されます
  • 赤い四角 → データセット1
  • 青い四角 → データセット2
  • これで複数の折れ線を直感的に区別できるようになります

ポイント

  • labels リストで各データセットの名前を管理
  • colors と対応させて凡例を描画
  • fillRect で色付きの四角を描き、その横にラベル文字列を表示

👉 これで「複数データセットの折れ線グラフ+凡例表示」まで完成しました。

Java
スポンサーリンク
シェアする
@lifehackerをフォローする
スポンサーリンク
タイトルとURLをコピーしました