100字范文,内容丰富有趣,生活中的好帮手!
100字范文 > android控件向内弧度_安卓自定义 View 基础:坐标系 角度弧度 颜色

android控件向内弧度_安卓自定义 View 基础:坐标系 角度弧度 颜色

时间:2021-12-02 17:39:29

相关推荐

android控件向内弧度_安卓自定义 View 基础:坐标系 角度弧度 颜色

安卓自定义View基础 - 坐标系

一.屏幕坐标系和数学坐标系的区别

由于移动设备一般定义屏幕左上角为坐标原点,向右为x轴增大方向,向下为y轴增大方向, 所以在手机屏幕上的坐标系与数学中常见的坐标系是稍微有点差别的,详情如下:

(PS:其中的∠a 是对应的,注意y轴方向!)

实际屏幕上的默认坐标系如下:

PS: 假设其中棕色部分为手机屏幕

二.View的坐标系

注意:View的坐标系统是相对于父控件而言的.

getTop(); //获取子View左上角距父View顶部的距离

getLeft(); //获取子View左上角距父View左侧的距离

getBottom(); //获取子View右下角距父View顶部的距离

getRight(); //获取子View右下角距父View左侧的距离

如下图所示:

三.MotionEvent中 get 和 getRaw 的区别

event.getX(); //触摸点相对于其所在组件坐标系的坐标

event.getY();

event.getRawX(); //触摸点相对于屏幕默认坐标系的坐标

event.getRawY();

如下图所示:

PS:其中相同颜色的内容是对应的,其中为了显示方便,蓝色箭头向左稍微偏移了一点.

四.核心要点

序号

要点

1

在数学中常见的坐标系与屏幕默认坐标系的差别

2

View的坐标系是相对于父控件而言的

3

MotionEvent中get和getRaw的区别

安卓自定义View基础-角度与弧度

安卓中角度(angle)与弧度(radian)的有关问题。

一.前言

1.为什么讲这个?

在我们自定义View,尤其是制作一些复杂炫酷的效果的时候,实际上是将一些简单的东西通过数学上精密的计算组合到一起形成的效果。

这其中可能会涉及到画布的相关操作(旋转),以及一些正余弦函数的计算等,这些内容就会用到一些角度、弧度相关的知识。

2.为什么对角的描述存在角度与弧度两种单位?

简单来说就是为了方便,为了精确描述一个角的大小引入了角度与弧度的概念。

由于两者进制是不同的(角度是60进制,弧度是10进制),在合适的地方使用合适的单位来描述会更加方便。

例如: 角度是60进位制,遇到30°6′这样的角,应该转化为10进制的30.1°。但弧度就不需要,因为弧度本身就是十进制的实数。

二.角度与弧度的定义

角度和弧度一样都是描述角的一种度量单位,下面是它们的定义:

名称

定义

角度

两条射线从圆心向圆周射出,形成一个夹角和夹角正对的一段弧。当这段弧长正好等于圆周长的360分之一时,两条射线的夹角的大小为1度.

弧度

两条射线从圆心向圆周射出,形成一个夹角和夹角正对的一段弧。当这段弧长正好等于圆的半径时,两条射线的夹角大小为1弧度.

如图:

三.角度和弧度的换算关系

圆一周对应的角度为360度(角度),对应的弧度为2π弧度。故得等价关系:

360(角度) = 2π(弧度) ==> 180(角度) = π(弧度)

由等价关系可得如下换算公式:

rad 是弧度, deg 是角度

公式

例子

rad = deg x π / 180

2π = 360 x π / 180

deg = rad x 180 / π

360 = 2π x 180 / π

维基百科的公式:

rad 是弧度, deg 是角度

四.一些细节问题

由于默认屏幕坐标系和常见数学坐标系的小差别,所以在角上必然也会存在一些区别,例如:

在常见的数学坐标系中角度增大方向为逆时针;

在默认的屏幕坐标系中角度增大方向为顺时针。

安卓自定义View基础-颜色

简要介绍安卓中的颜色相关内容,包括颜色的定义,创建颜色的几种方式,以及颜色的混合模式等。

一.简单介绍颜色

安卓支持的颜色模式:

颜色模式

备注

ARGB8888

四通道高精度(32位)

ARGB4444

四通道低精度(16位)

RGB565

屏幕默认模式(16位)

Alpha8

仅有透明通道(8位)

PS:其中字母表示通道类型,数值表示该类型用多少位二进制来描述。如ARGB8888则表示有四个通道(ARGB),每个对应的通道均用8位来描述。

注意:我们常用的是ARGB8888和ARGB4444,而在所有的安卓设备屏幕上默认的模式都是RGB565,请留意这一点。

以ARGB8888为例介绍颜色定义:

类型

解释

0(0x00)

255(0xff)

A(Alpha)

透明度

透明

不透明

R(Red)

红色

无色

红色

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。