Android View的位置参数

所有显示到手机界面上的都属于View。
在Android中手机屏幕的左上角为坐标原点,x轴和y轴正方式为向右和向下,如图所示:
这里写图片描述

表示一个View的位置时有四个参数,分别是mLeft,mTop,mRight,mBottom,分别对应左,上,右,下顶点位置,有了这四个参数就可以确定View所处于父View中的位置了,注意这四个参数是相对位置,是以父View中左上角为原点来绘制的。如图所示:
这里写图片描述

图画的有点丑这里写图片描述

View中的左上右下位置可以通过调用getLeft()和getTop()和getRight()还有getBottom()方法来获取值。

我们可以得到宽高与坐标的关系

width = right - left;//得到View的宽
height = bottom - top;//得到View的高

从Android3.0开始,View增加了额外的几个位置参数,x、y、translationX和translationY。
x和y表示View左上角的位置,translationX和translationY表示View相对于父View的偏移位置,默认值是0,对应公式

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

需要注意的是View在属性动画移动时,left和top的值不会发生变化,它们表示原始的位置,发生改变的是translationX和translationY,x和y发生变化。

这里写图片描述

我们在平移前后打印View的位置,代码如下:


    private TextView tv;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        tv = findViewById(R.id.tv);

        findViewById(R.id.btn).setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                printViewPosition(tv);
                tv.animate().translationX(100).setDuration(300).setListener(new AnimatorListenerAdapter() {
                    @Override
                    public void onAnimationEnd(Animator animation) {
                        super.onAnimationEnd(animation);
                        printViewPosition(tv);
                    }
                }).start();
            }
        });
    }

    private static final String TAG = "View_Position:";

    private void printViewPosition(View view) {
        Log.e(TAG, "mLeft:" + view.getLeft());
        Log.e(TAG, "mTop:" + view.getTop());
        Log.e(TAG, "mRight:" + view.getRight());
        Log.e(TAG, "mBottom:" + view.getBottom());
        Log.e(TAG, "x:" + view.getX());
        Log.e(TAG, "y:" + view.getY());
        Log.e(TAG, "translationX:" + view.getTranslationX());
        Log.e(TAG, "translationY:" + view.getTranslationY());
    }

结果如下图:
这里写图片描述

可以证实上述所说,平移后left和top的值不会发生变化,它们表示原始的位置,发生改变的是translationX和translationY,x和y发生变化。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值