Web和Android的渐变角度区别

从蓝湖(或者其他设计稿)里复制一个渐变的 angle 值,贴到 Android 的 XML 里,几乎每次方向都不对。然后我就开始靠猜 + 调试,一个一个改角度,调半天才对上方向。

最近又开始做 Web 前端,渐变上 Web 和 Android 的规则还不一样,搞得我更头大了。所以我这次下定决心,彻底搞清楚他们各自的角度系统到底怎么一回事。下面是研究结论


Android 的渐变角度 = 数学坐标系的角度

可以理解为跟三角函数里的角度一样:

  • 0deg从左往右
  • 90deg从下往上
  • 180deg从右往左
  • 270deg从上往下

顺时针旋转,起点是左边 → 就是数学坐标的 x 轴方向。


Web 的渐变角度 = 时钟方向的角度

CSS 的渐变是这样算的:

  • 0deg从下往上
  • 90deg从左往右
  • 180deg从上往下
  • 270deg从右往左

简单记:时钟指针指向的方向就是渐变的方向


顺带一提:Web 和 Android 的 margin/padding 顺序也不一样

CSS 中:

css 复制代码
margin: 10px 20px 30px 40px;
/* 顺序是:上 右 下 左(顺时针)*/

而 Android 的顺序是:

ini 复制代码
android:padding="40dp 10dp 20dp 30dp"
/* 顺序是:左 上 右 )*/
  • Web 也是按照时钟顺序来的
  • Android 这个可以理解为屏幕坐标系(左上角为原点)

总结

  • Android 的渐变角度参考数学坐标系(0度是从左到右 → )
  • Web 的渐变角度参考时钟方向(0度是从下从上 ↑ )
相关推荐
Huntto30 分钟前
在Android中使用libpng
android
雨白2 小时前
Android 自定义 View:彻底搞懂 Xfermode 与官方文档陷阱
android
_小马快跑_3 小时前
从VSync心跳到SurfaceFlinger合成:拆解 Choreographer与Display刷新流程
android
_小马快跑_3 小时前
Android | 视图渲染:从invalidate()到屏幕刷新的链路解析
android
Monkey-旭5 小时前
Android 定位技术全解析:从基础实现到精准优化
android·java·kotlin·地图·定位
树獭非懒7 小时前
Android 媒体篇|吃透 MediaSession 与 MediaController
android·架构
一起搞IT吧8 小时前
高通Camx hal进程CSLAcquireDeviceHW crash问题分析一:CAM-ICP FW response timeout导致
android·图像处理·数码相机
南风里8 小时前
Android Studio下载gradle文件很慢的捷径之路
android·ide·android studio
fatsheep洋12 小时前
文件上传 --- uploadlabs靶场
android
雨白20 小时前
Android 自定义 View:从绘制基础到实战仪表盘与饼图
android