调整窗口大小时如何自动调整JFreeChart的大小

时间:2019-02-09 15:20:35

标签: java swing jpanel jfreechart chartpanel

我在ChartPanel内的JPanel内的JFrame内有一个图表。我目前有BoxLayou t的帧和FlowLayout的{​​{1}}。我想让图表在调整窗口大小时自动调整大小。我已经尝试了在这里找到的所有解决方案,并且唯一有效的方法是将JPanel布局设置为JPanel,但是我无法使用它,因为{{1 }},并使它们的大小都相同(我需要图表比其他图表更大)。

目前,我有:

GridLayout

我已经尝试了解决方法here,但是添加子面板对我没有任何帮助。我认为不必为了使图表调整大小而添加额外的面板。我该如何仅使用JPanelchartPanel.setPreferredSize(new java.awt.Dimension(500, 250)); frame = new JFrame(); frame.setLayout(new BoxLayout(frame.getContentPane(), BoxLayout.Y_AXIS)); mainPanel = new JPanel(new FlowLayout()); mainPanel.setPreferredSize(new Dimension(500, 500)); mainPanel.add(chartPanel); frame.add(mainPanel); frame.pack(); frame.setLocationRelativeTo(null); frame.setVisible(true); chartPanel来做到这一点?

1 个答案:

答案 0 :(得分:1)

  

唯一可行的方法是将JPanel布局设置为GridLayout,但是我不能使用它,因为JPanel中有其他组件,并且它们的大小都相同(我需要图表比休息)。

然后对JPanel使用GridLayout或更好的BorderLayout并将其他组件放置在新的JPanel中,该组件使用FlowLayout,然后将 that JPanel添加到主JPanel中。一。 Nest JPanels,每个都使用各自的布局来实现最灵活的GUI和设计。

  

我认为不必为了增加图表的大小而添加额外的面板。

是的。

  

我有一个图表和一堆按钮(在图表下方),这些按钮可让用户与图表进行交互。显然,我不希望按钮与图表本身一样大。当前,所有按钮和chartPanel都位于mainPanel内部。

然后使用BorderLayout,将图表放置在BorderLayout.CENTER位置,并将按钮放到BorderPad.PAGE_END位置的JPanel中(如果需要,可以使用默认的FlowLayout,或者其他效果最佳的布局)。

例如:

enter image description here

import java.awt.BorderLayout;
import java.awt.Color;
import java.awt.Font;
import java.awt.GridBagLayout;
import java.awt.GridLayout;

import javax.swing.*;
import javax.swing.border.Border;

public class ChartAndButtons extends JPanel {
    private static final long serialVersionUID = 1L;

    public ChartAndButtons() {
        JPanel mockChartPanel = createMockChart();
        int gap = 3;
        JPanel buttonPanel = new JPanel(new GridLayout(1, 0, gap, gap));
        buttonPanel.setBorder(BorderFactory.createEmptyBorder(gap, gap, gap, gap));
        String[] buttonNames = {"Monday", "Tuesday", "Wednesday", "Thursday", "Friday"};
        for (String buttonName : buttonNames) {
            buttonPanel.add(new JButton(buttonName));
        }

        setLayout(new BorderLayout());
        add(mockChartPanel, BorderLayout.CENTER);
        add(buttonPanel, BorderLayout.PAGE_END);
    }

    // ignore this -- it simply creates a JPanel as a placeholder
    // for your real JFreeChart panel   
    private JPanel createMockChart() {
        JLabel label = new JLabel("Mock Chart");
        label.setFont(label.getFont().deriveFont(Font.BOLD, 60f));
        Color color = Color.ORANGE;
        JPanel mockChartPanel = new JPanel(new GridBagLayout());
        mockChartPanel.add(label);
        Border outsideBorder = BorderFactory.createLineBorder(color, 40);
        int eb = 80;
        Border insideBorder = BorderFactory.createEmptyBorder(eb, eb, eb, eb);
        mockChartPanel.setBorder(BorderFactory.createCompoundBorder(outsideBorder, insideBorder));
        mockChartPanel.setBackground(color.brighter());

        return mockChartPanel;
    }

    private static void createAndShowGui() {
        ChartAndButtons mainPanel = new ChartAndButtons();

        JFrame frame = new JFrame("ChartAndButtons");
        frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
        frame.getContentPane().add(mainPanel);
        frame.pack();
        frame.setLocationRelativeTo(null);
        frame.setVisible(true);
    }

    public static void main(String[] args) {
        SwingUtilities.invokeLater(() -> createAndShowGui());
    }
}