라인 렌더러 글씨 그리기 - Line Renderer Draw Line

Published: Dec 14, 2020 by BeatChoi

라인 렌더러로 글씨 그리기

이전 강의에서 배웠던 라인 렌더러를 활용하여 터치 그리기를 구현해봅니다.

유니티3D 에디터에서

스크립트 :: Drawing

프로젝트 창에 Drawing스크립트를 하나 생성합니다.


<01. 스크립트 생성>

다음과 같이 스크립트를 작성합니다.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
    public Camera cam;  //Gets Main Camera
    public Material defaultMaterial; //Material for Line Renderer

    private LineRenderer curLine;  //Line which draws now
    private int positionCount = 2;  //Initial start and end position
    private Vector3 PrevPos = Vector3.zero; // 0,0,0 position variable

    // Update is called once per frame
    void Update()
    {
        DrawMouse();
    }

    void DrawMouse()
    {
        Vector3 mousePos = cam.ScreenToWorldPoint(new Vector3(Input.mousePosition.x, Input.mousePosition.y, 0.3f));

        if (Input.GetMouseButtonDown(0))
        {
            createLine(mousePos);
        }else if (Input.GetMouseButton(0))
        {
            connectLine(mousePos);
        }
        
    }
  • DrawMouse()함수는 매 프레임마다 호출되는 업데이트 함수에 호출하여 실시간으로 이용자가 마우스 클릭를 하는지 여부를 체크합니다.
  • mousePos 변수에 현재 클릭하는 위치값을 저장하게 됩니다.
  • 첫 클릭에 CreateLine()함수를 호출합니다. GetMouseButtonDown의 특성상 하나의 선을 그릴 때 한번 호출됩니다.
  • 첫 클릭 후 드래그를 할 때 ConnectLine()함수를 호출하게 됩니다.
  • 기본적인 프로그램의 구조를 생성했습니다.

createLine함수를 생성합니다. 아래에 스크립트를 추가합니다.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
void createLine(Vector3 mousePos)
    {
        positionCount = 2;  
        GameObject line = new GameObject("Line");
        LineRenderer lineRend = line.AddComponent<LineRenderer>();

        line.transform.parent = cam.transform;
        line.transform.position = mousePos;

        lineRend.startWidth = 0.01f;
        lineRend.endWidth = 0.01f;
        lineRend.numCornerVertices = 5;
        lineRend.numCapVertices = 5;
        lineRend.material = defaultMaterial;
        lineRend.SetPosition(0, mousePos);
        lineRend.SetPosition(1, mousePos);

        curLine = lineRend;
    }
  • CreateLine함수를 생성합니다. 인자는 Vector3형의 mousePos 변수입니다.
  • positionCount변수는 처음 생성하는 라인 렌더러의 코너 점의 갯수를 지정해 줍니다.
  • 새로운 게임오브젝트를 생성하여 line변수에 값을 지정합니다.
  • line게임오브젝트에 라인 렌더러 컴포넌트를 부착합니다. 부착된 컴포넌트를 lineRend변수 에 저장합니다.
  • 생성한 line오브젝트를 카메라 오브젝트의 자식오브젝트로 계층을 이동시키고, 클릭지점으로 위치를 이동시킵니다.
  • 생성한 line오브젝트의 라인렌더러 컴포넌트의 값들을 지정합니다. (해당 항목들은 라인렌더러 기본 강좌 참조)

이어서 connectLine스크립트를 생성합니다.

1
2
3
4
5
6
7
8
9
10
11
void connectLine(Vector3 mousePos)
    {
        if(PrevPos != null && Mathf.Abs(Vector3.Distance(PrevPos, mousePos)) >= 0.001f)
        {
            PrevPos = mousePos;
            positionCount++;
            curLine.positionCount = positionCount;
            curLine.SetPosition(positionCount - 1, mousePos);
        }
        
    }
  • 현재 터치 위치와 직전의 터치 위치의 거리에 따라 라인렌더러의 길이를 증가시킵니다.
  • 터치가 진행될수록 positionCount의 숫자를 증가시킵니다. 라인렌더러의 길이가 길어져야 하기 때문입니다.
  • 최근 터치한 위치로 line오브젝트를 이동시킵니다.

에디터 메뉴

프로젝트 창에서 Material파일을 생성합니다. 이름은 LineMat으로 변경합니다.


<02. 매테리얼 생성>

LineMat매테리얼을 셰이더를 Unlit/Color로 변경합니다.
LineMat의 색상은 하단 Main Color항목 우측 색상표를 통해 변경할 수 있습니다.


<03. 매테리얼 색상 변경>

계층구조창에서 빈 게임 오브젝트를 생성하고 이름을 Draw로 변경합니다.
Draw오브젝트에 방금 작성한 Drawing스크립트를 인스턴스화 시킵니다.
Draw오브젝트를 선택하고 우측 인스펙터 창에 퍼블릭 변수들에 값을 각각 할당합니다.
Cam은 계층구조창의 Main Camera, Default Material항목은 프로젝트창의 LineMat`입니다.


<04. Drawing 스크립트 인스턴스화>

테스팅

위 상단 플레이 버튼을 누르고 게임창에서 마우스로 클릭, 드래그 해서 선을 그려봅니다.


<05. Game 창에서의 테스트>

Latest Posts

콘텐츠 개발 기법 - URP 환경에서 Bloom 및 Volume 포함한 화면 캡처
콘텐츠 개발 기법 - URP 환경에서 Bloom 및 Volume 포함한 화면 캡처

화면 캡처 :: Screen Capture

일반적으로 URP환경에서 Bloom 등의 Volume 이펙트들이 함께 캡처되지 않는 현상이 일어납니다.
두가지 원인이 있는데 첫번째는 저장할 Texture 및 Texture2D의 크기가 작아 모든 텍스쳐를 저장할 수 없는 경우와
두번째는 Linear color space의 픽셀을 텍스쳐에 저장 할 수 없는 경우가 있습니다.
이번 포스팅에서는 URP 환경에서 해당 이펙트들을 함께 캡쳐하는 방법을 알아봅니다.

콘텐츠 개발 기법 - UI 안나오게 화면 캡처(Screen Capture without UI)
콘텐츠 개발 기법 - UI 안나오게 화면 캡처(Screen Capture without UI)

화면 캡처 :: Screen Capture

UI 없이 화면을 캡쳐하는 방법을 알아봅니다.
해당 방법을 통해 사진 앱에서 사진을 찍거나 게임 내에서 UI를 제거한 스크린샷을 구현할 수 있습니다.

유니티3D 에디터에서

스크립트 작성

LightshipAR SDK 활용하기 - LightshipAR VPS의 활용
LightshipAR SDK 활용하기 - LightshipAR VPS의 활용

LightshipAR SDK

이번 강좌에서는 Visual Positioning System (VPS) 기능을 활용하여 콘텐츠를 개발해 봅니다.
VPS는 GPS정보와 타겟 매핑 정보를 정합하여 해당 타겟을 인식하는 기능입니다.
따라서 객체나 환경의 변화 및 이동이 잦지 않은 타겟이 스캔 대상이 됩니다.
주로 동상, 건물 입구, 가로등 등 위치의 변경이 없는 타겟들이 좋은 타겟입니다.

해당 타겟들을 인식시키고 주변에 가상의 오브젝트들을 배치하고 해당 위치를 저장하는 방법을 알아봅니다.

공간 매핑

Niantic Wayfarer

공간을 인식시키기 위해서 먼저 공간을 매핑해야 합니다.
이 과정은 IOS 어플리케이션으로 진행을 할 수 있는데 아래 링크에서

  1. Testflight
  2. Wayfarer

어플리케이션을 다운로드 및 설치합니다.

링크 : https://testflight.apple.com/join/VXu1F2jf