From cb0ee1254500db12525f1288c47d7499677d4eb7 Mon Sep 17 00:00:00 2001 From: lsh <lsh@163.com> Date: 星期三, 23 十月 2024 16:05:23 +0800 Subject: [PATCH] * --- src/main/java/com/zy/asrs/utils/Utils.java | 79 +++++++++++++++++++++++++++++++++++++++ 1 files changed, 79 insertions(+), 0 deletions(-) diff --git a/src/main/java/com/zy/asrs/utils/Utils.java b/src/main/java/com/zy/asrs/utils/Utils.java index 0f8c14a..fd24456 100644 --- a/src/main/java/com/zy/asrs/utils/Utils.java +++ b/src/main/java/com/zy/asrs/utils/Utils.java @@ -52,5 +52,84 @@ throw new RuntimeException("搴撲綅瑙f瀽寮傚父"); } + public static void main(String[] args) { + double[] lev = RingThroughXY(183.0, 1830.0); + System.out.printf("鐐圭殑鍧愭爣涓�: (%.2f, %.2f)%n", lev[0], lev[1]); + } + + public static double[] RingThroughXY(double a,double b) { +// while (true){ +// if (b>=a){ +// b=b-a; +// }else { +// break; +// } +// } + double l = b/a; + // 宸茬煡鏁版嵁 + double circumference = 314; // 鍦嗗懆闀� + double arcLength = 314*l; // 缁欏嚭鐨勫姬闀� + + // 璁$畻鍦嗙殑鍗婂緞 + double radius = circumference / (2 * Math.PI); + + // 鍦嗗績鍧愭爣 + double centerX = 50; + double centerY = 50; + + // 姹傚姬搴� + double theta = arcLength / radius; + + // 璁$畻鐐圭殑鍧愭爣 + double x = 100-(centerX + radius * Math.cos(theta)); + double y = centerY + radius * Math.sin(theta); + + return new double[]{x,y}; + } + + public static double[] RingThroughXYRgv(double a,double b) { + double l = b / a; + + // 鍦嗙殑宸茬煡鍙傛暟 + double radius = 47.52; // 鍗婂緞涓�48 +// double circumference = ; // 璁$畻鍦嗗懆闀� + double arcLength = 2 * Math.PI * radius * l; // 缁欏嚭鐨勫姬闀� + + // 鍦嗗績鍧愭爣 + double centerX = 50; + double centerY = 50; + + // 姹傚姬搴� + double theta = arcLength / radius; + + // 璁$畻鐐圭殑鍧愭爣 + double x = 100-(centerX + radius * Math.cos(theta)); + double y = centerY + radius * Math.sin(theta); + + return new double[]{x, y}; + } + + public static double[] RingThroughXYSta(double a,double b) { + double l = b / a; + + // 鍦嗙殑宸茬煡鍙傛暟 + double radius = 50; // 鍗婂緞涓�48 +// double circumference = ; // 璁$畻鍦嗗懆闀� + double arcLength = 2 * Math.PI * radius * l; // 缁欏嚭鐨勫姬闀� + + // 鍦嗗績鍧愭爣 + double centerX = 55; + double centerY = 45; + + // 姹傚姬搴� + double theta = arcLength / radius; + + // 璁$畻鐐圭殑鍧愭爣 + double x = 100-(centerX + radius * Math.cos(theta)); + double y = centerY + radius * Math.sin(theta); + + return new double[]{x, y}; + } + } -- Gitblit v1.9.1