untiy 连接两个UI或一段固定一段跟随鼠标移动的线段

注意,仅适用于UI,且Canvas必须是Camera模式,不能用在3D物体上,3D物体请使用LineRenender

先创建一个图片,将锚点固定在左边
在这里插入图片描述
然后在脚本中添加如下内容

		public RectTransform startObj;//起点物体
		public RectTransform endObj;//终点物体
        public Camera camera;//Canvas的相机
        
        private void CalcuateLine()//计算线的宽度和角度
        {
            if (startObj == null) return;
            //设置长度和角度
            Vector2 startPosition = Vector2.zero;
            Vector2 endPosition = Vector2.zero;
            //计算起点的世界坐标
            startPosition = RectTransformUtility. WorldToScreenPoint(camera,startObj.position);
            //计算终点的世界坐标
            if (endObj != null)//如果有结束物体,以结束物体为终点
            {
                endPosition = RectTransformUtility.WorldToScreenPoint(camera, endObj.position);
            }
            else//如果没有结束物体,以鼠标位置为终点
            {
                endPosition = Input.mousePosition;
            }
            //计算长度
            float dis = Vector2.Distance(startPosition,endPosition);
            //设置长度
            rectTransform.sizeDelta = new Vector2(dis,rectTransform.rect.height); 
            //计算角度
            Vector3 dir = endPosition - startPosition;
            float angle = Vector3.Angle(Vector3.right, dir);
            Vector3 cross = Vector3.Cross(Vector3.right, dir);
            float dirF = cross.z > 0 ? 1 : -1;
            angle = angle * dirF;
            //设置角度
            rectTransform.localEulerAngles = new Vector3(0,0,angle);

            //设置起点位置
            Vector2 startLocalPostion = Vector2.zero;
            RectTransformUtility.ScreenPointToLocalPointInRectangle(contentRectTransform, startPosition,camera,out startLocalPostion);
            rectTransform.localPosition = startLocalPostion;
        }
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值