iOS Click to Call¶
Пример Click to Call для iOS¶
Данный пример позволяет сделать аудиозвонок одним кликом кнопки, используя аккаунт заданный в файле настроек сервера
/usr/local/FlashphonerWebCallServer/conf/apps/click-to-call/accounts.xml

Работа с кодом примера¶
Для разбора кода возьмем версию примера ClickToCall, которая доступна здесь.
Класс для основного вида приложения: ViewController (заголовочный файл ViewController.h; файл имплементации ViewController.m).
1. Импорт API¶
2. Подключение к серверу¶
FPWCSApi2.createSession, FPWCSApi2Session.connect code
В параметрах сессии указываются:
- URL WCS-сервера
- имя серверного приложения clickToCallApp
- (FPWCSApi2Session *)connect {
FPWCSApi2SessionOptions *options = [[FPWCSApi2SessionOptions alloc] init];
options.urlServer = _connectUrl.text;
options.appKey = @"clickToCallApp";
NSError *error;
session = [FPWCSApi2 createSession:options error:&error];
...
[session connect];
return session;
}
3. Получение от сервера события, подтверждающего успешное соединение¶
ViewController.onConnected, ViewController.call code
При получении данного события вызывается метод ViewController.call для совершения звонка.
4. Исходящий звонок¶
FPWCSApi2Session.createCall, FPWCSApi2Call.call code
При создании звонка в метод createCall передаются параметры:
- имя вызываемого SIP-аккаунта
- параметры звонка: только аудио
- (FPWCSApi2Call *)call {
FPWCSApi2CallOptions *options = [[FPWCSApi2CallOptions alloc] init];
options.callee = _callee.input.text;
options.localConstraints = [[FPWCSApi2MediaConstraints alloc] initWithAudio:YES video:NO];
NSError *error;
call = [session createCall:options error:&error];
...
[call call];
return call;
}
5. Завершение звонка¶
FPWCSApi2Call.hangup code