选择圆弧段

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了选择圆弧段相关的知识,希望对你有一定的参考价值。

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

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

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

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

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

Wheel / Dial Example Image

答案

说实话,你可以通过多种方式做到这一点。我能想到的最简单的方法之一就是利用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

另一答案

如果可以接受,可以使用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;
}

以上是关于选择圆弧段的主要内容,如果未能解决你的问题,请参考以下文章

VS2015 代码片段整理

MFC 动态绘制直线,圆弧段(连续)如何实现

「SHOI2012」信用卡凸包

vs code 自定义代码片段

使用python实现画出一段给定角度的近似圆弧

vba在cad中画直线和圆弧多段线