博客
关于我
Android 获取子 View 的位置及坐标的方式
阅读量:592 次
发布时间:2019-03-11

本文共 2626 字,大约阅读时间需要 8 分钟。

一、View

1.1、View 概述

视图 (View) 是一个容器,专门负责布局。表现为显示在屏幕上的各种视图,如 TextView、LinearLayout 等。

1.2、View 分类

View 主要分为两类,具体如下表格所示:

类别 示例 特点
单一视图 即一个 View,如 TextView、EditText 不包含子View
视图组 即多个 View 组成的 ViewGroup,如 RelativeLayout 包含子View

1.3、View 类简介

  1. View 类是 Android 中各种组件的基类;

  2. View 的构造函数有四个,具体如下所示:

    public View(Context context) {}public View(Context context, @Nullable AttributeSet attrs) {    this(context, attrs, 0);}public View(Context context, @Nullable AttributeSet attrs, int defStyleAttr) {    this(context, attrs, defStyleAttr, 0);}public View(Context context, @Nullable AttributeSet attrs, int defStyleAttr, int defStyleRes) {}
  3. 源码中 View 的构造函数

通过源码的注释我们可以看出:

  1. 如果 View 是在 Java 代码里面 new 的,则调用第一个构造函数–>View(Context);
  2. 如果 View 是在 xml 里声明的,则调用第二个构造函数–>View(Context, AttributeSet)。

二、Android 坐标系

Android 坐标系和数学上的坐标系是不一样的,定义如下:

  • 屏幕的左上角为坐标原点。
  • 向右为 x 轴增大方向。
  • 向下为 y 轴增大方向。

具体如下图所示:

三、View 的位置

View 的位置是相对于父控件而言的,由 4 个顶点确定,如下图 A、B、C、D 所示:

确定 View 的位置有四个参数,分别是 Top、Bottom、Left、Right:

  • Top:子 View 左上角距父 View 顶部的距离。
  • Left:子 View 左上角距父 View 左侧的距离。
  • Bottom:子 View 右下角距父 View 顶部的距离。
  • Right:子 View 右下角距父 View 左侧的距离

具体如下图所示:

四、获取 View 位置的方式

View 的位置是通过 getTop()、getLeft()、getBottom()、getRight() 函数进行获取的。

这里我写了一个小例子来演示这四个方法,如下所示:(获取内部子 View 的位置)

因为是为了演示 View 的位置,所有我这里用绝对布局,并且大小的单位都是用 px,具体布局如下所示:

我们现在用四个方法来获取一下 View 的位置,具体代码如下所示:

public class CoordinateActivity extends AppCompatActivity {    private View mView;    @Override    protected void onCreate(Bundle savedInstanceState) {        super.onCreate(savedInstanceState);        setContentView(R.layout.activity_coordinate);        rl1 = findViewById(R.id.rl_1);        mView = findViewById(R.id.view);    }    @Override    protected void onResume() {        super.onResume();        new Handler().postDelayed(new Runnable() {            @Override            public void run() {                MyLogUtils.i(mView.getTop() + "--Top --mView");                MyLogUtils.i(mView.getBottom() + "--Bottom --mView");                MyLogUtils.i(mView.getLeft() + "--Left --mView");                MyLogUtils.i(mView.getRight() + "--Right --mView");                MyLogUtils.i(mView.getX() + "--X --mView");                MyLogUtils.i(mView.getY() + "--Y --mView");            }        }, 200);    }}

打印结果如下所示:

最外层紫色的 View 的坐标是(200,200),大小是 600px,在它内部,有一个大小为 300px 的子 View 位于其中心位置,所以上述打印结果是完全正确的。

注意:

  1. 我这里调用 getTop() 等方法是在 onResume() 里面,并且延时了 200ms,是因为如果不延迟直接调用,会出现 View 还没有绘制完,所以获取到的位置都是 0,所以就用最简单的延迟处理了一下(这里的处理方法有很多,比如 View.post() 等);
  2. getX() 和 getY() 的意思是获取子 View 相对父容器的坐标,所以这里结果都是 150。

最后

小编在这将自己收集的一份《Android核心知识汇总》分享给大家,希望能对大家有所帮助。请点击获取。 喜欢本文的话,不妨顺手给我点个小赞、评论区留言或者转发支持一下呗~

转载地址:http://isxtz.baihongyu.com/

你可能感兴趣的文章
NIFI1.21.0_NIFI和hadoop蹦了_200G集群磁盘又满了_Jps看不到进程了_Unable to write in /tmp. Aborting----大数据之Nifi工作笔记0052
查看>>
NIFI1.21.0_Postgresql和Mysql同时指定库_指定多表_全量同步到Mysql数据库以及Hbase数据库中---大数据之Nifi工作笔记0060
查看>>
NIFI1.21.0最新版本安装_连接phoenix_单机版_Https登录_什么都没改换了最新版本的NIFI可以连接了_气人_实现插入数据到Hbase_实际操作---大数据之Nifi工作笔记0050
查看>>
NIFI1.21.0最新版本安装_配置使用HTTP登录_默认是用HTTPS登录的_Https登录需要输入用户名密码_HTTP不需要---大数据之Nifi工作笔记0051
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增删改数据分发及删除数据实时同步_通过分页解决变更记录过大问题_02----大数据之Nifi工作笔记0054
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增加修改实时同步_使用JsonPath及自定义Python脚本_03---大数据之Nifi工作笔记0055
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_插入修改删除增量数据实时同步_通过分页解决变更记录过大问题_01----大数据之Nifi工作笔记0053
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表或全表增量同步_实现指定整库同步_或指定数据表同步配置_04---大数据之Nifi工作笔记0056
查看>>
NIFI1.23.2_最新版_性能优化通用_技巧积累_使用NIFI表达式过滤表_随时更新---大数据之Nifi工作笔记0063
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现update数据实时同步_实际操作05---大数据之Nifi工作笔记0044
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现数据实时delete同步_实际操作04---大数据之Nifi工作笔记0043
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_生成插入Sql语句_实际操作02---大数据之Nifi工作笔记0041
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_03_来吧用NIFI实现_数据分页获取功能---大数据之Nifi工作笔记0038
查看>>