前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >android uiautomator一个画心形图案的方法--代码的浪漫

android uiautomator一个画心形图案的方法--代码的浪漫

作者头像
FunTester
发布2019-08-22 16:46:49
8020
发布2019-08-22 16:46:49
举报
文章被收录于专栏:FunTesterFunTester

本人在uiautomator学习math方法的时候,突发奇想想画一个心形的图案,试了几次终于成功了。分享出来,请大神指正。其中主要用到了数学上心的极坐标方程式,然后通过math类的一些方法进行转化,使用swipe方法在手机屏幕上滑动。手机屏幕坐标点(x,y)与数学上的坐标系有些差异,需要转换。

代码语言:javascript
复制
    public void heart(int x, int y, int r) {//画心形的方法
        double d = (double) (Math.PI / 30);
        double[] angle = new double[61];//设置角度差
        for (int i = 0; i < 61; i++) {
            angle[i] = i * d;
        }
//建立一个角度差double数组
        double[] ox = new double[61];
        for (int i = 0; i < 61; i++) {
            ox[i] = r * (2 * Math.cos(angle[i]) - Math.cos(2 * angle[i]));
        }
//计算x坐标
        double[] oy = new double[61];
        for (int i = 0; i < 61; i++) {
            oy[i] = r * (2 * Math.sin(angle[i]) - Math.sin(2 * angle[i]));
        }
//计算y坐标
        Point[] heart = new Point[61];
        for (int i = 0; i < 61; i++) {
            heart[i] = new Point();
            heart[i].x = (int) oy[i] + x;
            heart[i].y = -(int) ox[i] + y;
        }
//简历一个点数组,这里坐标一定要转化一下,不然是倒着的心形
        getUiDevice().swipe(heart, 2);
    }

x和y表示心中心坐标,r是半径,都是参数。这个方法和画圆类似,不过改了一下数学方程,旋转了一下坐标。

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2019-08-17,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 FunTester 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档