我在具有屏幕空间 - 相机渲染模式的 Canvas 中有一个图像 UI。我喜欢做的是通过循环遍历所有 LineRenderer
位置并更改其 y 轴,将我的 LineRenderer
移动到图像垂直位置。我的问题是我无法获得 LineRenderer
可以理解的图像的正确位置。我试过使用 ViewportToWorldPoint
和 ScreenToWorldPoint
但它的位置不一样。
Vector3 val = Camera.main.ViewportToWorldPoint(new Vector3(image.transform.position.x, image.transform.position.y, Camera.main.nearClipPlane));
for (int i = 0; i < newListOfPoints.Count; i++)
{
line.SetPosition(i, new Vector3(newListOfPoints[i].x, val.y, newListOfPoints[i].z));
}
使用
Vector3 val = Camera.main.ScreenToWorldPoint(new Vector3(image.transform.localPosition.x, image.transform.localPosition.y, -10));
的截图结果绿色的
LineRenderer
是改变 y 位置的结果。它应该在方形图像的底部。最佳答案
哇,这既烦人又复杂。
这是我最终得到的代码。您问题中的代码是 Update()
函数的下半部分。我唯一改变的是传递给 ScreenToWorldPoint()
方法的内容。该值在 Update()
函数的上半部分计算。RectTransformToScreenSpace()
函数改编自 this Unity Answer post1 关于获取 RectTransform
的屏幕空间坐标(这正是我们想要将屏幕空间坐标转换回世界空间的功能!)唯一的区别是我得到了逆 Y 值,所以我从 Screen.height - transform.position.y
改为 transform.position.y
,它完美地完成了这个技巧。
之后,只需捕获该矩形的左下角,使其成为 Vector3 而不是 Vector2,然后将其传回 ScreenToWorldPoint()
。唯一的技巧是因为透视相机,我需要知道线条与相机最初的距离以保持相同的距离(否则线条在屏幕上的上下移动速度比图像快)。对于正交相机,此值可以是任何值。
void Update () {
//the new bits:
float dist = (Camera.main.transform.position - newListOfPoints[0]).magnitude;
Rect r = RectTransformToScreenSpace((RectTransform)image.transform);
Vector3 v3 = new Vector3(r.xMin, r.yMin, dist);
//more or less original code:
Vector3 val = Camera.main.ScreenToWorldPoint(v3);
for(int i = 0; i < newListOfPoints.Count; i++) {
line.SetPosition(i, new Vector3(newListOfPoints[i].x, val.y, newListOfPoints[i].z));
}
}
//helper function:
public static Rect RectTransformToScreenSpace(RectTransform transform) {
Vector2 size = Vector2.Scale(transform.rect.size, transform.lossyScale);
Rect rect = new Rect(transform.position.x, transform.position.y, size.x, size.y);
rect.x -= (transform.pivot.x * size.x);
rect.y -= ((1.0f - transform.pivot.y) * size.y);
return rect;
}
1并且从关于“如何获取 UI 对象的屏幕坐标”的广义搜索中找到该帖子并不容易。一堆其他帖子出现并有一些代码,但它们都没有做我想要的(包括将屏幕空间坐标转换回 UI 对象的世界空间坐标,这很容易而且不可逆,谢谢
RectTransformUtility
!)关于c# - 如何将新的 Canvas ui 图像位置转换为 linerenderer 位置?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/48133920/