亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Unity 通過LineRenderer繪制兩點之間的直線操作

 更新時間:2021年04月12日 14:20:08   作者:鬼谷傳人  
這篇文章主要介紹了Unity 通過LineRenderer繪制兩點之間的直線操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧

我就廢話不多說了,大家還是直接看代碼吧~

private LineRenderer line;
//畫線
line = this.gameObject.AddComponent<LineRenderer>();
//只有設置了材質(zhì) setColor才有作用
line.material = new Material(Shader.Find("Particles/Additive"));
line.SetVertexCount(2);//設置兩點
line.SetColors(Color.yellow, Color.red); //設置直線顏色
line.SetWidth(0.01f, 0.01f);//設置直線寬度
//設置指示線的起點和終點
line.SetPosition(0, initPosition);
line.SetPosition(1, newPosition);

繪制圓

下面是以物體position為圓心,半徑為R,在xz平面上的畫圓

 public float R;//半徑
 public int N;//不要超過45
 line.SetVertexCount(N+1);//這里要加1,達成閉合曲線
 for (int i = 0; i < N + 1; i++)
{
  float x = R * Mathf.Cos((360 / N * i) * Mathf.Deg2Rad) + transform.position.x; //確定x坐標
  float z = R * Mathf.Sin((360 / N * i) * Mathf.Deg2Rad) + transform.position.z; //確定z坐標
  line.SetPosition(i, new Vector3(x, transform.position.y, z));         
}

補充:Unity 通過LineRenderer組件畫線段

using System.Collections;
using System.Collections.Generic;
using UnityEngine; 
public class DrawLineByMouse : MonoBehaviour { 
    //畫線組件預制體
    public Transform gestureOnScreenPrefab; 
    private int strokeId = -1; 
    private Vector3 virtualKeyPosition = Vector2.zero;
    private Rect drawArea;
    private RuntimePlatform platform;
    private int vertexCount = 0; 
    private List<LineRenderer> gestureLinesRenderer = new List<LineRenderer>();
    private LineRenderer currentGestureLineRenderer; 
    //GUI
    private string message="what is this ?";
    private bool recognized;
    private string newGestureName = ""; 
    void Start()
    {
        platform = Application.platform;
        drawArea = new Rect(0, 0, Screen.width - Screen.width / 3, Screen.height);
    } 
    void Update()
    { 
        if (platform == RuntimePlatform.Android || platform == RuntimePlatform.IPhonePlayer)
        {
            if (Input.touchCount > 0)
            {
                virtualKeyPosition = new Vector3(Input.GetTouch(0).position.x, Input.GetTouch(0).position.y);
            }
        }
        else
        {
            if (Input.GetMouseButton(0))
            {
                virtualKeyPosition = new Vector3(Input.mousePosition.x, Input.mousePosition.y);
            }
        }
 
        if (drawArea.Contains(virtualKeyPosition))
        {
 
            if (Input.GetMouseButtonDown(0))
            {
               ++strokeId;
 
               // Transform tmpGesture = Instantiate(gestureOnScreenPrefab, transform.position, transform.rotation) as Transform;
               // currentGestureLineRenderer = tmpGesture.GetComponent<LineRenderer>();
 
                GameObject go = new GameObject("LineRenderer");
                go.transform.position = Camera.main.transform.position;
                go.transform.rotation = Camera.main.transform.rotation;
                currentGestureLineRenderer = go.AddComponent<LineRenderer>();              
                currentGestureLineRenderer.startWidth = 0.1f; 
                gestureLinesRenderer.Add(currentGestureLineRenderer); 
                vertexCount = 0;
            }
 
            if (Input.GetMouseButton(0))
            {            
                currentGestureLineRenderer.SetVertexCount(++vertexCount);
                currentGestureLineRenderer.SetPosition(vertexCount - 1, Camera.main.ScreenToWorldPoint(new Vector3(virtualKeyPosition.x, virtualKeyPosition.y, 10)));
            }
        }
    } 
    void OnGUI()
    {
 
        GUI.Box(drawArea, "Draw Area"); 
        GUI.Label(new Rect(10, Screen.height - 40, 500, 50), message); 
        if (GUI.Button(new Rect(Screen.width - 100, 10, 100, 30), "clear line"))
        {
            foreach (LineRenderer lineRenderer in gestureLinesRenderer)
            {
                lineRenderer.SetVertexCount(0);
                Destroy(lineRenderer.gameObject);
            }
            gestureLinesRenderer.Clear();
            recognized = true;
 
        }
    }
}

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。

相關(guān)文章

  • C# Resources資源詳解

    C# Resources資源詳解

    這篇文章主要為大家詳細介紹了C# Resources資源,包括Resource Basics、Strongly Typed Resources等,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-01-01
  • C#讀寫txt文件的2種方法

    C#讀寫txt文件的2種方法

    這篇文章主要為大家詳細介紹了C#讀寫txt文本文檔數(shù)據(jù)的2種方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-10-10
  • C#判斷密碼強度的方法

    C#判斷密碼強度的方法

    這篇文章主要介紹了C#判斷密碼強度的方法,較為詳細的分析了C#判斷密碼強度的原理與實現(xiàn)技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-08-08
  • C#批量修改文件后綴的實現(xiàn)方法

    C#批量修改文件后綴的實現(xiàn)方法

    這篇文章主要介紹了C#批量修改文件后綴的實現(xiàn)方法,本文介紹的方法是通用型的,你只要修改讀取的文件地址,想要讀取的文件后綴名,以及自己想更換的后綴名稱即可,感興趣的小伙伴跟著小伙伴一起來看看吧
    2024-07-07
  • C#實現(xiàn)凍結(jié)Excel窗口以鎖定行列或解除凍結(jié)

    C#實現(xiàn)凍結(jié)Excel窗口以鎖定行列或解除凍結(jié)

    在處理大型Excel工作簿時,有時候我們需要在工作表中凍結(jié)窗格,這樣可以在滾動查看數(shù)據(jù)的同時保持某些行或列固定不動,下面我們就來看看如何使用C#實現(xiàn)凍結(jié)Excel窗口吧
    2024-04-04
  • C#中Web.Config加密與解密的方法

    C#中Web.Config加密與解密的方法

    C#中Web.Config加密與解密的方法,需要的朋友可以參考一下
    2013-04-04
  • C#中文隨機數(shù)實現(xiàn)方法

    C#中文隨機數(shù)實現(xiàn)方法

    這篇文章主要介紹了C#中文隨機數(shù)實現(xiàn)方法,涉及C#針對中文及隨機數(shù)的相關(guān)操作技巧,需要的朋友可以參考下
    2015-06-06
  • C#基礎知識之Partial的使用

    C#基礎知識之Partial的使用

    這篇文章主要介紹了C#基礎知識之Partial的使用,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-01-01
  • 深入解析C#中的abstract抽象類

    深入解析C#中的abstract抽象類

    這篇文章主要介紹了深入解析C#中的abstract抽象類,包括定義抽象類等C#面相對象編程中的基礎知識,需要的朋友可以參考下
    2016-01-01
  • 詳解Unity入門之GameObject

    詳解Unity入門之GameObject

    Unity是一個Component-Based的引擎,所有物體都是GameObject。本文將詳細介紹GameObject和MonoBehaviour,感興趣的同學,可以參考下。
    2021-05-05

最新評論