묻고 답해요
160만명의 커뮤니티!! 함께 토론해봐요.
인프런 TOP Writers
-
해결됨[Rookiss University] UE5 Lyra 클론 코딩 (Haker)
강의 내용 문의드립니다.
수강 이제 막 시작했는데요섹션1부터18까지의 수업과 섹션19는 강사분만 다르고 내용은 같다고 생각하면 될까요?
-
미해결이득우의 언리얼 프로그래밍 Part1 - 언리얼 C++의 이해
45.26 해시값이라는건 구조체형식으로 TSet을 만들때 필요한건가요?
TSet<FString> AllUniqueNames;for (int32 idx = 0; idx < StudentNum; ++idx){AllUniqueNames.Emplace(MakeRandomName());} 이 코드는 빌드해도 따로 해시값을 만들수 없다는 오류가 안떠서그런데 결론을 내보자면구조체로만든 TSet같이 특정 데이터를 구분하기위한 해시값이 필요한경우가 있고위의코드처럼 TSet을만들면 값을 1개만 받는거라서 FString자체가 해시값이되서오류가 안뜨는걸까요?
-
해결됨이득우의 언리얼 프로그래밍 Part1 - 언리얼 C++의 이해
Coudn't set association for project. Check the file is writeable. 이라는 에러가 뜹니다.
(윈도우11)12:33 까지 따라한 상태이며, 모듈까지 삽입한 후 UnrealBuildSystem.uproject 를 실행하였으나라는 에러가 뜹니다. 제가 옮긴 Binaries->Win64 내부 파일들은이것이며.txt에는로 적혀서 저장되어 있습니다. 혹시 어떤 문제때문에 에러가 뜬지 알수 있을까요?
-
미해결이득우의 언리얼 프로그래밍 Part2 - 언리얼 게임 프레임웍의 이해
언제 public을 쓰고 언제 protected를 써야 하나요?
헤더함수에서 public과 protected를 각각 언제 써야하는지 헷갈립니다. 예를 들어 2강에서, ABFountain.h에서는 컴포넌트들을 public으로 선언했고 ABCharacterPlayer.h에서는 컴포넌트들을 protected로 선언했는데 차이가 궁금합니다. 그리고 항상 BeginPlay는 protected로, Tick은 public으로 선언되어 있는데 이 부분도 왜 그런지 궁금합니다.
-
미해결이득우의 언리얼 프로그래밍 Part1 - 언리얼 C++의 이해
init()에서 LoadStudentObject() 이 함수가 런타임 정적로딩이라고 보면 되나요?
void UMyGameInstance::LoadStudentObject() const 이 함수가 에셋의 로딩전략중2번째에 해당하는 런타임 로직에서 정적로딩을 하는게맞나요?21:54 로딩전략의 각각의 차이점이 잘 감이 오질않는데요 런타임로직에서 정적로딩을 한다는것은 에셋 크기가 클수록 부하가 엄청 커지겟지만작은에셋들을 바로 로딩할때 간편하게 쓰기위함이고 생성자 코드에서 미리 로딩을한다면프로젝트가 켜지는 속도는 느리겠지만에셋을 사용할땐 빠르겠고 관리자를 사용해 비동기로딩이라는것은게임이 진행되는 와중에 당장은 에셋을 쓰진않지만언젠간 쓸 에셋들을 계속해서 꾸준히 싱글턴클래스에서로딩을 한다는건가요?
-
미해결이득우의 언리얼 프로그래밍 Part1 - 언리얼 C++의 이해
스마트포인터에 관하여 질문이 있습니다.
안녕하세요 교수님. 스마트포인터로 파일읽기를 한 후, close()를 통해 파일을 닫는데 스마트 포인터를 통해서는 자동으로 파일을 닫는 행위는 할 수 없는건지가 궁금해서 질문남깁니다. (포인터 할당 종료만 가능한건지) 감사합니다.
-
미해결이득우의 언리얼 프로그래밍 Part1 - 언리얼 C++의 이해
15:22에서 TopStudent 가 보이지 않는 문제가 있습니다.
출력로그까지 정상적으로 뜨는데, contents 폴더에서 TopStudent가 보이지 않습니다. TopStudent 가 나타나지 않는 이유가 궁금합니다.일단 코드를 강의코드와 비교하며 개인적으로 재검토를 하였는데, 제가 다시 놓친 무언가가 있는 것인지, 아니며ㅑㄴ 현재 버전에서는 보이지 않게 된 것인지 궁금합니다.DebugGame Editor로 실행하였으며, 출력로그 및 코드 내용은 다음과 같습니다.(출력로그)LogTemp: 저장할 파일 폴더 : ../../../../../../Users/qkrwo/Documents/Unreal Projects/UnrealSerialization/SavedLogTemp: 저장할 파일 전체 경로 : ../../../../../../Users/qkrwo/Documents/Unreal Projects/UnrealSerialization/Saved/RawData.binLogTemp: 변경할 파일 전체 경로 : C:/Users/qkrwo/Documents/Unreal Projects/UnrealSerialization/Saved/RawData.binLogTemp: [RawData] 이름 이득우 순번 16LogTemp: [ObjectData] 이름 이득우 순번 59LogTemp: [JsonData] 이름 이득우 순번 59LogTemp: 패키지가 성공적으로 저장되었습니다. (Student.h)// Fill out your copyright notice in the Description page of Project Settings.#pragma once#include "CoreMinimal.h"#include "UObject/NoExportTypes.h"#include "Student.generated.h"/****/UCLASS()class UNREALSERIALIZATION_API UStudent : public UObject{GENERATED_BODY()public:UStudent();int32 GetOrder() const { return Order; }void SetOrder(int32 InOrder) { Order = InOrder; }const FString& GetName() const { return Name; }void SetName(const FString& InName) { Name = InName; }virtual void Serialize(FArchive& Ar) override;private:UPROPERTY()int32 Order;UPROPERTY()FString Name;};(Student.cpp)// Fill out your copyright notice in the Description page of Project Settings.#include "Student.h"UStudent::UStudent(){Order = -1;Name = TEXT("홍길동");}void UStudent::Serialize(FArchive& Ar){Super::Serialize(Ar); Ar << Name;Ar << Order;}(MyGameInstance.h)// Fill out your copyright notice in the Description page of Project Settings.#pragma once#include "CoreMinimal.h"#include "Engine/GameInstance.h"#include "MyGameInstance.generated.h"struct FStudentData{FStudentData() {}FStudentData(int32 InOrder, const FString& InName) : Order(InOrder), Name(InName) {} friend FArchive& operator<<(FArchive& Ar, FStudentData& InStudentData){Ar << InStudentData.Order;Ar << InStudentData.Name;return Ar;}int32 Order = -1;FString Name = TEXT("홍길동");};/****/UCLASS()class UNREALSERIALIZATION_API UMyGameInstance : public UGameInstance{GENERATED_BODY()public:UMyGameInstance();virtual void Init() override;void SaveStudentPackage() const;private:static const FString PackageName;static const FString AssetName;UPROPERTY()TObjectPtr<class UStudent> StudentSrc;};(MyGameInstance.cpp)// Fill out your copyright notice in the Description page of Project Settings.#include "MyGameInstance.h"#include "Student.h"#include "JsonObjectConverter.h"#include "UObject/SavePackage.h"const FString UMyGameInstance::PackageName = TEXT("/Game/Student");const FString UMyGameInstance::AssetName = TEXT("TopStudent");void PrintStudentInfo(const UStudent* InStudent, const FString& InTag){UE_LOG(LogTemp, Log, TEXT("[%s] 이름 %s 순번 %d"), InTag, InStudent->GetName(), InStudent->GetOrder());}UMyGameInstance::UMyGameInstance(){}void UMyGameInstance::Init(){Super::Init();FStudentData RawDataSrc(16, TEXT("이득우"));const FString SavedDir = FPaths::Combine(FPlatformMisc::ProjectDir(), TEXT("Saved"));UE_LOG(LogTemp, Log, TEXT("저장할 파일 폴더 : %s"), *SavedDir);{const FString RawDataFileName(TEXT("RawData.bin"));FString RawDataAbsolutePath = FPaths::Combine(*SavedDir, *RawDataFileName);UE_LOG(LogTemp, Log, TEXT("저장할 파일 전체 경로 : %s"), *RawDataAbsolutePath);FPaths::MakeStandardFilename(RawDataAbsolutePath);UE_LOG(LogTemp, Log, TEXT("변경할 파일 전체 경로 : %s"), *RawDataAbsolutePath);FArchive* RawFileWriterAr = IFileManager::Get().CreateFileWriter(*RawDataAbsolutePath);if (nullptr != RawFileWriterAr){*RawFileWriterAr << RawDataSrc;RawFileWriterAr->Close();delete RawFileWriterAr;RawFileWriterAr = nullptr; }FStudentData RawDataDest;FArchive* RawFileReaderAr = IFileManager::Get().CreateFileReader(*RawDataAbsolutePath);if (nullptr != RawFileReaderAr){*RawFileReaderAr << RawDataDest;RawFileReaderAr->Close();delete RawFileReaderAr;RawFileReaderAr = nullptr;UE_LOG(LogTemp, Log, TEXT("[RawData] 이름 %s 순번 %d"), *RawDataDest.Name, RawDataDest.Order);}}StudentSrc = NewObject<UStudent>();StudentSrc->SetName(TEXT("이득우"));StudentSrc->SetOrder(59);{const FString ObjectDataFileName(TEXT("ObjectData.bin"));FString ObjectDataAbsolutePath = FPaths::Combine(*SavedDir, *ObjectDataFileName);FPaths::MakeStandardFilename(ObjectDataAbsolutePath);TArray<uint8> BufferArray;FMemoryWriter MemoryWriterAr(BufferArray);StudentSrc->Serialize(MemoryWriterAr);if (TUniquePtr<FArchive> FileWriterAr = TUniquePtr<FArchive>(IFileManager::Get().CreateFileWriter(*ObjectDataAbsolutePath))){*FileWriterAr << BufferArray;FileWriterAr->Close();}TArray<uint8> BufferArrayFromFile;if (TUniquePtr<FArchive> FileReaderAr = TUniquePtr<FArchive>(IFileManager::Get().CreateFileReader(*ObjectDataAbsolutePath))){*FileReaderAr << BufferArrayFromFile;FileReaderAr->Close();}FMemoryReader MemoryReaderAr(BufferArrayFromFile);UStudent* StudentDest = NewObject<UStudent>();StudentDest->Serialize(MemoryReaderAr);PrintStudentInfo(StudentDest, TEXT("ObjectData"));}{const FString JsonDataFileName(TEXT("StudentJsonData.txt"));FString JsonDataAbsolutePath = FPaths::Combine(*SavedDir, *JsonDataFileName);FPaths::MakeStandardFilename(JsonDataAbsolutePath);TSharedRef<FJsonObject> JsonObjectSrc = MakeShared<FJsonObject>();FJsonObjectConverter::UStructToJsonObject(StudentSrc->GetClass(), StudentSrc, JsonObjectSrc);FString JsonOutString;TSharedRef<TJsonWriter<TCHAR>> JsonWriterAr = TJsonWriterFactory<TCHAR>::Create(&JsonOutString);if (FJsonSerializer::Serialize(JsonObjectSrc, JsonWriterAr)){FFileHelper::SaveStringToFile(JsonOutString, *JsonDataAbsolutePath);}FString JsonInString;FFileHelper::LoadFileToString(JsonInString, *JsonDataAbsolutePath);TSharedRef<TJsonReader<TCHAR>> JsonReaderAr = TJsonReaderFactory<TCHAR>::Create(JsonInString); TSharedPtr<FJsonObject> JsonObjectDest;if (FJsonSerializer::Deserialize(JsonReaderAr, JsonObjectDest)){UStudent* JsonStudentDest = NewObject<UStudent>();if (FJsonObjectConverter::JsonObjectToUStruct(JsonObjectDest.ToSharedRef(), JsonStudentDest->GetClass(), JsonStudentDest)){PrintStudentInfo(JsonStudentDest, TEXT("JsonData"));}}} SaveStudentPackage();}void UMyGameInstance::SaveStudentPackage() const{UPackage* StudentPackage = CreatePackage(*PackageName);EObjectFlags ObjectFlag = RF_Public | RF_Standalone;UStudent* TopStudent = NewObject<UStudent>(StudentPackage, UStudent::StaticClass(), *AssetName, ObjectFlag);TopStudent->SetName(TEXT("이득우"));TopStudent->SetOrder(36);const int32 NumofSubs = 10;for (int32 ix = 1; ix <= NumofSubs; ++ix){FString SubObjectName = FString::Printf(TEXT("Student%d"), ix);UStudent* SubStudent = NewObject<UStudent>(TopStudent, UStudent::StaticClass(), *SubObjectName, ObjectFlag);SubStudent->SetName(FString::Printf(TEXT("학생%d"), ix));SubStudent->SetOrder(ix);}const FString PackageFileName = FPackageName::LongPackageNameToFilename(PackageName, FPackageName::GetAssetPackageExtension());//UE_LOG(LogTemp, Log, TEXT("PakageFileName : %s"), *PackageFileName);FSavePackageArgs SaveArgs;SaveArgs.TopLevelFlags = ObjectFlag; if (UPackage::SavePackage(StudentPackage, nullptr, *PackageFileName, SaveArgs)){UE_LOG(LogTemp, Log, TEXT("패키지가 성공적으로 저장되었습니다."));}}UnrealSerialization.Build.cs 에서PublicDependencyModuleNames.AddRange(new string[] { "Core", "CoreUObject", "Engine", "InputCore", "EnhancedInput", "Json", "JsonUtilities" });를 정상적으로 삽입하였습니다.
-
미해결이득우의 언리얼 프로그래밍 Part1 - 언리얼 C++의 이해
직렬화 관련하여 궁금한 점이 있습니다.
22:43 부분에서, 제가 실수로void UStudent::Serialize(FArchive& Ar){Super::Serialize(Ar); Ar << Name;} 처럼 Ar<<Order; 를 적지 않은 상태에서 31:19 부분까지 진행을 하였고, 출력 결과가 놀랍게도 "[ObjectData] 이름 이득우 순번 59" 가 출력이 되었습니다.분명 StudentSrc->Serialize(MemoryWriterAr); 에서 Ar << Order; 가 누락되어서 직렬화를 진행하지 못했고, BufferArray 에는 59 라는 Order가 저장되지 않았을 것일텐데, 따라서 결과적으로 print함수를 통해 순번이 59가 아닌 생성자에서 설정한 -1로 떠야 한다고 생각하지만 이상하게도 59라는 숫자가 출력됩니다.이 말은 Ar<<Order; 를 누락했더라도 내부적으로 알아서 직렬화를 진행했다고 볼수밖에 없는 것일까요...?만약 그렇다면 어떤 코드부분에서 StudentSrc의 Order를 MemoryWriterAr가 소유한 BufferArray 에 저장하게 되는 것인지 궁금합니다. 다음은 저의 코드입니다.(제가 실수하지 않았다면, 사실상 Student.cpp ->void UStudent::Serialize(FArchive& Ar) 함수에서 Ar << Order; 가 누락된 것을 제외하고 전부 동일합니다.) //MyGameInstance.h// Fill out your copyright notice in the Description page of Project Settings.#pragma once#include "CoreMinimal.h"#include "Engine/GameInstance.h"#include "MyGameInstance.generated.h"struct FStudentData{FStudentData() {}FStudentData(int32 InOrder, const FString& InName) : Order(InOrder), Name(InName) {} friend FArchive& operator<<(FArchive& Ar, FStudentData& InStudentData){Ar << InStudentData.Order;Ar << InStudentData.Name;return Ar;}int32 Order = -1;FString Name = TEXT("홍길동");};/****/UCLASS()class UNREALSERIALIZATION_API UMyGameInstance : public UGameInstance{GENERATED_BODY()public:UMyGameInstance();virtual void Init() override;private:UPROPERTY()TObjectPtr<class UStudent> StudentSrc;};//MyGameInstance.cpp// Fill out your copyright notice in the Description page of Project Settings.#include "MyGameInstance.h"#include "Student.h"void PrintStudentInfo(const UStudent* InStudent, const FString& InTag){UE_LOG(LogTemp, Log, TEXT("[%s] 이름 %s 순번 %d"), InTag, InStudent->GetName(), InStudent->GetOrder());}UMyGameInstance::UMyGameInstance(){}void UMyGameInstance::Init(){Super::Init();FStudentData RawDataSrc(16, TEXT("이득우"));const FString SavedDir = FPaths::Combine(FPlatformMisc::ProjectDir(), TEXT("Saved"));UE_LOG(LogTemp, Log, TEXT("저장할 파일 폴더 : %s"), *SavedDir);{const FString RawDataFileName(TEXT("RawData.bin"));FString RawDataAbsolutePath = FPaths::Combine(*SavedDir, *RawDataFileName);UE_LOG(LogTemp, Log, TEXT("저장할 파일 전체 경로 : %s"), *RawDataAbsolutePath);FPaths::MakeStandardFilename(RawDataAbsolutePath);UE_LOG(LogTemp, Log, TEXT("변경된 파일 전체 경로 : %s"), *RawDataAbsolutePath);FArchive* RawFileWriterAr = IFileManager::Get().CreateFileWriter(*RawDataAbsolutePath);if (nullptr != RawFileWriterAr){*RawFileWriterAr << RawDataSrc;/*RawDataSrc << RawFileWriterAr;/RawFileWriterAr->Close();delete RawFileWriterAr;RawFileWriterAr = nullptr; }FStudentData RawDataDest;FArchive* RawFileReaderAr = IFileManager::Get().CreateFileReader(*RawDataAbsolutePath);if (nullptr != RawFileReaderAr){*RawFileReaderAr << RawDataDest;RawFileReaderAr->Close();delete RawFileReaderAr;RawFileReaderAr = nullptr;UE_LOG(LogTemp, Log, TEXT("[RawData] 이름 %s 순번 %d"), *RawDataDest.Name, RawDataDest.Order);}}StudentSrc = NewObject<UStudent>();StudentSrc->SetName(TEXT("이득우"));StudentSrc->SetOrder(59);{const FString ObjectDataFileName(TEXT("ObjectData.bin"));FString ObjectDataAbsolutePath = FPaths::Combine(*SavedDir, *ObjectDataFileName);FPaths::MakeStandardFilename(ObjectDataAbsolutePath);TArray<uint8> BufferArray;FMemoryWriter MemoryWriterAr(BufferArray);StudentSrc->Serialize(MemoryWriterAr);if (TUniquePtr<FArchive> FileWriterAr = TUniquePtr<FArchive>(IFileManager::Get().CreateFileWriter(*ObjectDataAbsolutePath))){*FileWriterAr << BufferArray;FileWriterAr->Close();}TArray<uint8> BufferArrayFromFile;if (TUniquePtr<FArchive> FileReaderAr = TUniquePtr<FArchive>(IFileManager::Get().CreateFileReader(*ObjectDataAbsolutePath))){*FileReaderAr << BufferArrayFromFile;FileReaderAr->Close();}FMemoryReader MemoryReaderAr(BufferArrayFromFile);UStudent* StudentDest = NewObject<UStudent>();StudentDest->Serialize(MemoryReaderAr);PrintStudentInfo(StudentDest, TEXT("ObjectData"));}}//Student.h// Fill out your copyright notice in the Description page of Project Settings.#pragma once#include "CoreMinimal.h"#include "UObject/NoExportTypes.h"#include "Student.generated.h"/****/UCLASS()class UNREALSERIALIZATION_API UStudent : public UObject{GENERATED_BODY()public:UStudent();int32 GetOrder() const { return Order; }void SetOrder(int32 InOrder) { Order = InOrder; }const FString& GetName() const { return Name; }void SetName(const FString& InName) { Name = InName; }virtual void Serialize(FArchive& Ar) override;private:UPROPERTY()int32 Order;UPROPERTY()FString Name;};//Student.cpp// Fill out your copyright notice in the Description page of Project Settings.#include "Student.h"UStudent::UStudent(){Order = -1;Name = TEXT("홍길동");}void UStudent::Serialize(FArchive& Ar){Super::Serialize(Ar); Ar << Name;}
-
미해결이득우의 언리얼 프로그래밍 Part1 - 언리얼 C++의 이해
Int32Array += {2, 4, 6, 8, 10}; 문법이 궁금합니다.
이걸 풀어서쓰면 int32Array = int32Array + {2,4,6,8,10}; 이거인데문법오류가 나더라구요 +=는 어떻게 가능한건가요? TArray는 배열끼리의 +연산자가 오버로딩되어있나요?
-
미해결이득우의 언리얼 프로그래밍 Part1 - 언리얼 C++의 이해
한글 코드 저장에 관하여 질문드립니다.
한글관련 코드를 작성하실때마다 UTF8로 인코딩 형식을 바꿔서 저장해주고 계신데,매번 바꾸는게 번거로워혹시 기본 저장세팅을 UTF8로 하면 문제가 생기나요? 기본 인코딩을 UTF8로 하면 다른 단점이 있는지기본 인코딩을 UTF8로 바꾸는하는 것이 불가능한지?에 관하여 질문드리고 싶습니다.강의 잘 보고 있습니다. 감사합니다.
-
미해결이득우의 언리얼 프로그래밍 Part4 - 게임플레이 어빌리티 시스템
빌드오류가 계속 나옵니다
vs 도구를 추가로 설치하거나 generate를 계속해주거나일반 프로젝트를 생성하고 source랑 contents를 넣은 뒤 generate를 해줘도 동일합니다강의자료로 해도 깃헙에서 받아도 전부 그렇습니다
-
미해결이득우의 언리얼 프로그래밍 Part1 - 언리얼 C++의 이해
21:07 부분에서 NonPropStudent 인수타입 및 기타 질문입니다.
1) 21:07 부분의 CheckObjectIsNull( NonPropStudent, TEXT("NonPropStdudent")); 부분에서, NonPropStudent 에 const UObject* 로의 적절한 변환 함수가 없습니다. 라는 에러가 뜹니다.혹시 업데이트하면서 바뀐 것일까요?(const UObject*) 로 강제형변환을 하면 문제가 없어지긴 하는데, 과연 이것이 일반적인 방법이 된 것인지 궁금합니다.또한2) PropStudent 에서 심각도 코드 설명 프로젝트 파일 줄 비표시 오류(Suppression) 상태 세부 정보오류 UHT001 Unable to find 'class' with name 'Student' 라는 에러가 뜨면서 디버깅이 실패합니다.이것도 업데이트가 되면서 바뀐건지 모르겠습니다만, 혹시 이젠 MyGameInstance.h 에도 Student.h 를 삽입해야만 하도록 변경된것일까요...?
-
미해결이득우의 언리얼 프로그래밍 Part1 - 언리얼 C++의 이해
자꾸 자식생성자에서 부모 프로퍼티의 Name에 접근하면 오류가납니다.
특정 자식생성자에서 부모프로퍼티 Name에 접근하면 error C2001 : newline in constanterror C2143 : syntax error : missing ';' before '}'이라는 에러가 발생하는데요 Name = TEXT("");이걸 주석처리하면 문제없긴합니다만특정 자식에서만 간할적으로 저러니까 매번 프로젝트를 다시생성하거나 그냥 부모생성자에서초기화하는걸로 수업을 따라가고있습니다 .. 왜 이런 오류가 날까요?
-
미해결이득우의 언리얼 프로그래밍 Part1 - 언리얼 C++의 이해
OnChanged.AddUObject이 함수가 BroadCast로 연결되는건가요?
CourseInfo->OnChanged.AddUObject(MyStudent1, &UMyStudent::GetNotification);인스턴스의 이 코드를 통해서 학생클래스에 있는 멤버함수와 Courseinfo 클래스에 있는 BroadCast랑 묶이는건가요?? Courseinfo 클래스에서 선언된 OnChanged 변수는델리게이트에 접근하기위함일 뿐인 거같고결국 AddUObject랑 특정객체의 멤버함수랑 연결만 해놓으면 델리게이트 멤버함수의 어디든 무조건 델리게이트의 BroadCast로만 이어지는건가요?만약 그렇다면 CourseInfo->OnChanged.BroadCast(MyStudent1, &UMyStudent::GetNotification);이렇게 쓰면 좀 덜헷갈렸을 거 같네요 ..ㅎ
-
해결됨[언리얼 공인 강사 직강] 하루만에 언리얼 엔진5 입문하기
1:58 플레이스 엑터에서 큐브하나를 끌어다 놓을때 transform에 mobility 설정이 static이면 이후 벽을 움직이는 부분이 작동하지 않습니다.
1:58 플레이스 엑터에서 큐브하나를 끌어다 놓을때 transform에 mobility 설정이 static이면 이후 벽을 움직이는 부분이 작동하지 않습니다. movable로 설정해야지 되네요. 저는 기본값이 스태틱으로 되어있어서 분명 똑같이 했는데 왜 안되는지 헤메다가 gpt한테 물어봐서 찾았습니다.
-
미해결[입문자를 위한 UE5] Part2. 언리얼 엔진 2D 게임 개발 입문
PlayerController가 생성되지 않는 것 같아요.
오류가 있는 것 같아 수업자료 다운 받아서 모두 똑같이 연결 했는데도캐릭터가 움직이지 않고 공격입력만 받아져서 controller의 event begin play에 print text를 찍어봐도 아무것도 출력되지 않네요. 혹시 뭐가 잘못된 건지 짐작이 가시나요?world setting도 이미지 입니다.
-
해결됨이득우의 언리얼 프로그래밍 Part1 - 언리얼 C++의 이해
TSet<FString> FruitSet; 관련 궁금증입니다.
TSet<FString> FruitSet; 로 아무런 요소를 할당하지 않고 만들었을때, 초기 메모리 할당크기는 0 바이트인지 16바이트인지 궁금합니다. TSet<FString> FruitSet;UE_LOG(LogTemp, Warning, TEXT("FruitSet's size : %d"), FruitSet2.GetAllocatedSize());라는 구문을 실행했을 때, 저는 0바이트로 기대했는데 결과가 16바이트로 나옵니다. 단지 선언만 했을 뿐인데도 16바이트가 자동으로 할당되는것처럼 생각되는데, 이것은 참인가요? (테스트 코드)// Fill out your copyright notice in the Description page of Project Settings.#include "GameInstance/MyGameInstance.h"#include "Algo/Accumulate.h"void UMyGameInstance::Init(){Super::Init();FString Comb;TSet<FString> FruitSet2;UE_LOG(LogTemp, Warning, TEXT("FruitSet2's size : %d"), FruitSet2.GetAllocatedSize());//FruitSet2.Reserve(10);UE_LOG(LogTemp, Warning, TEXT("FruitSet2's size : %d"), FruitSet2.GetAllocatedSize());//FruitSet2 = { "Kiwi", "Melon", "Orange" };UE_LOG(LogTemp, Warning, TEXT("FruitSet2's size : %d"), FruitSet2.GetAllocatedSize()); // 결과 출력Comb = FString::Join(FruitSet2, TEXT(", "));UE_LOG(LogTemp, Warning, TEXT("FruitSet2(Sorted) : %s"), *Comb); //FruitSet2.Empty();UE_LOG(LogTemp, Warning, TEXT("FruitSet2's size : %d"), FruitSet2.GetAllocatedSize());}
-
해결됨이득우의 언리얼 프로그래밍 Part1 - 언리얼 C++의 이해
TSet 관련 질문입니다.
40:55 에서 TSet<int32, FString> NewSet = FruitSet; <- 이 구문은 아직도 유효한가요? 심각도 코드 설명 프로젝트 파일 줄 비표시 오류(Suppression) 상태 세부 정보오류(활성) E0312 "TSet<FString, DefaultKeyFuncs<FString, false>, FDefaultSetAllocator>"에서 "TSet<int32, FString, FDefaultSetAllocator>" (aka "TSet<signed int, FString, FDefaultSetAllocator>")(으)로의 사용자 정의 변환이 적절하지 않습니다. LevelChanger D:\Unreal Project\LevelChanger\Source\LevelChanger\GameInstance\MyGameInstance.cpp 38 라는 에러가 뜹니다. NewSet의 파라미터 타입이 2개인데, TSet에서 이 방식이 아직 유효한건가요?
-
미해결이득우의 언리얼 프로그래밍 Part1 - 언리얼 C++의 이해
37:41, 38:35 에서 CreateConstIterator 와 FSetElementId 관련 질문입니다.
for (auto It = FruitSet.CreateConstIterator(); It; ++It){FPlatformMisc::LocalPrint(FString::Printf(TEXT("\"%s\"\n"), *It));}구문에서, *It을 하니 컴파일에러가 뜹니다.**It로 수정하니 정상적으로 작동되는데, 사이트의 설명에 오류가 있는 것일까요? FSetElementId 구조체에서 사이트의 함수를 그대로 적용하고자FSetElementId BananaIndex = FruitSet.Index(TEXT("Banana"));FPlatformMisc::LocalPrint(*FString::Printf(TEXT(" \"%s\"\n"),*FruitSet[BananaIndex]));를 그대로 따라 쳤으나, Index 부분에서 에러가 뜹니다. 오류(활성) E0135 클래스 "TSet<FString, DefaultKeyFuncs<FString, false>, FDefaultSetAllocator>"에 "Index" 멤버가 없습니다. LevelChanger D:\Unreal Project\LevelChanger\Source\LevelChanger\GameInstance\MyGameInstance.cpp 56 이유가 무엇인지 궁금합니다.39:44 의 FruitSet.Remove(0); 라는 구문은 심각도 코드 설명 프로젝트 파일 줄 비표시 오류(Suppression) 상태 세부 정보오류(활성) E0304 인수 목록이 일치하는 오버로드된 함수 "TSet<InElementType, KeyFuncs, Allocator>::Remove [대상 InElementType=FString, KeyFuncs=DefaultKeyFuncs<FString, false>, Allocator=FDefaultSetAllocator]"의 인스턴스가 없습니다. LevelChanger D:\Unreal Project\LevelChanger\Source\LevelChanger\GameInstance\MyGameInstance.cpp 93 라는 에러가 뜨는데, TSet은 현재에도 Remove(인덱스) 로 삭제하는것이 유효한지 궁금합니다. 예를들어 FruitSet.Remove(0); 이라는 구문은<FString> 파라미터가 아닌 <int32> 파라미터일 경우에 한해서TSet<int32> int32Set = { 2,4,0,8,10 }; 를 선언하였을 때, 0 이라는 요소값 제거하기 위해서 int32Set.Remove(0); 을 사용하는 것과는 다른 개념인가요?
-
해결됨[Rookiss University] UE5 Lyra 클론 코딩 (Haker)
[섹션 12 Weapon Animation] DefaultLayer(Anim Layer)가 정상적으로 Load되지 않음
안녕하세요. 현재 섹션 12의 Weapon Animation 영상을 수강하고 있습니다.Haker님의 실행 결과와는 다르게, Mannequin의 AnimClass를 세팅해줘도 Pistol의 AnimLayer가 적용되지 않는 오류가 있어 질문 드리게 되었습니다. 디버깅 포인트로 확인해보니 ABP_PistolAnimLayers가 DefaultLayer에 세팅되지 못하고 있었습니다. 그래서 섹션 12강을 처음부터 다시 점검해보고 있는데, Lyra에서 AnimLayers를 가져올 때 Haker님은 Feminine 버전을 들고 왔지만 저는 기본 AnimLayers를 들고 왔습니다. 그 부분을 제외하고는 다 동일한 것으로 확인되는데, 혹시 기본 버전을 들고 오면 이런 에러가 발생하는 것일까요? https://coal-schooner-81d.notion.site/Section-10-11524bba9b048044bd6deb6fc79de295?pvs=4강의를 보며 정리하는 노션 페이지입니다. 혹시 진행 상황에서 문제가 있는 부분이 보인다면 알려주시면 감사하겠습니다...