javapackage p1008; import javax.swing.*; import java.awt.*; import java.awt.image.BufferedImage; import java.io.File; import java.io.IOException; import javax.imageio.ImageIO; public class CirclePoints extends JPanel { private int n; // Number of points private final int radius = 200; // Radius of the circle public CirclePoints(int n) { this.n = n; } @Override protected void paintComponent(Graphics g) { super.paintComponent(g); Graphics2D g2d = (Graphics2D) g; // Calculate the center of the panel int centerX = getWidth() / 2; int centerY = getHeight() / 2; // Draw points and connect them double angleIncrement = 2 * Math.PI / n; int[] xPoints = new int[n]; int[] yPoints = new int[n]; for (int i = 0; i < n; i++) { double angle = i * angleIncrement; int x = (int) (centerX + radius * Math.cos(angle)); int y = (int) (centerY + radius * Math.sin(angle)); xPoints[i] = x; yPoints[i] = y; // Draw the point g2d.fillOval(x - 5, y - 5, 10, 10); } // Connect the points for (int i = 0; i < n; i++) { for(int j=i+1;j<n;j++){ g2d.drawLine(xPoints[i], yPoints[i], xPoints[j], yPoints[j]); } } } public static void main(String[] args) { int n = Integer.parseInt(JOptionPane.showInputDialog("请输入一个5到36之间的整数:")); if (n < 5 || n > 36) { System.out.println("输入无效,请输入5到36之间的整数。"); return; } JFrame frame = new JFrame("Circle Points"); CirclePoints circlePoints = new CirclePoints(n); frame.add(circlePoints); frame.setSize(500, 500); frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); frame.setVisible(true); // Save the panel as an image BufferedImage image = new BufferedImage(frame.getWidth(), frame.getHeight(), BufferedImage.TYPE_INT_RGB); Graphics2D g2d = image.createGraphics(); circlePoints.paint(g2d); g2d.dispose(); try { ImageIO.write(image, "jpg", new File("res.jpg")); System.out.println("图片已保存为 res.jpg"); } catch (IOException e) { e.printStackTrace(); } } }
使用 java画图。
laocooon5238578862024-10-15 20:42
相关推荐
天乐敲代码2 小时前
JAVASE入门九脚-集合框架ArrayList,LinkedList,HashSet,TreeSet,迭代十年一梦实验室2 小时前
【Eigen教程】矩阵、数组和向量类(二)Kent_J_Truman2 小时前
【子矩阵——优先队列】快手技术3 小时前
KwaiCoder-23BA4-v1:以 1/30 的成本训练全尺寸 SOTA 代码续写大模型一只码代码的章鱼4 小时前
粒子群算法 笔记 数学建模小小小小关同学4 小时前
【JVM】垃圾收集器详解圆圆滚滚小企鹅。4 小时前
刷题笔记 贪心算法-1 贪心算法理论基础Kacey Huang4 小时前
YOLOv1、YOLOv2、YOLOv3目标检测算法原理与实战第十三天|YOLOv3实战、安装Typoraeguid_14 小时前
JavaScript图像处理,常用图像边缘检测算法简单介绍说明带多刺的玫瑰5 小时前
Leecode刷题C语言之收集所有金币可获得的最大积分