시작하기
Buzzvil iOS SDK(이하 Buzzvil SDK)에서 제공하는 기능을 사용하기 전 완료해야 하는 설정에 대해 알아보세요.
요구 사양
✅ 중요
- 요구 사양은 Buzzvil SDK의 최신 상태를 기준으로 명시됩니다.
- 버즈빌은 안정적인 광고 플랫폼 및 개선된 수익화 기능의 탑재와 iOS와의 호환성을 위해 최신 버전으로 업데이트하는 것을 권장합니다.
- 크로스 플랫폼 프레임워크(React Native, Flutter 등)를 통한 SDK 사용은 가능하지만, 기술 지원은 제공되지 않습니다.
- deployment target 13 이상
- Xcode 15.1 이상
연동용 ID 발급받기
Buzzvil SDK를 연동하려면 반드시 연동하려는 앱의 고유 식별자(App ID)와 광고 지면의 고유 식별자(Unit ID)가 필요합니다. ID를 발급받으려면 버즈빌 담당자에게 연락하세요.
ID 유형 | 설명 |
---|---|
App ID | Buzzvil SDK를 연동하는 앱별로 부여하는 고유 식별자입니다. |
Unit ID | Buzzvil SDK를 통해 생성하는 지면별로 부여하는 고유 식별자입니다. |
포인트 적립 서버 연동하기
버즈빌이 공급하는 광고는 유저에게 포인트를 지급하는 보상형 광고와 지급하지 않는 비보상형 광고로 분류됩니다.
- 비보상형 광고: 논리워드 광고라고도 합니다. 유저가 광고에 참여해도 별도의 포인트를 지급할 필요가 없으므로 포인트 처리 서버를 연동하지 않아도 됩니다.
- 보상형 광고: 리워드 광고라고도 합니다. 유저가 광고에 참여하면 포인트를 지급해야 하므로 클라이언트의 포인트 적립 요청을 처리할 수 있는 서버가 필요합니다.
보상형 광고의 포인트 적립 요청을 처리할 수 있는 자체 서버를 보유한 경우, 포스트백 연동 가이드를 참고해 포인트 처리 서버를 연동하세요.
SDK 설치하기
Swift Package Manager
Buzzvil SDK 5.9.1 버전 이상 부터 Swift Package Manager를 지원합니다. Swift 패키지를 가져오려면 아래 단계를 따르세요.
✏️ 참고
CocoaPods 기반 프로젝트에서 이전하는 경우 pod deintegrate를 실행하여 Xcode 프로젝트에서 CocoaPods를 삭제합니다. CocoaPods에서 생성된 .xcworkspace 파일은 나중에 안전하게 삭제할 수 있습니다.
Xcode에서
File > Add Package Dependencies
로 이동합니다.Buzzvil SDK Swift Package GitHub 저장소를 검색합니다.
https://github.com/Buzzvil/buzzvil-ios-sdk
- 사용할 버전을 선택합니다. Up to Next Major Version(최대 다음 메이저 버전) 사용을 권장합니다.
패키지 종속 항목을 추가하는 방법에 관한 자세한 내용은 Apple Developer 공식 문서를 참고하세요.
Cocoapods
Buzzvil SDK를 설치하려면 CocoaPods을 사용하여 Podfile
에 BuzzvilSDK를 추가하세요.
✏️ 참고
아래의 코드 스니펫은 최신 버전의 라이브러리를 기준으로 작성되었습니다.
pod 'BuzzvilSDK', '= 5.29.2'
✏️ 참고
오프라인 빌드를 진행하는 경우, 버즈빌 담당자(help@buzzvil.com)에게 오프라인 빌드에 필요한 프레임워크를 요청하세요. 오프라인 빌드에 대한 자세한 내용은 오프라인 빌드 토픽을 참고하세요.
❌ 오류
SDK 설치 시 문제가 발생하는 경우, 문제 해결하기 토픽을 참고하세요.
SDK 초기화하기
Buzzvil SDK를 설치한 후 App ID, 유저 프로필 등 필요한 정보를 추가해 SDK를 초기화하세요.
Buzzvil SDK 초기화하기
- 원하는 위치에서
BuzzBenefit.initialize()
를 호출해 SDK를 초기화하세요.
🚨 경고
BuzzBenefit.initalize()
호출하기 이전에 다른 모든 함수들이 호출되면 정상동작 하지 않습니다. 초기화 함수를 다른 함수 이전에 꼭 호출 해 주세요.
✏️ 참고
BuzzBenefitConfig
를 사용해 베네핏허브 지면의 기능과 디자인을 변경할 수 있습니다. 자세한 내용은 추가 구현과 커스터마이징 토픽을 참고하세요.
- Swift
- Objective C
import BuzzvilSDK
let config = BuzzBenefitConfig.Builder(appID: "YOUR_APP_ID")
.build()
BuzzBenefit.shared.initialize(with: config)
@import BuzzvilSDK;
BuzzBenefitConfig *config = [BuzzBenefitConfig configWithBlock:^(BuzzBenefitConfigBuilder * _Nonnull builder) {
builder.appID = @"YOUR_APP_ID";
}];
[[BuzzBenefit sharedInstance] initializeWithConfig:config];
다크 모드 설정하기
SDK를 초기화한 후에 BuzzBenefit.shared.setUserInterfaceStyle
를 호출하여 BuzzAd iOS용 SDK의 다크 모드를 설정하세요. 아래의 표는 다는 모드 설정 옵션을 나열합니다.
다크 모드 설정 옵션 | 설명 |
---|---|
BuzzBenefitUserInterfaceStyleLight | 시스템의 다크 모드 설정과 관계 없이 라이트 모드를 사용합니다. |
BuzzBenefitUserInterfaceStyleDark | 시스템의 다크 모드 설정과 관계 없이 다크 모드를 사용합니다. |
BuzzBenefitUserInterfaceStyleSystem | SDK의 다크 모드 설정 기본 값 입니다. 시스템의 다크 모드 설정을 사용합니다. |
다음은 SDK가 시스템의 다크 모드 설정을 사용하도록 설정하는 예시입니다.
- Swift
- Objective C
import BuzzvilSDK
@main
final class AppDelegate: UIResponder, UIApplicationDelegate {
func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey : Any]? = nil) -> Bool {
// ...생략...
BuzzBenefit.shared.setUserInterfaceStyle(.system)
return true
}
}
@import BuzzvilSDK;
@implementation AppDelegate
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
// ...생략...
[[BuzzBenefit sharedInstance] setUserInterfaceStyle:BuzzBenefitUserInterfaceStyleSystem];
return YES;
}
@end
로그인 요청하기
광고 할당을 요청하려면 로그인을 요청해야 합니다. 로그인 요청을 구성하는 항목에 대해서는 아래 표를 참고하세요.
❗️❗️❗️ 중요 ❗️❗️❗️
성별과 출생연도 정보는 권장으로 표기되어 있으나 등록하지 않으면 타겟팅 광고 송출이 불가능합니다. 버즈빌의 광고는 타겟팅 광고가 대부분이기에 해당 정보를 등록해야 정상적인 광고 할당이 가능합니다.
필수/권장 | 사용자 프로필 | 설명 |
---|---|---|
필수 | userId | 유저별로 고유하게 생성하는 ID로, 개인정보 식별은 불가능한 값입니다 (로그인 ID, 이메일 사용 불가). 서비스 도중 변하지 않는 고정 값이며, 광고 할당을 위한 필수 정보입니다. ASCII 형식의 65자 이하로 제한됩니다. ⚠️ 주의 ❗️❗️❗️ 앱을 삭제 후 재설치하여 사용자의 ID 값이 변경되거나 다른 사유로 인해 고정 ID를 사용하지 못하는 경우, 어뷰징 발생 가능성으로 인해 액션형 광고 송출이 불가능합니다. 사용자 고유 식별자가 변동되는 경우 버즈빌 사업 담당자에게 문의하세요. |
권장 | gender | 사용자의 성별입니다.
|
권장 | birthYear | 사용자의 출생연도입니다. |
다음은 SDK에 사용자 프로필을 등록하는 예시입니다. 등록한 사용자 프로필은 삭제할 수도 있습니다.
- Swift
- Objective C
// 로그인을 요청하는 코드입니다.
let buzzBenefitUser = BuzzBenefitUser.Builder(userID: "USER_ID")
.setGender(.male)
.setBirthYear(YYYY)
.build()
BuzzBenefit.shared.login(
with: buzzBenefitUser,
onSuccess: {
// 로그인이 성공한 경우 호출됩니다.
},
onFailure: { error in
// 로그인이 실패한 경우 호출됩니다.
}
)
// 로그인 상태를 확인하는 코드입니다.
BuzzBenefit.shared.isLoggedIn()
// 로그아웃하는 코드입니다.
BuzzBenefit.shared.logout()
BuzzBenefitUser *buzzBenefitUser = [BuzzBenefitUser userWithBlock:^(BuzzBenefitUserBuilder * _Nonnull builder) {
builder.userID = @"USER_ID";
builder.gender = BuzzBenefitUserGenderMale;
builder.birthYear = YYYY;
}];
[[BuzzBenefit sharedInstance] loginWithUser:buzzBenefitUser onSuccess:^{
// 로그인이 성공한 경우 호출됩니다.
} onFailure:^(NSError * _Nonnull error) {
// 로그인이 실패한 경우 호출됩니다.
}];
// 로그인 상태를 확인하는 코드입니다.
[[BuzzBenefit sharedInstance] isLoggedIn];
// 로그아웃하는 코드입니다.
[[BuzzBenefit sharedInstance] logout];
샘플 코드
Github 샘플 코드를 통해 실제 구현에 사용된 예제를 참고할 수 있습니다.
자주 하는 질문
질문 | 답변 |
---|---|
iOS 17에 대응하기 위해 적용된 사항이 궁금합니다. | iOS 17을 위한 대응 토픽을 참고하세요. |
iOS 14에 대응하기 위한 기능을 설정하고 싶습니다. | Buzzvil SDK는 iOS 14 이상에서 사용자에게 활동 추적 권한 허용 팝업을 표시하는 기능과 설치형 광고에 대한 전환을 추적하기 위해 애플의 SKAdNetwork를 지원합니다. 자세한 내용은 ATT(App Tracking Transparency, 앱 추적 투명성) 허용 다이얼로그 토픽을 참고하세요. |
Buzzvil SDK의 UI를 한꺼번에 변경하고 싶습니다. | 테마를 설정하여 SDK의 전반적인 색상과 아이콘을 변경할 수 있습니다. 자세한 내용은 전체 테마 토픽을 참고하세요. |
액션형 광고에 유저 문의 버튼을 추가해야하는 이유가 궁금합니다. | 액션형 광고를 할당할 경우, 안정적인 서비스 운영을 위해 유저의 문의 기능이 반드시 구현되어야 합니다. 자세한 내용은 액션형 광고의 유저 문의 기능 추가하기 토픽을 참고하세요. |
광고를 웹뷰(WebView)로 연결하고 싶습니다. | 커스텀 런처를 사용해 광고 랜딩 페이지를 인앱 브라우저로 열 수 있습니다. 자세한 내용은 커스텀 인앱 브라우저 사용하기 토픽을 참고하세요. |
동영상 광고 재생 옵션을 변경하고 싶습니다. | 동영상 광고 재생 조건 변경하기 토픽을 참고하세요. |
베네핏허브 또는 네이티브 지면의 광고 타입을 확인하고 싶습니다. | 광고 타입 확인하기를 참고하세요. |
오프라인으로 Buzzvil SDK를 연동하고 싶습니다. | 오프라인 빌드를 진행하려면 먼저 버즈빌에 제공하는 프레임워크를 준비하고 프로젝트에 프레임워크와 Run script를 추가해야 합니다. 자세한 내용은 오프라인 빌드 토픽을 참고하세요. |