欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Unity 通過LineRenderer繪制兩點(diǎn)之間的直線操作

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

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

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

繪制圓

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

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

補(bǔ)充:Unity 通過LineRenderer組件畫線段

using System.Collections;
using System.Collections.Generic;
using UnityEngine; 
public class DrawLineByMouse : MonoBehaviour { 
    //畫線組件預(yù)制體
    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;
 
        }
    }
}

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

相關(guān)文章

  • C# Resources資源詳解

    C# Resources資源詳解

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

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

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

    C#判斷密碼強(qiáng)度的方法

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

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

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

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

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

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

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

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

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

    C#基礎(chǔ)知識之Partial的使用

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

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

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

    詳解Unity入門之GameObject

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

最新評論