polygon
//關鍵是要去處理角度問題
import javax.swing.;
import java.awt.;
import java.awt.geom.Ellipse2D;
import java.awt.geom.Line2D;
import java.awt.geom.Point2D;
import java.util.*;
import java.util.List;
public class PolygonFrame extends JFrame
{
// Build a method to compare points by their y values, breaking ties with
// the x value. As this type of comparison does not need any data other
// than the two points being tested, there is no need to build a
// Comparator class, a method is sufficient.
public static int comparePointByY(Point2D.Double o1, Point2D.Double o2)
{
// Finish this method
if(o1.y < o2.y)
return -1;
else if(o1.y == o2.y){
if(o1.x < o2.x)
return -1;
else if(o1.x == o2.x)
return 0;
else return 1;
}
else
return 1;
}
// Build a Comparator class that compares points by their the polar angle
// (look for helpful functions in java.Math and Point2D) to a given point p
// breaking ties by the distance to p. We can then use this Comparator to
// sort collections or search for minimums and maximums. As this type of
// comparison depends on additional data (the point p) making a class for
// it makes sense. Care must be taken to make this a total ordering.
public static class CompareByPolarAngleToPoint implements Comparator<Point2D.Double>
{
private final Point2D.Double p;
public CompareByPolarAngleToPoint(Point2D.Double p)
{
this.p = p;
}
@Override
public int compare(Point2D.Double o1, Point2D.Double o2)
{
/*
if(o1.x == p.x && o1.y == p.y)
return -1;
if(o2.x == p.x && o2.y == p.y)
return 1;
*/
double diffO1y = o1.y - p.y;
double diffO1x = o1.x - p.x;
double diffO2y = o2.y - p.y;
double diffO2x = o2.x - p.x;
double p1 = Math.atan2(diffO1y,diffO1x);
double p2 = Math.atan2( diffO2y,diffO2x);
if(p1 < p2)
return -1;
else if(Math.abs(p1-p2) < 0.000001){
double dis1 = Math.sqrt(diffO1y * diffO1y + diffO1x * diffO1x);
double dis2 = Math.sqrt(diffO2y * diffO2y + diffO2x * diffO2x);
if(dis1 < dis2)
return -1;
else if(Math.abs(dis1 - dis2) < 0.000001)
return 0;
else return 1;
}
else
return 1;
}
}
// Do not edit the remaining code. However, you should read it to see how your
// comparators are being used.
// Reads in points and draws them
public static void main(String[] args)
{
// Read in all of our points
List<Point2D.Double> pointList = new ArrayList<>();
Scanner scanner = new Scanner(System.in);
while(scanner.hasNextDouble())
{
pointList.add(new Point2D.Double(scanner.nextDouble(), scanner.nextDouble()));
}
// Find the point with the smallest y-coordinate. Here we will use the
// Method reference syntax to pick the comparisons function.
Point2D.Double p = Collections.min(pointList, PolygonFrame::comparePointByY);
// Sort the points using p.
pointList.sort(new CompareByPolarAngleToPoint(p));
// Print the points
System.out.println(pointList);
// Display the points if we can
if (!GraphicsEnvironment.isHeadless())
{
new PolygonFrame(pointList).setVisible(true);
}
}
// A list to hold all of the points
private final List<Point2D.Double> pointList;
// Some constants to control how things look.
public static final String WINDOW_TITLE = "Polygon";
public static final int POINT_SIZE = 8;
public static final int STARTING_WIDTH = 800;
public static final int STARTING_HEIGHT = 800;
public static final Color BACKGROUND = Color.BLACK;
public static final Color FOREGROUND = Color.GREEN;
private static final long serialVersionUID=1L;
// An inner class to deal with all of the drawing
private class DrawingPanel extends JPanel
{
private static final long serialVersionUID=1L;
// Build a panel with the colors that have been picked
public DrawingPanel()
{
setBackground(BACKGROUND);
setForeground(FOREGROUND);
}
// Scale the given points to fit the panel
private List<Point2D.Double> scalePoints()
{
// Find the bounding box for the points
double minX = Double.MAX_VALUE;
double minY = Double.MAX_VALUE;
double maxX = Double.MIN_VALUE;
double maxY = Double.MIN_VALUE;
for(Point2D.Double point : pointList)
{
if(point.x < minX) minX = point.x;
if(point.x > maxX) maxX = point.x;
if(point.y < minY) minY = point.y;
if(point.y > maxY) maxY = point.y;
}
// Add a 5% margin to all sides
double boxWidth = maxX - minX;
double boxHeight = maxY - minY;
minX -= 0.05 * boxWidth;
minY -= 0.05 * boxHeight;
maxX += 0.05 * boxWidth;
maxY += 0.05 * boxHeight;
boxWidth = maxX - minX;
boxHeight = maxY - minY;
// Scale all of the points to fill the view
List<Point2D.Double> result = new ArrayList<>(pointList.size());
// Create the linear transformation to scale the x and y values by
// mapping (minX, maxY) -> (0,0) and (maxX, minY) -> (width, height).
double aX = getWidth() / boxWidth;
double bX = -minX * getWidth() / boxWidth;
double aY = -getHeight() / boxHeight;
double bY = maxY * getHeight() / boxHeight;
// Apply the mapping to each point
for(Point2D.Double p : pointList)
{
result.add(new Point2D.Double(aX * p.x + bX, aY * p.y + bY));
}
return result;
}
// Draw all of our points in the given order
@Override
protected void paintComponent(Graphics g)
{
super.paintComponent(g);
Graphics2D g2d = (Graphics2D) g;
// Get the points in our view
List<Point2D.Double> scaledPoints = scalePoints();
// Draw all of the points.
for(Point2D.Double p : scaledPoints)
{
g2d.fill(new Ellipse2D.Double(p.x - POINT_SIZE / 2.0, p.y - POINT_SIZE / 2.0, POINT_SIZE, POINT_SIZE));
}
// Draw all of the lines.
for(int i = 0; i < scaledPoints.size() - 1; i++)
{
Point2D.Double start = scaledPoints.get(i);
Point2D.Double end = scaledPoints.get(i + 1);
g2d.draw(new Line2D.Double(start, end));
}
g2d.draw(new Line2D.Double(scaledPoints.get(scaledPoints.size() - 1), scaledPoints.get(0)));
}
}
// Creat a window with the given settings and a drawing panel for our polygon.
public PolygonFrame(List<Point2D.Double> pointList)
{
super(WINDOW_TITLE);
this.pointList = pointList;
setDefaultCloseOperation(WindowConstants.EXIT_ON_CLOSE);
setSize(STARTING_WIDTH, STARTING_HEIGHT);
add(new DrawingPanel());
}
}
相關文章
- SVG <polygon> 多邊形SVGGo
- HDU 6055 Regular polygon(幾何)Go
- 折線(Polyline)、多邊形(Polygon)Go
- Polygon馬蹄鏈智慧合約挖礦系統開發|Polygon馬蹄鏈專案開發Go
- 智慧合約馬蹄鏈Polygon系統開發案例丨馬蹄鏈Polygon功能開發詳情Go
- 《黑帝斯》何以當選 Polygon 年度遊戲Go遊戲
- 【IDL】 自動構建泰森多邊形(Voronoi Polygon)Go
- 《死亡之門》Polygon 前瞻:死神終究也是社畜?Go
- Polygon:2010-2019年全球遊戲排名TOP100Go遊戲
- 《Death Trash》Polygon 前瞻:對老派 RPG 的大膽嘗試Go
- 《Cozy Grove》Polygon 評測:放鬆身心,休閒護肝Go
- Polygon(matic)馬蹄鏈智慧合約互助系統開發Go
- 《Arise:一個平凡故事》Polygon:一個悲喜交加的平凡故事Go
- polygon馬蹄鏈質押DApp開發合約系統搭建GoAPP
- polygon鏈迴圈互助遊戲系統開發(FDF合約)Go遊戲
- Nintendo Switch(OLED 款式)Polygon 評測:提升巨大的「將就」產品Go
- 《公理邊緣 2》Polygon 評測:「銀河戰士」的忠實信徒Go
- 《黑相集:灰冥界》Polygon 評測:野心勃勃的恐怖佳作Go
- Polygon馬蹄鏈迴圈互助公排系統開發詳情Go
- Polygon馬蹄鏈(matic)智慧合約DApp開發系統技術GoAPP
- Polygon馬蹄鏈在以太坊上的智慧合約開發應用Go
- polygon鏈智慧合約理財分紅系統開發技術方案Go
- Polygon馬蹄鏈佛薩奇2.0系統開發(現成原始碼)Go原始碼
- 洛谷題單指南-動態規劃3-P4342 [IOI1998] Polygon動態規劃Go
- Polygon 年度遊戲之《巴巴是你》:解讀純粹的遊戲樂趣Go遊戲
- FDF迴圈遊戲互助合約開發|polygon馬蹄鏈智慧合約遊戲Go
- Polygon馬蹄鏈佛薩奇合約2.0系統開發技術分析Go
- 《殺手 3》Polygon 評測:精彩刺激的三部曲收官之作Go
- PS5 DualSense 手柄 Polygon 評測:全新的美學與人體工程學Go
- Polygon馬蹄鏈佛薩奇2.0開發|佛薩奇原始碼合約部署Go原始碼
- 《對馬島之魂》Polygon評測:絕景之下差強人意的刻板設計Go
- Polygon馬蹄鏈智慧合約公排互助系統開發技術詳情Go
- polygon鏈(matic)矩陣公排智慧合約系統開發詳細介紹Go矩陣
- 《分享同樂!瓦力歐製造》Polygon 前瞻:聯機體驗,雙倍混亂!Go
- Polygon:暴雪過去的6個月 顯示出一個正在迅速改變的公司Go
- polygon馬蹄鏈智慧合約dapp系統開發|NFT鏈遊戲搭建技術GoAPP遊戲
- 《馬力歐派對 超級巨星》Polygon 評測:史上最強《馬力歐派對》Go
- DAPP馬蹄鏈polygon智慧合約系統開發(詳細及案例)原始碼部署APPGo原始碼