选择圆弧段

问题描述 投票:1回答:2

我正在使用java在Windows中创建一个轮/拨号选择器,它会在按下按钮时弹出,以便用户选择其中一个不同的段来执行之前在创建该段时指定的内容。

我不知道如何选择圆的不同部分,目前我使用自定义布局在圆周围创建了JLabel,但是它们的交互区域仅限于文本周围的矩形。

如何将此区域更改为三角形/ pi区段?

有没有更好的方法来实现这一目标?

这是一个图像,其中段4具有我想要实现的区域(以蓝色突出显示)。

Wheel / Dial Example Image

java swing geometry draw jlabel
2个回答
3
投票

说实话,你可以通过多种方式做到这一点。我能想到的最简单的方法之一就是利用2D Graphics Shape API。

下面的例子简单地使用Arc2D来简化,但是一般的概念也应该适用于基于Path的形状(如果你想要那么复杂)

Highlight segment

import java.awt.Color;
import java.awt.Dimension;
import java.awt.EventQueue;
import java.awt.Graphics;
import java.awt.Graphics2D;
import java.awt.Point;
import java.awt.event.MouseAdapter;
import java.awt.event.MouseEvent;
import java.awt.geom.Arc2D;
import javax.swing.JFrame;
import javax.swing.JPanel;
import javax.swing.UIManager;
import javax.swing.UnsupportedLookAndFeelException;

public class Test {

    public static void main(String[] args) {
        new Test();
    }

    public Test() {
        EventQueue.invokeLater(new Runnable() {
            @Override
            public void run() {
                try {
                    UIManager.setLookAndFeel(UIManager.getSystemLookAndFeelClassName());
                } catch (ClassNotFoundException | InstantiationException | IllegalAccessException | UnsupportedLookAndFeelException ex) {
                    ex.printStackTrace();
                }

                JFrame frame = new JFrame("Testing");
                frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
                frame.add(new TestPane());
                frame.pack();
                frame.setLocationRelativeTo(null);
                frame.setVisible(true);
            }
        });
    }

    public class TestPane extends JPanel {

        private Arc2D segment;

        private Arc2D selected = null;

        public TestPane() {
            segment = new Arc2D.Double(0, 0, 190, 190, -11.75, 23.5, Arc2D.PIE);
            addMouseMotionListener(new MouseAdapter() {
                @Override
                public void mouseMoved(MouseEvent e) {
                    Point p = e.getPoint();
                    p.translate(-5, -5);
                    selected = null;
                    if (segment.contains(e.getPoint())) {
                        selected = segment;
                    }
                    repaint();
                }
            });
        }

        @Override
        public Dimension getPreferredSize() {
            return new Dimension(200, 200);
        }

        protected void paintComponent(Graphics g) {
            super.paintComponent(g);
            Graphics2D g2d = (Graphics2D) g.create();
            g2d.translate(5, 5);
            if (selected != null) {
                g2d.setColor(Color.BLUE);
                g2d.fill(selected);
            }
            g2d.setColor(Color.RED);
            g2d.draw(segment);
            g2d.dispose();
        }

    }

}

有关更多详细信息,请查看Working with Geometry


3
投票

如果可以接受,可以使用PiePlot。从包含在分布中的PieChartDemo1开始,以下更改产生如下所示的图。当鼠标移动时,ChartMouseListener突出显示指示的部分。

image

public static JPanel createDemoPanel() {
    …
    PiePlot plot = (PiePlot) chart.getPlot();
    PieDataset data = plot.getDataset();
    panel.addChartMouseListener(new ChartMouseListener() {
        @Override
        public void chartMouseMoved(ChartMouseEvent e) {
            ChartEntity ce = e.getEntity();
            if (ce instanceof PieSectionEntity) {
                for (int i = 0; i < data.getItemCount(); i++) {
                    plot.setExplodePercent(data.getKey(i), 0);
                }
                PieSectionEntity item = (PieSectionEntity) ce;
                plot.setExplodePercent(item.getSectionKey(), 0.25);
            }
        }
        @Override
        public void chartMouseClicked(ChartMouseEvent e) {}
    });
    return panel;
}
© www.soinside.com 2019 - 2024. All rights reserved.