유니티 자료 구조 - 딕셔너리

Published: Aug 2, 2021 by BeatChoi

딕셔너리 :: Dictionary

배열이나 리스트 같은 경우에는 원하는 값에 접근할 때 index번호로 접근하게 되며 이 index는 정수로 구성되어 있습니다.
Dictionary의 경우 배열이나 리스트의 index를 사용자가 지정할 수 있습니다. 이를 dictionary에서는 key라고 합니다.
쉽게말해 내가 지정한 값에 이름표를 붙인다고 생각하면 편합니다.
다음 예제는 SwordDamage라는 dictionary를 생성하고 SwordDamage안에 각각의 검의 종류를 키로 지정하고 해당 검의 종류에 따라 다른 데미지를 줘보도록 하겠습니다.

유니티3D 에디터에서

스크립트 생성

프로젝트 창에서 DataStructure_Dictionary.cs 스크립트를 생성합니다.
DataStructure_Dictionary.cs스크립트를 열어 다음과 같이 작성합니다.

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
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
using System.Collections;
using System.Collections.Generic;
using UnityEngine;

public class DataStructure_Dictionary : MonoBehaviour
{
    //Dictionary 선언
    //검의 종류() 대미지() 
    Dictionary<string, int> SwordDamage = new Dictionary<string, int>();

    // Start is called before the first frame update
    void Start()
    {
        AddData();
        CallData();
        FindData();
    }

    void AddData()
    {
        //검의 종류는 String, 대미지는 int 값으로 추가
        SwordDamage.Add("ShortSword", 5);
        SwordDamage.Add("BroadSword", 10);
        SwordDamage.Add("LongSword", 15);
    }

    void CallData()
    {
        //데이터를 불러오고 데이터를 출력
        int damage = SwordDamage["ShortSword"];
        Debug.Log("ShortSword's damage is "+damage);
        damage = SwordDamage["BroadSword"];
        Debug.Log("BroadSword's damage is " + damage);
        damage = SwordDamage["LongSword"];
        Debug.Log("LongSword's damage is " + damage);
    }

    void FindData()
    {
        //원하는 데이터를 키로 검색
        if (!SwordDamage.ContainsKey("LongSword")) SwordDamage.Add("LongSword", 15);
        if (!SwordDamage.ContainsKey("GrandSword")) SwordDamage.Add("GrandSword", 20);
        ReadAllData();
    }

    void ReadAllData()
    {
        //딕셔너리의 반복문 활용
        foreach(KeyValuePair<string, int> data in SwordDamage)
        {
            Debug.Log(data.Key + "'s damage is " + data.Value);
        }
    }
}
  • Dictionary의 선언은 Dictionary<키 자료형, 값 자료형> 변수이름 = new Dictionary<키 자료형, 값 자료형>() 의 형태입니다.
  • 데이터의 추가는 `Add(키, 값) 의 형태입니다.
  • Dictionaryint damage = SwordDamage["ShortSword"];처럼 키로 값을 저장할 수 있습니다.
  • DictionaryContainsKey()메소드로 해당 키가 존재하는지 검색할 수 있습니다.
  • Dictionary는 일반적인 index로 접근하지 않기때문에 for문을 활용할 수 없습니다.
    • foreach문을 활용하여 모든 값에 접근할 수 있습니다.

씬 설정

계층구조창에 빈 게임오브젝트를 생성하고 이름을 Dictionary로 변경합니다.
Dictionary 오브젝트에 DataStructure_Dictionary.cs 스크립트를 인스턴스화 시킵니다.

상단 플레이 버튼을 누르고 Console 창에 프린트되는 메시지를 확인합니다.


<01. 콘솔 확인>

CallData에서 호출된 Debug.Log 세줄과
FindData에서 호출된 Debug.Log 네줄이 나타나면 성공입니다.

설명

딕셔너리는 데이터에 key라는 이름표를 붙여 key를 통해 데이터에 접근할 수 있도록 하는 자료구조입니다.
자료에 접근하는 시간이 짧아 시간복잡도가 1로 효율적이며 특히 게임이나 다양한 데이터를 관리해야하는 콘텐츠의 개발에서 잘 쓰일 수 있습니다.

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