Unity之LineRenderer组件

LineRenderer线渲染器主要是用于在3D中渲染线段,虽然我们也可以使用GL图像库来渲染线段,但是使用LineRenderer我们可以对线段进行更多的操作,例如:设置颜色,宽度等。在这里要注意LineRenderer渲染出的线段的两个端点是3D世界中的点,即他是属于世界坐标(World Point)中的。 LineRenderer是以组件形成存在的,首先我们新建一个空的Game Object,然后我们选择“Component→Effects→Line Renderer”,即可为其添加LineRenderer组件了。


其实我们也可以通过脚本来为其添加

Z0Q8Q(HTLX@56P@SF~K~$RU.png

LineRenderer组件:

LineRenderer lineRenderer = gameObject.AddComponent<LineRenderer>();  

获取LineRenderer组件:

lineRenderer = GetComponent<LineRenderer>();  

【案例】根据鼠标左击的位置,来持续绘制线段
首先我们在场景中新建一个空的GameObject,并Reset一下。然后将Script1脚本添加给他。

using UnityEngine;  
using System.Collections;  
  
public class Script1 : MonoBehaviour {  
    //LineRenderer  
    private LineRenderer lineRenderer;  
    //定义一个Vector3,用来存储鼠标点击的位置  
    private Vector3 position;  
    //用来索引端点  
    private int index = 0;  
    //端点数  
    private int LengthOfLineRenderer=0;  
  
    void Start()  
    {  
        //添加LineRenderer组件  
        lineRenderer = gameObject.AddComponent<LineRenderer>();  
        //设置材质  
        lineRenderer.material = new Material(Shader.Find("Particles/Additive"));  
        //设置颜色  
        lineRenderer.SetColors(Color.red, Color.yellow);  
        //设置宽度  
        lineRenderer.SetWidth(0.02f, 0.02f);  
          
    }  
  
    void Update()  
    {    
        //获取LineRenderer组件  
        lineRenderer = GetComponent<LineRenderer>();  
       //鼠标左击  
        if (Input.GetMouseButtonDown(0))  
        {  
            //将鼠标点击的屏幕坐标转换为世界坐标,然后存储到position中  
            position = Camera.main.ScreenToWorldPoint(new Vector3(Input.mousePosition.x,Input.mousePosition.y,1.0f));   
            //端点数+1  
            LengthOfLineRenderer++;  
            //设置线段的端点数  
            lineRenderer.SetVertexCount(LengthOfLineRenderer);  
              
        }  
        //连续绘制线段  
        while (index < LengthOfLineRenderer)  
        {     
            //两点确定一条直线,所以我们依次绘制点就可以形成线段了  
            lineRenderer.SetPosition(index, position);  
            index++;  
        }   
         
  
    }  
  
    void OnGUI()  
    {            
        GUILayout.Label("当前鼠标X轴位置:" + Input.mousePosition.x);  
        GUILayout.Label("当前鼠标Y轴位置:" + Input.mousePosition.y);          
    }    
}  

效果图:

在这里我提一下,如果我们将Input.GetMouseButtonDown(0)改为Input.GetMouseButton(0)会产生什么样的效果呢?那就是我们拖动鼠标就可以持续的渲染线段了。


添加脚本使物体射线跟随

    public GameObject a;
    LineRenderer or;

    void Start () {
        or = transform.GetComponent<LineRenderer>();
    }
    
    // Update is called once per frame
    void Update () {
        //使射线跟随物体a
        or.SetPosition(1, a.transform.position);
        //创建物体a拖尾效果(飞机的航线)
        //or.SetPosition(0,a.transform.position);
    }
Paste_Image.png
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,383评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,522评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,852评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,621评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,741评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,929评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,076评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,803评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,265评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,582评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,716评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,395评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,039评论 3 316
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,798评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,027评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,488评论 2 361
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,612评论 2 350

推荐阅读更多精彩内容

  • 一、Unity简介 1. Unity界面 Shift + Space : 放大界面 Scene界面按钮渲染模式2D...
    MYves阅读 8,180评论 0 22
  • This article is a record of my journey to learn Game Deve...
    蔡子聪阅读 3,768评论 0 9
  • 为了对得起新买的运动裤,更为了分散某些注意力,疯狂运动了一番,决定去办张卡了,行动力是不是又碾压了那个谁谁,没办法...
    自由和安阅读 104评论 1 1
  • 兴趣与负担 我觉得,只要是一门兴趣,即不应该成为一种负担,即使它也是一种使命。 但就目前来看,很多计划我的确完成不...
    蒙古海军上将阅读 138评论 0 1
  • 最近阿里巴巴旗下的招财宝发生了逾期事件,即违约事件,了解一下事件背后的逻辑,或许对你我会有警示作用: 这个事件主要...
    胡思乱想之阅读 182评论 0 0