Unity UI實現(xiàn)拖拽旋轉(zhuǎn)
本文實例為大家分享了Unity UI實現(xiàn)拖拽旋轉(zhuǎn)的具體代碼,供大家參考,具體內(nèi)容如下
跟隨鼠標旋轉(zhuǎn)
第一種效果是跟隨鼠標旋轉(zhuǎn),原理是計算下鼠標位置與拖拽物體的相對位移
旋轉(zhuǎn)方向即可
注意轉(zhuǎn)換對應(yīng)空間坐標
新建腳本mono類繼承 IBeginDragHandler, IDragHandler, IEndDragHandler 接口
[SerializeField] private Canvas m_Canvas;
private Vector3? CalculateWorldToScreenPos(Vector3 worldPos)
{
if (m_Canvas.renderMode == RenderMode.ScreenSpaceCamera)
{
return m_Canvas.worldCamera.WorldToScreenPoint(worldPos);
}
else if (m_Canvas.renderMode == RenderMode.ScreenSpaceOverlay)
{
Vector3 screenPos = m_Canvas.transform.InverseTransformPoint(worldPos);
var rectTrans = m_Canvas.transform as RectTransform;
screenPos.x += rectTrans.rect.width * 0.5f * rectTrans.localScale.x;
screenPos.y += rectTrans.rect.height * 0.5f * rectTrans.localScale.y;
return screenPos;
}
return null;
}
public void OnDrag(PointerEventData eventData)
{
if (eventData.button != PointerEventData.InputButton.Left) return;
//計算當前物體距離畫布左下角位置
Vector3? curScreenPos = CalculateWorldToScreenPos(transform.position);
if (curScreenPos == null) return;
//鼠標位置偏移量
Vector2 offset = eventData.position - (Vector2)curScreenPos.Value;
if (offset != Vector2.zero)
{
transform.rotation = Quaternion.FromToRotation(Vector3.up, offset);
}
}
設(shè)置下箭頭錨點

效果如下:

手指拖拽旋轉(zhuǎn)
第二種是根據(jù)旋轉(zhuǎn)速度來旋轉(zhuǎn)UI 可以實現(xiàn)一些齒輪交互滾動和車把方向盤交互滾動
//旋轉(zhuǎn)速度
[SerializeField] private float m_RotateSpeed;
public void OnDrag(PointerEventData eventData)
{
if (eventData.button != PointerEventData.InputButton.Left) return;
//手指滑動偏移量
Vector2 mouseXY = eventData.delta;
mouseXY *= m_RotateSpeed;
//計算當前物體距離畫布左下角位置
Vector3? curScreenPos = CalculateWorldToScreenPos(transform.position);
if (curScreenPos == null) return;
//手指位置偏移量
Vector2 offset = eventData.position - (Vector2)curScreenPos.Value;
float value;
if (Mathf.Abs(mouseXY.x) > Mathf.Abs(mouseXY.y)) // 判斷水平滑動還是垂直滑動
{
//手指往水平滑動 下面旋轉(zhuǎn)跟隨偏移參數(shù) 上面與偏移參數(shù)相反
value = mouseXY.x * Mathf.Sign(-offset.y);
}
else
{
//手指垂直滑動 右邊跟隨偏移參數(shù) 左邊與偏移參數(shù)相反
value = mouseXY.y * Mathf.Sign(offset.x);
}
transform.Rotate(Vector3.forward, value, Space.Self);
}
效果如下:

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
c# socket網(wǎng)絡(luò)編程接收發(fā)送數(shù)據(jù)示例代碼
這篇文章主要介紹了c# socket網(wǎng)絡(luò)編程,server端接收,client端發(fā)送數(shù)據(jù),大家參考使用吧2013-12-12
使用 BenchmarkDotNet 對 C# 代碼進行基準測試
這篇文章主要介紹了使用 BenchmarkDotNet 對 C# 代碼進行基準測試,幫助大家更好的理解和學習使用c#,感興趣的朋友可以了解下2021-03-03

