【Android 应用开发】Android 组件 位置坐标 属性 ( 组件位置属性 | 父容器坐标系坐标 | 窗口坐标系坐标 | 屏幕坐标系坐标 | 触摸坐标 )

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
简介: 【Android 应用开发】Android 组件 位置坐标 属性 ( 组件位置属性 | 父容器坐标系坐标 | 窗口坐标系坐标 | 屏幕坐标系坐标 | 触摸坐标 )

文章目录

I . View 坐标体系总结

II . View 组件的 left , top , right , bottom 父容器相对位置

III . View 组件的 x , y , translationX , translationY 属性

IV . View 组件 窗口坐标 属性

V . View 组件 屏幕坐标 属性

VI . View 组件的触摸位置 属性

VII . View 坐标获取 0 的解决方案



I . View 坐标体系总结


left , top , right , bottom 是组件相对于父容器的位置 , 该值一般不会改变 ;


x , y 是组件当前相对于父容器的位置 ;


translationX , translationY 分别是相对于 left , top 值的偏移大小 ;


left + translationX = x , top + translationY = y ;


窗口坐标获取 : getLocationInWindow ;


屏幕坐标获取 : getLocationOnScreen ;


触摸坐标 : x , y 触摸坐标是相对于组件的坐标 , rawX , rawY 是相对于屏幕的坐标 ;




II . View 组件的 left , top , right , bottom 父容器相对位置


1 . View 组件的基础位置 : left , top , right , bottom 是 View 组件的最基本的位置属性 , 其作用是 描述该组件相对于父容器的位置 ;



2 . 相对父容器位置 : 这里特别注意 , left , top , right , bottom 属性 , 是 相对于父容器的位置 , 不是 相对于 Activity 界面位置 , 也不是 相对于屏幕的位置 ;



3 . 属性本质 : left , top , right , bottom , 四个属性本质是坐标值 ;



4 . 父容器 坐标系 及 坐标原点 : 四属性的坐标值原点 ( 0 , 0 ) (0, 0)(0,0) 是父容器的左上角位置 , x xx 轴向右为正 , 向左为负 , y yy 轴向下为正 , 向上为负 ;



5 . 组件基础位置属性 : 组件的基础位置属性是不会改变的 ;



① left 属性 : 组件的左侧 x xx 轴坐标 , 值为左侧距离父容器左侧的长度 , 本组件左上角顶点 , 在父容器坐标系的 x xx 值 ;


② top 属性 : 组件的顶部 y yy 轴坐标 , 值为顶部距离父容器顶部的高度 , 本组件左上角顶点 , 在父容器坐标系的 y yy 值 ;


③ right 属性 : 组件的右侧 x xx 轴坐标 , 值为右侧距离父容器左侧的长度 , 本组件右下角顶点 , 在父容器坐标系的 x xx 值 ;


④ bottom 属性 : 组件的底部 y yy 轴坐标 , 值为底部距离父容器顶部的长度 , 本组件右下角顶点 , 在父容器坐标系的 y yy 值 ;




III . View 组件的 x , y , translationX , translationY 属性


1 . View 组件的当前位置 : x , y , translationX , translationY 是 View 组件的当前位置 , 其作用是 描述当前的实际位置 , 该位置也是相对于父容器的坐标 , 这里要与基础位置区分开 ;



2 . 组件当前位置 属性 : x , y 是当前的位置 , 这个位置会随着 translationX 和 translationY 的值改变而改变 ;



① x : 表示组件左上角当前的实际位置的 x 坐标 , 该坐标是父容器坐标系中的坐标 , 原点是父容器左上角位置 ;


② y : 表示组件左上角当前的实际位置的 y 坐标 , 该坐标是父容器坐标系中的坐标 , 原点是父容器左上角位置 ;



3 . 偏移位置 : translationX , translationY , 是基于基础位置 left , top 的偏移位置 ;



4 . 当前位置 和 偏移位置 的 初始值 : x 的初始值是 left , y 的初始值是 top , translationX 初始值是 0 , translationY 初始值是 0;




5 . View 组件 坐标属性之间的关系 :



① x , left , translationX 关系 :


x = l e f t + t r a n s l a t i o n X x = left + translationX

x=left+translationX


② y , top , translationY 关系 :


y = t o p + t r a n s l a t i o n Y y = top + translationY

y=top+translationY




6 . 代码分析 :



① View 组件获取 x 属性代码分析 : x 的值 , 由 left 加上 translationX 得到 ;


/**
 * The visual x position of this view, in pixels. This is equivalent to the
 * {@link #setTranslationX(float) translationX} property plus the current
 * {@link #getLeft() left} property.
 *
 * @return The visual x position of this view, in pixels.
 */
@ViewDebug.ExportedProperty(category = "drawing")
public float getX() {
    return mLeft + getTranslationX();
}
1


② View 组件获取 y 属性代码分析 : y 的值 , 由 top 加上 translationY 得到 ;


/**
 * The visual y position of this view, in pixels. This is equivalent to the
 * {@link #setTranslationY(float) translationY} property plus the current
 * {@link #getTop() top} property.
 *
 * @return The visual y position of this view, in pixels.
 */
@ViewDebug.ExportedProperty(category = "drawing")
public float getY() {
    return mTop + getTranslationY();
}



IV . View 组件 窗口坐标 属性


1 . 获取 View 组件窗口坐标 : 这里的窗口指的是 Activity 窗口 ;



① 所在坐标系 : 坐标系的原点 ( 0 , 0 ) (0 ,0)(0,0) 是 Activity 窗口的左上角位置 ;


② 区分屏幕坐标 : Activity 窗口上还有一个状态栏 , 这里要与屏幕坐标系区分开 ;


③ 获取方法 : 调用 View 组件对象的 getLocationInWindow ( ) 方法 , 数组 0 索引是 x 坐标 , 数组 1 索引是 y 坐标 ;


int[] array = new int[2];
surfaceView.getLocationInWindow(array);



V . View 组件 屏幕坐标 属性


1 . 获取 View 组件屏幕坐标 : 这里的屏幕指的是手机屏幕 ;



① 所在坐标系 : 坐标系的原点 ( 0 , 0 ) (0 ,0)(0,0) 是 手机屏幕的左上角位置 ;


② 获取方法 : 调用 View 组件对象的 getLocationOnScreen ( ) 方法 , 数组 0 索引是 x 坐标 , 数组 1 索引是 y 坐标 ;


int[] array = new int[2];
surfaceView.getLocationOnScreen(array);



VI . View 组件的触摸位置 属性


View 组件的触摸事件的位置属性 :



① x , y 相对于组件坐标 : 当触摸组件时 , 从 MotionEvent 事件中获取的 x , y 坐标是 相对于本组件的坐标 , 即坐标系的原点 ( 0 , 0 ) ( 0, 0 )(0,0) 是该组件的左上角位置 ;


② rawX , rawY 相对于屏幕坐标 : 从 MotionEvent 事件中获取的 rawX , rawY 坐标 , 是当前触摸点相对于屏幕的坐标 , 即坐标系的原点 ( 0 , 0 ) (0, 0)(0,0) 是屏幕的左上角位置 ;




VII . View 坐标获取 0 的解决方案


1 . 问题描述 : 在获取组件 位置 , 宽高 时 , 经常遇到获取组件的值为 0 00 的情况 , 这是因为该组件还没有绘制完成 ;



2 . 解决方案 : 获取 ViewTreeObserver , 监听布局树的绘制情况 , 组件绘制时 , 需要测量 ( Measure ) , 摆放 ( Layout ) , 绘制 ( Draw ) , 此时监听的是摆放操作 , 摆放完毕后 , 就可以获取组件的坐标和大小属性 ;



3 . 监听 Layout 代码 :


surfaceView.getViewTreeObserver().addOnGlobalLayoutListener(new ViewTreeObserver.OnGlobalLayoutListener() {
    @Override
    public void onGlobalLayout() {
        //此时可以获取 View 的坐标和大小 , 不为 0
    }
});



目录
相关文章
|
3月前
|
存储 XML 开发工具
探索安卓应用开发:从基础到进阶
在这篇文章中,我们将一起踏上安卓应用开发的旅程。不论你是编程新手还是希望提升技能的开发者,这里都有你需要的东西。我们会从最基础的概念开始,逐步深入到更复杂的主题。文章将涵盖开发环境设置、用户界面设计、数据处理以及性能优化等方面。通过理论与实践的结合,你将能够构建出既美观又高效的安卓应用。让我们一起开启这段技术之旅吧!
|
3月前
|
Android开发 Swift iOS开发
深入探索iOS与Android操作系统的架构差异及其对应用开发的影响
在当今数字化时代,移动设备已经成为我们日常生活和工作不可或缺的一部分。其中,iOS和Android作为全球最流行的两大移动操作系统,各自拥有独特的系统架构和设计理念。本文将深入探讨iOS与Android的系统架构差异,并分析这些差异如何影响应用开发者的开发策略和用户体验设计。通过对两者的比较,我们可以更好地理解它们各自的优势和局限性,从而为开发者提供有价值的见解,帮助他们在这两个平台上开发出更高效、更符合用户需求的应用。
|
2月前
|
XML 搜索推荐 前端开发
安卓开发中的自定义视图:打造个性化UI组件
在安卓应用开发中,自定义视图是一种强大的工具,它允许开发者创造独一无二的用户界面元素,从而提升应用的外观和用户体验。本文将通过一个简单的自定义视图示例,引导你了解如何在安卓项目中实现自定义组件,并探讨其背后的技术原理。我们将从基础的View类讲起,逐步深入到绘图、事件处理以及性能优化等方面。无论你是初学者还是有经验的开发者,这篇文章都将为你提供有价值的见解和技巧。
|
2月前
|
搜索推荐 Android开发 开发者
安卓应用开发中的自定义控件实践
在安卓应用开发的广阔天地中,自定义控件如同璀璨的星辰,点亮了用户界面设计的夜空。它们不仅丰富了交互体验,更赋予了应用独特的个性。本文将带你领略自定义控件的魅力,从基础概念到实际应用,一步步揭示其背后的原理与技术细节。我们将通过一个简单的例子——打造一个具有独特动画效果的按钮,来展现自定义控件的强大功能和灵活性。无论你是初学者还是资深开发者,这篇文章都将为你打开一扇通往更高阶UI设计的大门。
|
3月前
|
缓存 监控 前端开发
探索Android应用开发之旅:从新手到专家
【10月更文挑战第42天】本文将带你踏上Android应用开发的旅程,无论你是初学者还是有经验的开发者。我们将一起探索如何从零开始创建你的第一个Android应用,并逐步深入到更高级的主题,如自定义视图、网络编程和性能优化。通过实际示例和清晰的解释,你将学会如何构建高效、吸引人的Android应用。让我们一起开启这段激动人心的旅程吧!
|
3月前
|
开发框架 前端开发 Android开发
探索安卓和iOS应用开发中的跨平台解决方案
【10月更文挑战第42天】在移动应用开发的广阔天地中,安卓和iOS系统如同两座巍峨的山峰,分别占据着半壁江山。开发者们在这两座山峰之间穿梭,努力寻找一种既能节省资源又能提高效率的跨平台开发方案。本文将带你走进跨平台开发的世界,探讨各种解决方案的优势与局限,并分享一些实用的代码示例,助你在应用开发的道路上更加游刃有余。
|
XML Android开发 数据格式
Android中利用shape属性自定义设置Button按钮
Android中利用shape属性自定义设置Button按钮
292 0
|
Android开发
Android 获取include标签中的控件属性并设置事件
Android 获取include标签中的控件属性并设置事件
208 0
|
Java 开发工具 Android开发