Flutter中关于angle的踩坑记录

 更新时间:2022年06月26日 08:53:43   作者:hackware  
考虑到可能有很多同学还没有接触 Flutter,下面这篇文章主要给大家介绍了关于Flutter中关于angle的踩坑记录,文中通过图文介绍的非常详细,需要的朋友可以参考下

这个问题是我最近做业务开发和业余开发都遇到的,这里的 angle 指的是旋转弧度。不是旋转角度

先看一下我使用 angle 的场景吧:

图一中使用了 canvas.drawArc,传入了 startAngle 和 sweepAngle。图二也是如此。图三是 Flutter ConstraintLayout 中圆形定位的 example,我没有使用 Flutter ConstraintLayout 自带的旋转能力,而是用了 Transform.rotate,传入了 angle。Flutter ConstraintLayout 自带的对 Widget 的旋转能力用了 canvas.rotate,也传入了 angle。

我现在还没搞明白弧度和角度的对应关系,官网文档中也没有详细说明。但对于我来说,我根本就不想去关心弧度是多少,我只关心角度,这个角度的范围是 [0.0, 360.0]。以图三中的时钟为例,旋转 0.0 或 360.0 度时,指针应该指向 12,旋转 90.0 度时,指针应该指向 3,旋转 180.0 度时,指针应该指向 6,旋转 270.0 度时,指针应该指向 9。

于是我们需要将旋转弧度转换成旋转角度,我研究出的转换公式如下:

Transform.rotate:

pi + pi * (angle / 180)

canvas.rotate:

angle * pi / 180

canvas.drawArc:

startAngle = -pi / 2
sweepAngle = angle * pi / 180

看见没有,这三类旋转的转换公式都不一样。我不明白 Flutter 官方为什么要这么设计,为啥这么优秀的 Flutter 引入了这么糟糕的 API。于是我带着气愤给官方提了个 Issue,想喷一喷设计这几个 API 的哥们:

结果我被反杀了。

冷静下来之后,我决定提交一个 Pull Request 来修正这个 API。但这需要时间,因为提交 Pull Request 的周期很长,上次我提了个 bug,Oppo 的一个哥们修复了它,Pull Request 等了将近两个月才合并。

总结

到此这篇关于Flutter中关于angle踩坑的文章就介绍到这了,更多相关Flutter中angle坑内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Flutter使用JsBridge方式处理Webview与H5通信的方法

    Flutter使用JsBridge方式处理Webview与H5通信的方法

    这篇文章主要介绍了Flutter使用JsBridge方式处理Webview与H5通信的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-04-04
  • Android实现电影院选座效果

    Android实现电影院选座效果

    这篇文章主要为大家详细介绍了Android实现电影院选座效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-01-01
  • android自定义进度条渐变圆形

    android自定义进度条渐变圆形

    这篇文章主要介绍了android自定义进度条渐变圆形,需要的朋友可以来参考下
    2015-08-08
  • Android 校验email是否合法实现代码

    Android 校验email是否合法实现代码

    这篇文章主要介绍了Android 校验email是否合法实现代码的相关资料,需要的朋友可以参考下
    2017-01-01
  • Android AutoCompleteTextView自动提示文本框实例代码

    Android AutoCompleteTextView自动提示文本框实例代码

    这篇文章主要介绍了Android AutoCompleteTextView自动提示文本框实例代码的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2016-07-07
  • Android 操作excel功能实例代码

    Android 操作excel功能实例代码

    这篇文章主要介绍了Android 操作excel功能实例代码 ,需要的朋友可以参考下
    2017-01-01
  • Android实现聊天界面

    Android实现聊天界面

    这篇文章主要为大家详细介绍了Android实现聊天界面的方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-06-06
  • Android studio git创建与删除标签(Tag)的教程详解

    Android studio git创建与删除标签(Tag)的教程详解

    这篇文章主要介绍了Android studio git创建与删除标签(Tag)的教程详解,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-12-12
  • 一篇文章弄懂Android自定义viewgroup的相关难点

    一篇文章弄懂Android自定义viewgroup的相关难点

    这篇文章主要给大家介绍了关于如何通过一篇文章弄懂Android中自定义viewgroup的一些相关难点,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2018-06-06
  • Android使用SimpleDateFormat警告介绍

    Android使用SimpleDateFormat警告介绍

    大家好,本篇文章讲的是Android使用SimpleDateFormat警告介绍,感兴趣的同学快来看一看吧,希望对你起到帮助
    2021-11-11

最新评论