유니티에서 Azure PlayFab 활용하기 - PlayFab 가입 및 로그인

Published: May 25, 2022 by BeatChoi

Azure Playfab

이번 포스팅에서는 회원가입 을 구현합니다.

Unity3D

Scene

PlayFab SDK 를 세팅한 프로젝트에서 진행합니다.
회원가입 UI를 다음과 같이 세팅합니다.
중요한 것은 Username(ID), Password, Email 항목을 입력하는 부분은 Input Field로,
Create Account(아이디 생성) 항목은 Button으로 구현합니다.


<01. 회원가입 UI 구현 >

Script

CreateAccountManager.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
55
56
using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using UnityEngine.Events;
using PlayFab;
using PlayFab.ClientModels;

public class CreateAccountManager : MonoBehaviour
{
    string playfabID;
    string username, password, emailaddress;

    public void CreateAccount(string username, string emailaddress, string password)
    {
        PlayFabClientAPI.RegisterPlayFabUser(
            new RegisterPlayFabUserRequest()
            {
                Email = emailaddress,
                Password = password,
                Username = username,
                RequireBothUsernameAndEmail = true
            },
            response =>
            {
                Debug.Log($"Successful Account Creation: {username}, {emailaddress}");
                playfabID = response.PlayFabId;
            },
            error =>
            {
                Debug.Log($"Unsuccessful Account Creation: {username}, {emailaddress} \n {error.ErrorMessage}");
            }
        );
    }

    public void UpdateUsername(string _username)
    {
        username = _username;
    }


    public void UpdatePassword(string _password)
    {
        password = _password;
    }


    public void UpdateEmailAddress(string _emailaddress)
    {
        emailaddress = _emailaddress;
    }

    public void CreateAccount()
    {
        CreateAccount(username, emailaddress, password);
    }
}
  • CreateAccount(string username, string emailaddress, string password) PlayFabClientAPI.RegisterPlayFabUser 함수를 활용하여 이메일, 비밀번호, 아이디를 생성, PlayFab 서버로 전송합니다.
    생성에 성공하면 response, 실패하면 error 항목에 있는 명령어가 호출됩니다.

  • UpdateUsername, UpdatePassword, UpdateEmailAdreess, CreateAccount Input Field의 값을 불러오는 역할을 합니다. Input Field의 OnValueChanged 함수에 연결시킵니다.

Scene

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


<02. AccountManager 오브젝트 생성 >

UI Input Field오브젝트를 선택하고 Input Field컴포넌트의 On Value Changed (string)항목을 찾아봅니다.
함수란을 추가하고 오브젝트란에 AccountManager오브젝트를 연결하고 그림과 같이 해당하는 함수를 연결합니다.
여기서 주의해야할 것은 상단의 UpdateUsername 함수와 하단 UpdateUsername(string) 두개중 상단의 것을 써야
Input Field에 값이 변할 때 자동으로 함수가 호출됩니다.


<03. Username Input Field>


<04. Password Input Field >


<05. Email Input Field >

CreateAccount 버튼의 Button컴포넌트의 On Click () 이벤트 항목을 찾습니다.
함수란에 AccountManager 오브젝트를 연결하고 그림과 같이 해당하는 CreateAccount 함수를 연결합니다.


<06. Create Account Button >

테스트

상단 플레이 버튼을 누르고 Game 창에서 Account를 생성해 봅니다.
Username(아이디)에는 공백이 없도록, 비밀번호는 대소문자 및 숫자와 특수문자를 포함하여 작성해봅니다.


<07. Create Account >

만약 정상적으로 생성이 된다면 Create Account 버튼을 누르고 Console창을 보았을 때 다음과 같은 메시지가 생성됩니다.


<08. 콘솔 메시지 >

확실하게 체크를 하기 위해서는 PlaFab Developer 콘솔에서 확인할 수 있습니다.
하단 게임 타이틀을 클릭하여 들어갑니다.


<09. PlayFab Developer 로그인 >

좌측 메뉴의 Players항목을 클릭하고 화면 중앙 우측 푸른색 Search 버튼을 누릅니다.


<10. Player 항목 >


<11. Player Search >

찾아서 나온 계정을 클릭하여 들어가면 다음과 같이 세부사항을 확인할 수 있습니다.


<12. Player 정보 >

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