Callback
Android 버전의 Kakao i Connect Live SDK에서 제공하는 Callback 메서드는 다음과 같습니다.
공통
일대일 통화, 방송, 그룹 통화에서 공통적으로 사용되는 Callback 메서드는 다음과 같습니다.
onInit()
onInit() Callback 메서드는 SDK가 Kakao i Connect Live 서버에 정상적으로 접속하여 방송 또는 통신 인프라를 사용할 준비가 완료되었을 때 호출됩니다. onInit() 메서드는 일반적인 경우에는 사용되지 않으며, 디버깅(Debugging) 용도로만 사용됩니다.
코드예제onInit() Syntax
remonCast.onInit(() -> {
... // 서비스에 맞게 구현
});
remonCast.onInit {
... // 서비스에 맞게 구현
}
onClose()
onClose() Callback 메서드는 사용자 또는 상대방이 명시적으로 close() 메서드를 호출하거나, 네트워크 이상 등으로 연결이 종료될 때 호출됩니다. onClose() Callback이 호출되면 Remon 클래스에서 사용했던 모든 자원들의 연결이 해제됩니다.
코드예제onClose() Syntax
remonCast.onClose((closeType) -> {
... // 서비스에 맞게 구현
});
remonCast.onClose { closeType: CloseType ->
... // 서비스에 맞게 구현
}
파라미터 | 타입 | 필수 여부 | 설명 |
---|---|---|---|
closeType | CloseType | 선택 |
연결 종료에 대한 구분 |
CloseType.MINE : 자신이 close() 메서드를 호출하여 연결을 끊은 경우 |
|||
CloseType.OTHER : 상대방이 close() 메서드를 호출하여 연결을 끊은 경우 |
|||
CloseType.OTHER_UNEXPECTED : 상대방의 연결이 끊어져서 연결이 끊긴 경우 |
|||
CloseType.UNKNOWN : 알 수 없는 이유로 연결이 종료된 경우 |
onError()
onError() Callback 메서드는 Remon
클래스 동작 중 에러가 발생했을 때 호출됩니다.
코드예제onError() Syntax
remonCall.onError((RemonException error) -> {
switch(error.getRemonError()) {
case initError:
break;
case restInitError:
break;
case wsError:
break;
case wsResponseError:
break;
case iceError:
break;
case mediaError:
break;
case connectionTimeout:
break;
case unknown:
break;
}
});
remonCall.onError { error: RemonException ->
when (error.remonError) {
RemonError.initError ->
RemonError.restInitError ->
RemonError.wsError ->
RemonError.wsResponseError ->
RemonError.iceError ->
RemonError.mediaError ->
RemonError.connectionTimeout ->
RemonError.unknown ->
}
}
파라미터 | 타입 | 필수 여부 | 설명 |
---|---|---|---|
error | String | 필수 |
연결 오류에 대한 구분 및 타입 |
initError : 인증 오류(ex. 유효하지 않은 Service ID 사용) |
|||
restInitError : REST API 호출 실패(ex. 서버 응답 없음, 토큰 만료) |
|||
wsError : 웹소켓 연결 실패 |
|||
wsResponseError : 웹 소켓 오류 응답 |
|||
iceError : WebRTC API에서 발생한 오류 |
|||
mediaError : 미디어 송수신 오류 |
|||
connectionTimeout : SDK 연결 타임아웃 오류 |
|||
unknown : 알 수 없는 이유 또는 기타 오류 |
onStat()
사용자는 간혹 자신 또는 상대방의 네트워크 문제로 인하여 통화 품질이 안 좋거나 끊어진 상황에서도 네트워크 문제가 아닌 서비스 문제라고 생각하고 불만을 제기할 수 있습니다. 해당 경우에는 사용자에게 서비스 문제가 아닌 네트워크 문제임을 사전에 알려주거나 또는 다양한 UI 처리를 통해 정확한 안내를 하는 것이 좋습니다.
네트워크 상황 등에 따른 미디어 품질 문제를 정확하게 파악하기 위해서는 onState(report) Callback 메서드를 통해 통화 또는 방송 상태를 알 수 있는 report를 수신할 수 있습니다. report는 사용자가 remon
클래스 생성 시에 설정한 statInterval 간격을 기준으로 제공됩니다. 해당 report는 네트워크 상황과 같은 미디어 품질을 나타내기 때문에 사용자에게 로딩 UI 처리 등을 안내하는 경우에 유용하게 사용할 수 있습니다. report에 들어오는 값은 현재 통화 품질(음성 또는 영상)에 대해 다음과 같이 총 다섯 단계로 구분되어 표시됩니다. 현재 이러한 통화 품질 정보는 5초에 한 번씩 받을 수 있으며, result에서 받을 수 있는 여러 정보 중 result.rating은 네트워크 상황에 따른 통합적인 통화 품질 정보를 의미합니다.
단계 | 품질 |
---|---|
1 | 매우 좋은 상태 |
2 | 좋은 상태 |
3 | 나쁜 상태 |
4 | 매우 나쁜 상태 |
5 | 방송 또는 통화가 불가능한 상태 |
코드예제onStat() Syntax
remonCall.onStat(statReport -> {
Logger.i(TAG, "report: " + report.getHealthRating());
String stat = "health:" + report.getHealthRating().getLevel() + "\n";
});
remonCall.onStat { report:RemonStatReport ->
Logger.i(TAG, "report: " + report.getHealthRating())
val stat:String = "health:" + report.getHealthRating().getLevel() + "\n"
}
방송
방송 서비스에서 제공하는 Callback 메서드는 다음과 같습니다.
onCreate()
onCreate() Callback 메서드는 방송 Caster에게만 사용되며, Caster는 create() 메서드를 통해 방송을 정상적으로 생성하고 송출합니다. onCreate() 메서드는 고유 구분자인 Channel ID를 생성하며, Viewer들은 해당 Channel ID를 사용하여 방송에 접속할 수 있습니다.
코드예제onCreate() Syntax
remonCast.onCreate((channelId) -> {
... // 서비스에 맞게 구현
});
remonCast.create("{CHANNEL_NAME}");
remonCast.onCreate {(channelId)->
... // 서비스에 맞게 구현
}
remonCast.create("{CHANNEL_NAME}")
구분 | 타입 | 필수 여부 | 설명 |
---|---|---|---|
channelld | String | 선택 |
Caster가 생성한 방송의 고유 아이디 - Channel ID 생성 규칙에 따라 생성할 수 있으며, 미지정 시 자동 생성됨 |
onJoin()
onJoin() Callback 메서드는 방송에 Viewer에게만 사용하며, Viewer가 join() 메서드의 Channel ID를 통해 연결이 완료되어 미디어 시청이 가능한 상태가 되면 호출됩니다.
코드예제onJoin() Syntax
remonCast.onJoin(() ->
... // 서비스에 맞게 구현
});
remonCast.join('{CHANNEL_ID}');
remonCast.onJoin {
... // 서비스에 맞게 구현
}
remonCast.join('{CHANNEL_ID}')
구분 | 타입 | 필수 여부 | 설명 |
---|---|---|---|
CHANNEL_ID | String | 필수 |
Caster가 생성한 방송의 고유 아이디 - Viewer는 해당 Channel ID를 사용하여 방송에 접속 |
통화
통화 서비스에서 제공하는 Callback 메서드는 다음과 같습니다.
onConnect()
onConnect() Callback 메서드는 통화에서만 사용됩니다. 채널을 생성하여 통화를 요청하는 Caller와 해당 채널에 접속하여 요청에 응답하는 Callee의 동작이 다른 경우가 많기 때문에, 개발자는 Caller 또는 Callee 여부에 대한 상태를 관리에 주의해야 합니다.
- Caller는 connect() 메서드를 통해 채널을 새로 만들고, 상대방의 입장을 기다립니다.
- Callee는 connect() 메서드를 통해 이미 만들어진 채널에 Channel ID 정보를 가지고 접속합니다.
- Callee가 정상적으로 채널에 연결되면 onConnect() 메서드가 호출되지만, 곧바로 발생하는 onComplete() 메서드를 사용하는 것을 권장합니다.
코드예제onConnect() Syntax
remonCall.onConnect((channelId) -> {
... // 서비스에 맞게 구현
});
remonCall.connect("{CHANNEL_ID}");
remonCall.onConnect{ channelId ->
... // 서비스에 맞게 구현
}
remonCall.connect("{CHANNEL_ID}")
구분 | 타입 | 필수 여부 | 설명 |
---|---|---|---|
channelld | String | 선택 |
Caster가 생성한 통화의 고유 아이디 - Channel ID 생성 규칙에 따라 생성할 수 있으며, 미지정 시 자동 생성됨 |
onComplete()
onComplete() Callback 메서드는 통화에서만 사용되며, Caller와 Callee가 연결이 완료되어 미디어 전송이 가능한 상태가 되면 호출됩니다.
코드예제onComplete() Syntax
remonCall.onComplete(() -> {
... // Caller와 Callee가 정상적으로 연결되어 통화 시작
});
remonCall.onComplete {
... // Caller와 Callee가 정상적으로 연결되어 통화 시작
}
Config
Kakao i Connect Live SDK는 RemonCall 또는 RemonCast 객체에 직접 설정 정보를 지정할 수 있습니다. 이러한 설정 정보를 별도의 객체에 생성해 두고, RemonCall 또는 RemonCast 객체를 생성할 때마다 해당 설정값을 사용하고자 하거나 또는 다른 화면에서 설정값을 방송 또는 통신 화면으로 전달해야하는 경우에 Config 값을 사용할 수 있습니다.
RemonCall 또는 RemonCast 객체의 connect() 메서드 호출 시에는 Config 정보와 함께 전달하며, RemonCall 또는 RemonCast 내부의 설정이 아닌 Config 설정을 사용해 연결이 이루어집니다. Android의 경우에는 Config 객체를 사용합니다.
View 설정
영상이 표출될 View를 지정하는 설정입니다. View 설정을 하지 않으면 영상이 보이지 않습니다.
코드예제View 설정
Config config = new com.remotemonster.sdk.Config();
config.setLocalView((SurfaceViewRenderer) findViewById(R.id.local_video_view));
config.setRemoteView((SurfaceViewRenderer) findViewById(R.id.remote_video_view));
Config config = com.remotemonster.sdk.Config()
config.localView = findViewById(R.id.local_video_view)
config.remoteView = findViewById(R.id.remote_video_view)
Meta 데이터 설정
사용자의 UID(User ID) 또는 프로퍼티 등 서비스에 필요한 메타 데이터를 설정할 수 있습니다.
코드예제Meta 데이터 설정
HashMap<String, Object> meta = new HashMap<>();
meta.put("uid", "{USER ID}");
Config config = new com.remotemonster.sdk.Config();
config.setMeta(meta);
var meta = hashMapOf<String, Object>()
meta.put("uid", "{USER ID}")
var config = com.remotemoster.sdk.Config()
config.meta = meta
Media
음성 방송/통화 설정
비디오를 사용하지 않고, 음성 방송 또는 음성 통화 서비스를 만들 수 있습니다.
코드예제음성 방송/통화 설정
// 비디오를 사용하지 않고 음성만 사용 시
config.setVideoCall(false); // false로 설정 시 비디오를 사용하지 않음
// 비디오와 오디오를 모두 사용 시
config.setVideoCall(true);
// 비디오를 사용하지 않고 음성만 사용 시
config.videoCall = false // false로 설정 시 비디오를 사용하지 않음
// 비디오와 오디오를 모두 사용 시
config.videoCall = true
비디오 옵션 설정
WebRTC는 기본적으로 네트워크나 단말의 상태에 따라 해상도와 Frame Rate 등을 유연하게 변화시키면서 품질을 유지합니다. 따라서 해상도를 특정값으로 설정하더라도 설정된 해상도가 정확하게 유지되지 않을 수 있습니다. 이러한 경우에는 코덱 등의 옵션을 변경하여 해상도를 최적으로 설정할 수 있습니다.
코드예제비디오 옵션 설정
config.setVideoWidth(640);
config.setVideoHeight(480);
config.setVideoCodec("VP8");
config.setVideoFps(15);
config.setStartVideoBitrate(700);
config.videoWidth = 640
config.videoHeight = 480
config.videoCodec = "VP8"
config.videoFps = 15
config.startVideoBitrate = 700
파라미터 | 타입 | 필수 여부 | 설명 |
---|---|---|---|
videoWidth | Integer | 선택 |
상대에게 보낼 영상의 가로 해상도 |
videoHeight | Integer | 선택 |
상대에게 보낼 영상의 높이 해상도 |
videoCodec | String | 선택 |
브라우저에서 지원하는 코덱으로, 필요 시 다른 코덱으로 변경 필요 |
H.264 (기본값) |
|||
VP8 |
|||
VP9 |
|||
videoFps | Integer | 선택 |
비디오의 초당 프레임 수 |
startVideoBitrate | Integer | 선택 |
해당 비디오의 대역폭을 설정 - 앱의 전체적인 네트워크 트래픽을 고려하여 적절한 값을 설정 필요 |
오디오 타입 설정
오디오 출력 시 주변 소음을 제거하는 기능과 관련한 작동 유형을 설정할 수 있습니다.
코드예제오디오 타입 설정
config.setAudioType( AudioType.VOICE );
config.audioType = AudioType.VOICE
파라미터 | 타입 | 필수 여부 | 설명 |
---|---|---|---|
AudioType | String | 선택 |
오디오 타입 설정 |
AudioType.MUSIC : 모든 소리를 가공없이 전달- 방송(RemonCast)에서는 기본값으로 설정 |
|||
AudioType.VOICE : 주변 소음을 제거하고 음성을 전달- 통화(RemonCall)에서는 기본값으로 설정 |
오디오 추가 설정
오디오에 다양한 세부 항목을 추가로 설정할 수 있습니다. 오디오 추가 설정 항목은 방송 또는 통화 환경과 목적에 따라 최적의 설정이 다를 수 있으므로, 설정 항목들을 적절히 조합하여 사용하시기 바랍니다.
코드예제오디오 추가 설정
config.setAudioCodec("OPUS");
config.setAudioStartBitrate(48);
config.audioCodec = "OPUS"
config.audioStartBitrate = 48
파라미터 | 타입 | 필수 여부 | 설명 |
---|---|---|---|
audioCodec | String | 선택 |
오디오 코덱을 설정 |
OPUS (기본값) |
|||
ISAC |
|||
audioStartBitrate | Integer | 선택 |
오디오 품질과 관련된 초기 오디오 비트 전송률 설정 |
Debug
Debug(디버그) 레벨을 설정하여 WebRTC의 세부적인 로그를 출력할 수 있습니다. 해당 레벨 모드는 RemonConfig를 사용하여 통화 또는 방송을 생성하는 경우에만 가능합니다. VERBOSE 로그 레벨로 갈수록 더욱 자세한 내용을 확인할 수 있습니다.
코드예제Debug Syntax
config.setLogLevel(Log.DEBUG); // ERROR, WARN, INFO, DEBUG, VERBOSE 순으로 로그 레벨을 설정
config.setLogLevel = Log.DEBUG // ERROR, WARN, INFO, DEBUG, VERBOSE 순으로 로그 레벨을 설정
구분 | 설명 |
---|---|
ERROR | 오류를 일으킨 문제뿐만 아니라 더 낮은 레벨의 메시지도 목록에 출력 |
WARN | 아직 오류는 아니지만 발생할 수 있는 경고성 로그와 더 낮은 레벨(ERROR)의 메시지도 목록에 출력 |
INFO | 예상할 수 있는 진행사항 또는 상태 정보 이상의 로그와 더 낮은 레벨(WARN, ERROR)의 메시지도 목록에 출력 |
DEBUG | 개발 단계에서만 유용한 디버그 로그와 더 낮은 레벨(INFO, WARN, ERROR)의 메시지도 목록에 출력 |
VERBOSE | 모든 로그의 메시지 출력 |