From a3b29090a48fc6245b76907c3b2e10c5aa920286 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E5=A5=A5=E5=88=A9=E5=A5=A5=E5=97=B7=E5=97=B7=E5=8F=AB?= Date: Wed, 12 Oct 2022 22:22:59 +0800 Subject: [PATCH 1/2] =?UTF-8?q?=E6=B7=BB=E5=8A=A0=E7=AB=96=E7=9B=B4?= =?UTF-8?q?=E5=9D=90=E6=A0=87=E5=92=8Cpoco=E5=9D=90=E6=A0=87=E8=BD=AC?= =?UTF-8?q?=E6=8D=A2=E5=99=A8?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../driver/common/tool/PocoXYTransformer.java | 78 +++++++++++++++++++ .../common/tool/PocoXYTransformerTest.java | 34 ++++++++ 2 files changed, 112 insertions(+) create mode 100644 src/main/java/org/cloud/sonic/driver/common/tool/PocoXYTransformer.java create mode 100644 src/test/java/org/cloud/sonic/driver/common/tool/PocoXYTransformerTest.java diff --git a/src/main/java/org/cloud/sonic/driver/common/tool/PocoXYTransformer.java b/src/main/java/org/cloud/sonic/driver/common/tool/PocoXYTransformer.java new file mode 100644 index 0000000..99a71f0 --- /dev/null +++ b/src/main/java/org/cloud/sonic/driver/common/tool/PocoXYTransformer.java @@ -0,0 +1,78 @@ +/* + * Copyright (C) [SonicCloudOrg] Sonic Project + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + */ +package org.cloud.sonic.driver.common.tool; + +/*** + * poco coordinate system conversion and vertical coordinate system converter + */ +public class PocoXYTransformer { + /** + * Convert adb vertical coordinates to poco coordinate system coordinates according to different directions + * + * @param x x poco coordinate point x + * @param y y poco coordinate point y + * @param w w ScreenWidth + * @param h h ScreenHeight + * @param orientation The device orientation, based on the vertical direction of the mobile device, + * rotate 90° counterclockwise, orientation=90, 180° counterclockwise, orientation=180, + * and so on + * @return {@link int[]} + */ + public static double[] PocoTransformerVertical(double x, double y, double w, double h, Integer orientation) { + if (orientation == 90) { + double temp = x; + x = w - y; + y = temp; + } else if (orientation == 180) { + x = w - x; + y = h - y; + } else if (orientation == 270) { + double temp = x; + x = y; + y = h - temp; + } + return new double[]{x, y}; + } + + /** + * Convert the coordinate system of poco to the coordinates in the adb vertical coordinate system + * + * @param x x vertical coordinate x + * @param y y vertical coordinate y + * @param w w ScreenWidth + * @param h h ScreenHeight + * @param orientation The device orientation, based on the vertical direction of the mobile device, + * rotate 90° counterclockwise, orientation=90, 180° counterclockwise, orientation=180, + * and so on + * @return {@link int[]} + */ + public static double[] VerticalTransformerPoco(double x, double y, double w, double h, Integer orientation) { + if (orientation == 90) { + double temp = x; + x = y; + y = w - temp; + } else if (orientation == 180) { + x = w - x; + y = h - y; + } else if (orientation == 270) { + double temp = x; + x = h - y; + y = temp; + } + return new double[]{x, y}; + } +} diff --git a/src/test/java/org/cloud/sonic/driver/common/tool/PocoXYTransformerTest.java b/src/test/java/org/cloud/sonic/driver/common/tool/PocoXYTransformerTest.java new file mode 100644 index 0000000..738fa6f --- /dev/null +++ b/src/test/java/org/cloud/sonic/driver/common/tool/PocoXYTransformerTest.java @@ -0,0 +1,34 @@ +package org.cloud.sonic.driver.common.tool; + +import org.junit.Assert; +import org.junit.Test; + +import javax.swing.plaf.synth.SynthOptionPaneUI; + +public class PocoXYTransformerTest { + double width = 100, height = 1000; + + @Test + public void testOriToUP() { + double pocoX = 100, pocoY = 50; + double[]result = PocoXYTransformer.PocoTransformerVertical(pocoX,pocoY,width,height,270); + System.out.printf("x:%s,y:%s",result[0],result[1]); + System.out.println(); + + result = PocoXYTransformer.PocoTransformerVertical(pocoX,pocoY,width,height,90); + System.out.printf("x:%s,y:%s",result[0],result[1]); + System.out.println(); + } + + @Test + public void testUPToOri() { + double upx = 50,upy = 100; + double[]result = PocoXYTransformer.VerticalTransformerPoco(upx,upy,width,height,270); + System.out.printf("x:%s,y:%s",result[0],result[1]); + System.out.println(); + + result = PocoXYTransformer.VerticalTransformerPoco(upx,upy,width,height,90); + System.out.printf("x:%s,y:%s",result[0],result[1]); + System.out.println(); + } +} From 5667612177d4b2fc77706319455d39e0d75005a5 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E5=A5=A5=E5=88=A9=E5=97=B7=E5=97=B7=E5=97=B7=E5=8F=AB?= Date: Fri, 14 Oct 2022 17:02:50 +0800 Subject: [PATCH 2/2] add coordinate system conversion assertions --- .../sonic/driver/common/tool/PocoXYTransformerTest.java | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/src/test/java/org/cloud/sonic/driver/common/tool/PocoXYTransformerTest.java b/src/test/java/org/cloud/sonic/driver/common/tool/PocoXYTransformerTest.java index 738fa6f..c7be21e 100644 --- a/src/test/java/org/cloud/sonic/driver/common/tool/PocoXYTransformerTest.java +++ b/src/test/java/org/cloud/sonic/driver/common/tool/PocoXYTransformerTest.java @@ -12,10 +12,14 @@ public class PocoXYTransformerTest { public void testOriToUP() { double pocoX = 100, pocoY = 50; double[]result = PocoXYTransformer.PocoTransformerVertical(pocoX,pocoY,width,height,270); + Assert.assertEquals(result[0],pocoY,0); + Assert.assertEquals(result[1],height-pocoX,0); System.out.printf("x:%s,y:%s",result[0],result[1]); System.out.println(); result = PocoXYTransformer.PocoTransformerVertical(pocoX,pocoY,width,height,90); + Assert.assertEquals(result[0],pocoY,0); + Assert.assertEquals(result[1],pocoX,0); System.out.printf("x:%s,y:%s",result[0],result[1]); System.out.println(); } @@ -24,10 +28,14 @@ public void testOriToUP() { public void testUPToOri() { double upx = 50,upy = 100; double[]result = PocoXYTransformer.VerticalTransformerPoco(upx,upy,width,height,270); + Assert.assertEquals(result[0],height-upy,0); + Assert.assertEquals(result[1],upx,0); System.out.printf("x:%s,y:%s",result[0],result[1]); System.out.println(); result = PocoXYTransformer.VerticalTransformerPoco(upx,upy,width,height,90); + Assert.assertEquals(result[0],upy,0); + Assert.assertEquals(result[1],upx,0); System.out.printf("x:%s,y:%s",result[0],result[1]); System.out.println(); }