localPosition:表示的是子物体的pivot相对于父物体RectTransform的中心点pivot的相对坐标。
anchoredPosition3D:表示的是子物体的pivot相对于锚点anchor的相对坐标。
anchorMax:右上方锚点位置(所在位置与父物体RectTransform宽度和长度的比例)
anchorMin:左下方锚点位置(所在位置与父物体RectTransform宽度和长度的比例)
offsetMax:从右上方锚点位置到UI右上方坐标的偏移向量
offsetMin:从左下方锚点位置到UI左下方坐标的偏移向量
sizeDelta:offsetMax - offsetMin
rect:RectTransform中的属性,不与UI元素所在的位置有关
SetSizeWithCurrentAnchors(Animations.Axis axis, float size):可以通过直接设置rect中的width和height值来改变UI元素的大小。
SetInsetAndSizeFromParentEdge(RectTransform.Edge edge, float inset, float size):根据父物体的Edge(某一边)去布局
写了个编辑器拓展,选中gameObject,按快捷键会输出一些RectTransform的信息。
using UnityEngine;
using UnityEditor;
public class TestEditor
{
[MenuItem("MyTool/ShowRectTransform", true)]
private static bool Validate()
{
if (Selection.objects.Length > 0)
return true;
else
return false;
}
[MenuItem("MyTool/ShowRectTransform %_q", false)]
private static void MyToolShowRectTransform()
{
GameObject go;
//Selection.objects 返回场景或者Project中选择的多个对象
foreach (Object item in Selection.objects)
{
go = ((GameObject)item);
RectTransform rect = go.GetComponent<RectTransform>();
Debug.Log(go.name + ".localPosition=====" + rect.localPosition);
Debug.Log(go.name + ".anchoredPosition3D=====" + rect.anchoredPosition3D);
Debug.Log(go.name + ".anchorMax=====" + rect.anchorMax);
Debug.Log(go.name + ".anchorMin=====" + rect.anchorMin);
Debug.Log(go.name + ".offsetMax=====" + rect.offsetMax);
Debug.Log(go.name + ".offsetMin=====" + rect.offsetMin);
Debug.Log(go.name + ".sizeDelta=====" + rect.sizeDelta);
Debug.Log(go.name + ".rect=====" + rect.rect);
//rect.SetSizeWithCurrentAnchors(RectTransform.Axis.Horizontal, 100);
//rect.SetInsetAndSizeFromParentEdge(RectTransform.Edge.Right, 0, 622);
}
}
}
1. localPosition与anchoredPosition3D(anchoredPosition)
localPosition表示的是子物体的pivot相对于父物体RectTransform的中心点pivot的相对坐标。
anchoredPosition3D表示的是子物体的pivot相对于锚点anchor的相对坐标。
也就是说,当锚点与父物体RectTransform的中心点重合时,localPosition与anchoredPosition相当。
data:image/s3,"s3://crabby-images/f4269/f42696ae8971efc88ed63a5f785cf654c13d5fcf" alt=""
data:image/s3,"s3://crabby-images/9b562/9b5626d420d38c80dd2208bd4a93d67f4d1c7194" alt=""
data:image/s3,"s3://crabby-images/2dd98/2dd9886ce9c8563da30a9dc5c4773f4286d3143d" alt=""
可以看到两者相等,如果移动锚点位置,则只改变anchoredPosition。
如果将锚点打开,则anchoredPosition为中心点到锚点正中央的位置相对坐标。
2. offsetMax与offsetMin
offsetMax:从右上方锚点位置到UI右上方坐标的偏移向量
offsetMin:从左下方锚点位置到UI左下方坐标的偏移向量
当锚点没有打开时:
data:image/s3,"s3://crabby-images/d0fc2/d0fc282604bdea821ea8912c10e76ae4d09477d8" alt=""
data:image/s3,"s3://crabby-images/97ae8/97ae8e82a9f19fc8ec0ecc9422f9924b80bac2f5" alt=""
当锚点打开时:
data:image/s3,"s3://crabby-images/221e4/221e4904875686d1545f82714e3fe83da4213368" alt=""
data:image/s3,"s3://crabby-images/17a08/17a08a5ce55d977b80e0ab2005e0c622ccc24a1e" alt=""
offsetMax与offsetMin可以修改,当锚点打开到最大时,可以用来动态调整子物体到边界的距离。
3.sizeDelta
sizeDelta=offsetMax - offsetMin
在锚点没打开的时候,就是子物体的长和宽,可以用来动态修改长宽。
data:image/s3,"s3://crabby-images/3b30c/3b30c2fc4efb0b677bd8161b5e221c9a0bfc6112" alt=""
打开的时候,就是锚点的框框长宽跟子物体Rect长宽的差值。
4. rect(只读)
rect中的属性,不与UI元素所在的位置有关,只和其自身属性相关,所以其中的rect.width和rect.height属性就可以让我们在任何情况下取得子物体的大小,而rect.x和rect.y表示的是以Pivot为原点,UI元素左下角的坐标:
data:image/s3,"s3://crabby-images/80e19/80e1903f9e1359263765ff3a71f941d4397a41b5" alt=""
data:image/s3,"s3://crabby-images/bc489/bc489d04d7f85248ea6f5284b1cfc06068c54be8" alt=""
data:image/s3,"s3://crabby-images/8b223/8b223426c3ac4de16981f159464676ac4490d662" alt=""
data:image/s3,"s3://crabby-images/e7e78/e7e78ac5d69f551c86a9cd62802b61f12754fd8c" alt=""
5.SetSizeWithCurrentAnchors(Animations.Axis axis, float size)
可以通过直接设置rect中的width和height值来改变UI元素的大小。
需要强调的是,在动态设置width或者length时,由于PosX,PosY不变,所以全看中心点设在哪里,设在最左边,那么只会往右拉宽,设在最上面,只会往下拉宽。
data:image/s3,"s3://crabby-images/60873/6087326bf2b4cffcdf1ae70b61167c1ee1a50c65" alt=""
data:image/s3,"s3://crabby-images/c3ccb/c3ccbef84740af90903dbb761e8731528490d4f8" alt=""
6.SetInsetAndSizeFromParentEdge(RectTransform.Edge edge, float inset, float size)
根据父物体的Edge(某一边)去布局
data:image/s3,"s3://crabby-images/86ba3/86ba3477c173e24977cf4eaef31bf2c89d5d70c0" alt=""
rect.SetInsetAndSizeFromParentEdge(RectTransform.Edge.Right, 0, 622);
说的是,让子物体距离右边长度为零,设置其宽度为622。
网友评论