iOS / tvOS 확장 프로그램 만들기

iOS 또는 tvOS용 확장 프로그램을 만들기 위해서는 두 가지 부분으로 나누어 작업해야 합니다. 첫 번째는 확장 프로그램 자체와 필요한 파일을 추가하는 것이고, 두 번째는 확장 프로그램에 필요한 함수와 매크로/상수를 만드는 것입니다.

확장 프로그램 추가하기

확장 프로그램의 함수와 상수는 플레이스홀더 파일을 사용하여 그룹화합니다. 플레이스홀더를 추가한 후, 함수와 매크로를 정의할 수 있습니다. 나머지 파일을 추가하려면, 에디터의 추가 기능 섹션에서 iOS 및/또는 tvOS 체크박스를 선택하여 관련 확장 속성 창을 열어야 합니다.

항목 설명
컴파일러 플래그 / 링크 플래그 일부 프레임워크 및 서드파티 SDK는 추가 링크 플래그와 컴파일러 플래그가 필요합니다.
클래스 이름 확장 프로그램은 여러 클래스를 가질 수 있으며, 각 클래스는 고유한 함수와 상수를 가집니다.
앱 델리게이트 클래스 이름 사용자 정의 앱 델리게이트 클래스의 이름을 설정합니다.

앱 델리게이트 설정

사용자 정의 앱 델리게이트를 사용하려면 다음을 수행해야 합니다:

  1. 델리게이트 소스 파일의 이름이 델리게이트 클래스와 동일해야 합니다.
  2. 앱 델리게이트 헤더 파일의 상단에 ${YYExtAppDelegateIncludes} 환경 변수를 추가합니다.
  3. ${YYExtAppDelegateBaseClass} 환경 변수를 사용자 정의 앱 델리게이트의 기본 클래스로 사용합니다.

시스템 프레임워크 추가

여기에서 iOS 시스템 프레임워크를 추가할 수 있습니다. 버튼을 클릭하여 플레이스홀더 프레임워크를 추가하고, 더블 클릭하여 편집할 수 있습니다. 시스템 프레임워크를 제거하려면 선택한 후 버튼을 클릭하면 됩니다.

서드파티 프레임워크 및 번들 추가

서드파티 및 SDK 번들을 추가하는 섹션입니다. 시스템 프레임워크와 마찬가지로 버튼을 클릭하여 추가하고, 더블 클릭하여 편집할 수 있습니다.

옵션 설명
포함하지 않음 프레임워크를 포함하지 않습니다.
포함 및 서명 프레임워크를 포함하고 서명합니다.
포함하되 서명하지 않음 프레임워크를 포함하지만 서명하지 않습니다.

소스 추가

확장 프로그램이 작동하는 데 필요한 소스 파일을 추가할 수 있습니다. 추가된 파일은 확장 디렉토리 내의 iOSSource 폴더에 저장됩니다.

코드 주입

코드를 주입하여 iOS 애플리케이션에 추가할 수 있습니다. 게임을 스토어에 제출하기 전에 설정을 신중하게 검토해야 합니다.

태그 유형 주입 경로
Entitlements {RUNTIME}\ios\TemplateProject\${YYXCodeProjName}\${YYXCodeProjName}.entitlements
info.plist {RUNTIME}\ios\TemplateProject\${YYXCodeProjName}\Supporting Files\${YYXCodeProjName}-Info.plist
PrivacyManifest {RUNTIME}\ios\TemplateProject\${YYXCodeProjName}\Supporting Files\PrivacyInfo.xcprivacy

코드 주입 값 삽입

주입된 코드에 다양한 값을 삽입할 수 있습니다. ${NAME} 구문을 사용하여 다음과 같은 값을 사용할 수 있습니다:

  • 프로젝트 정보
  • Xcode 내장 변수

파일 주입

확장 프로그램에 추가된 텍스트 파일 내에서 ${ } 안에 태그를 언급하여 코드를 주입할 수 있습니다. 예를 들어:

<?xml version="1.0" encoding="UTF-8"?>
<dict>${YYIosMyInjectionTag}</dict>

사용자 정의 파일

확장 프로그램 폴더에 "iOSProjectFiles"라는 폴더를 만들 수 있습니다. 이 폴더에 있는 파일은 컴파일 시 생성된 Xcode 프로젝트의 루트로 이동합니다.

추가 정보

확장 프로그램에 시스템 프레임워크나 서드파티 프레임워크가 추가된 경우, 확장 속성 창에 나열됩니다. 체크박스를 선택하면 약한 링크가 활성화됩니다.

활용 예제

// 확장 프로그램의 기본 클래스 정의
@interface MyCustomAppDelegate : UIResponder <UIApplicationDelegate>
@end

// 앱 델리게이트 메서드 오버라이드
- (BOOL)application:(UIApplication *)application willFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
    if ([[self superclass] instancesRespondToSelector:@selector(application:willFinishLaunchingWithOptions:)]) {
        return [super application:application willFinishLaunchingWithOptions:launchOptions];
    } else {
        return TRUE;
    }
}

// 시스템 프레임워크 추가
[self addSystemFramework:@"SomeFramework"];

// 서드파티 프레임워크 추가
[self addThirdPartyFramework:@"ThirdPartyFramework"];
// 코드 주입 예제
<YYIosMyInjectionTag>
    <key>SomeKey</key>
    <string>SomeValue</string>
</YYIosMyInjectionTag>
// 사용자 정의 파일 추가
NSString *path = [[NSBundle mainBundle] pathForResource:@"MyCustomFile" ofType:@"txt"];

이 문서는 iOS 및 tvOS 확장 프로그램을 만드는 방법에 대한 기본적인 개요를 제공합니다. 각 단계에서 필요한 설정과 주의사항을 잘 숙지하여 개발에 활용하시기 바랍니다.

Read more

기술 문서 해설 및 활용 예제

이 문서는 특정 기술에 대한 설명과 활용 방법을 다룹니다. 아래에서 내용을 쉽게 이해할 수 있도록 해설하고, 다양한 활용 및 응용 예제를 추가로 제공합니다. 기술 개요 이 기술은 게임 개발에서 자주 사용되는 기능으로, 특정 작업을 자동화하거나 효율적으로 처리하는 데 도움을 줍니다. 주로 게임의 로직을 구성하거나 사용자 인터페이스를 제어하는 데 사용됩니다. 주요

By 이재협/실장/시스템개발실/PHYSIA

키워드 설명서

이 문서는 특정 키워드에 대한 설명과 사용법을 제공합니다. 문법 (arguments); 인수 인수 이름 유형 설명 argument_name 인수에 대한 설명을 여기에 작성합니다. 반환값 (선택적 설명) 예제 code_example() { // 여기에 코드 예제를 설명합니다. } 코드 예제 설명 위의 코드 예제는 특정 기능을 수행하는 함수의 기본 구조를 보여줍니다. 이 함수는 인수를 받아들이고, 특정

By 이재협/실장/시스템개발실/PHYSIA

GameMaker 환경 설정 및 기능

이 문서에서는 GameMaker의 환경 설정 및 다양한 IDE 기능에 대한 정보를 제공합니다. 다음은 주요 항목들입니다: IDE 환경 설정 IDE(통합 개발 환경) 설정은 GameMaker의 전반적인 사용 경험을 조정하는 데 도움을 줍니다. 여기서 사용자는 개인의 필요에 맞게 다양한 옵션을 설정할 수 있습니다. 주요 설정 항목 설정 항목 설명 테마 IDE의 색상

By 이재협/실장/시스템개발실/PHYSIA

GameMaker IDE 설명서

GameMaker IDE는 게임을 만들고 소프트웨어에서 제공하는 모든 기능을 활용하는 주요 인터페이스입니다. 이 프로그램은 시작 화면부터 게임을 만들기 위해 사용하는 모든 편집기 창까지 포함되며, 매뉴얼과 다양한 튜토리얼에서 IDE라고 언급됩니다. IDE의 구성 요소 다음 섹션에서는 IDE에 대한 정보를 다룹니다: 1. 설정 및 기능 IDE의 설정 및 기능은 사용자가 게임 개발을 보다 효율적으로

By 이재협/실장/시스템개발실/PHYSIA