Hướng dẫn xây dựng ứng dụng gọi video 1-1 trên nền tảng Android với Stringee Call API

Tram Ho

Tổng quan về Stringee Call API

Stringee Call API là cách dễ nhất để xây dựng các ứng dụng thoại chất lượng cao trên Đám mây. Với Call API của Stringee, bạn có thể:

Xây dựng ứng dụng mở rộng quy mô với các công nghệ web bạn chọn.
Mua số điện thoại động.
Mở rộng cơ sở hạ tầng của bạn với Giao diện SIP.
Kiểm soát luồng cuộc gọi trong JSON bằng Đối tượng điều khiển cuộc gọi Stringee. (SCCO):
Thực hiện cuộc gọi giữa ứng dụng với ứng dụng (cuộc gọi ngang hàng) HOẶC cuộc gọi từ ứng dụng tới điện thoại (cuộc gọi đi).
Nhận và quản lý cuộc gọi điện thoại (cuộc gọi đến): chuyển cuộc gọi đến ứng dụng, từ chối cuộc gọi, ghi âm, v.v.
Ghi âm và lưu trữ cuộc gọi.
Tạo cuộc gọi hội nghị.

Chuẩn bị

Trước khi bạn có thể dùng Stringee Call API để tạo và nhận cuộc gọi video, bạn cần :

  1. Tạo tài khoản Stringee miễn phí <a href = https://asia-1.console.stringee.com/account/register target = “_blank”>tại đây</a>.
  2. Tạo project trên <a href = https://asia-1.console.stringee.com target = “_blank”>Stringee Dashboard</a>

image.png

  1. Cấu hình answer_url
  • Để hiểu rõ hơn về answer_url, bạn xem <a href = https://developer.stringee.com/docs/call-api-overview target = “_blank”>tại đây</a> .Bạn có thể tham khảo cách tạo answer_url <a href = https://github.com/stringeecom/server-samples/tree/master/answer_url target = “_blank”>tại đây</a>
  • Để có thể thực hiện cuộc gọi bạn cần cấu hình answer_url vào project của bạn như sau:

image.png

Nếu bạn chưa có sẵn answer_url, bạn có thể sử dụng Project’s answer_url sau để đẩy nhanh quá trình:

(Source code: https://github.com/stringeecom/server-samples/blob/master/answer_url/php/project_answer_url.php)
Khi xây dựng ứng dụng, bạn nên có answer_url của riêng mình.

Tích hợp Stringee SDK

Chuẩn bị

  1. Tạo một project Android với minSdkVersion >= 16.
  2. Tạo class MainActivity làm màn hình chính để thực hiện việc kết nối đến Stringee Server.
  3. Tạo class CallActivity để hiển thị màn hình của cuộc gọi.

Cài đặt Stringee SDK

Stringee Android SDK được phân phối dưới dạng AAR và có thể được thêm vào dự án của bạn bằng cách tham chiếu AAR từ xa với Maven.

  1. Mở file build.gradle và thêm các dòng sau:
  2. Mở file app/build.gradle và thêm các dòng sau:

Chỉnh sửa Permissions và proguard

Permissions

Stringee Android SDK yêu cầu một số permissions, mở file AndroidManifest.xml và thêm các dòng sau:

Ghi chú:

  • Bạn bắt buộc phải cấp đủ quyền trước khi thực hiện cuộc gọi, trước khi thực hiện cuộc gọi bạn bắt buộc yêu cầu các quyền sau: RECORD_AUDIO, CAMERA
  • Với việc sử dụng class StringeeAudioManager bạn cần cấp thêm quyền BLUETOOTH_CONNECT đối với Android SDK version 31 trở lên

ProGuard

Nếu project của bạn sử dụng ProGuard, bạn cần thêm các cài đặt sau vào file proguard-rules.pro để đảm bảo khi build ra bản release Stringee SDK có thể chạy được chính xác:

Kết nối Stringee server

Để kết nối đến Stringee Server, bạn cần có access_token. Trong quá trình xây dựng ứng dụng, access_token nên được tạo ra từ server của bạn, bạn có thể tìm hiểu thêm về authentication ở đây: <a href = https://developer.stringee.com/docs/client-authentication target = “_blank”>Client authentication</a>), và code mẫu tạo access_token: https://github.com/stringeecom/server-samples/tree/master/access_token.

Để tiết kiệm thời gian, chúng tôi sẽ hard code access_token ở trong ứng dụng:

  1. Ở class MainActivity, khởi tạo một biến để chứa access_token.
  2. Lấy access_token và hard code dữ liệu :
    Để làm điều đó, chúng tôi đã cung cấp sẵn tool để sinh ra access_token, bạn truy cập vào <a href = https://developer.stringee.com/tool target = “_blank”>Dashboard -> Tools -> Generate Access token</a> và sinh access_token của bạn.

Tiếp theo, chúng ta sẽ kết nối đến Stringee Server. Bạn cần phải kết nối được đến Stringee Server trước thì mới có thể thực hiệc được cuộc gọi.

  1. Thêm đối tượng StringeeClient vào class MainActivity.
  2. Khởi tạo đối tượng StringeeClient và lắng nghe sự kiện từ StringeeConnectionListener để giao tiếp với Stringee Server:
  • Khi client kết nối thành công đến Stringee Server, hàm onConnectionConnected(StringeeClient stringeeClient, boolean isReconnecting) được gọi đến.
  • Khi client mất kết nối với Stringee Server, hàm onConnectionDisconnected(StringeeClient stringeeClient, boolean isReconnecting) được gọi đến.
  • Khi client kết nối thất bại đến Stringee Server, hàm onConnectionError(StringeeClient stringeeClient, StringeeError stringeeError) được gọi đến.
  • Khi access_token hết hạn, hàm onRequestNewToken(StringeeClient stringeeClient) được gọi đến. Bạn sẽ cần tạo lại access_token mới và kết nối lại.
  • Khi client nhận được cuộc gọi đến, ở đây chúng ta dùng đối tượng StringeeCall2 để thực hiện cuộc gọi video nên hàm onIncomingCall2(StringeeCall2 stringeeCall2) được gọi đến.
  1. Nếu bạn sử dụng On-Premise Server, bạn cần thêm những dòng sau để có thể kết nối được:
  • ip: ip của server của bạn ở dạng String.
  • port: port của server của bạn ở dạng int.

Ghi chú: Bạn cần phải setHost trước khi kết nối.

  1. Kết nối đến Stringee Server bằng access_token được tạo ra ở trên:

Xử lý logic cuộc gọi

Sau khi kết nối đến Stringee Server, bạn cần thực hiện các bước sau:

  1. Thêm đối tượng stringeeCall2 vào class CallActivity:
  2. Lắng nghe sự kiện của cuộc gọi:
  • Khi tạo/trả lời cuộc gọi thất bại, hàm onError(StringeeCall stringeeCall, int code, String description) được gọi đến.
  • Khi tạo/trả lời cuộc gọi thành công, cuộc gọi sẽ đi qua rất nhiều trạng thái như là: CALLING, RINGING, ANSWERED, ENDED, BUSY. Mỗi lần trạng thái của cuộc gọi thay đổi, hàm onSignalingStateChange(StringeeCall call, StringeeCall.SignalingState signalingState, String reason, int sipCode, String sipReason) được gọi đến.
  • Khi media stream của cuộc gọi đã kết nối hoặc mất kết nối, hàm onMediaStateChange(StringeeCall stringeeCall, StringeeCall.MediaState mediaState) được gọi đến.
  • Khi cuộc gọi được xử lý trên thiết bị khác, hàm onHandledOnAnotherDevice(StringeeCall stringeeCall, StringeeCall.SignalingState signalingState, String description) được gọi đến.
  • Một cuộc gọi thực sự được thành công khi trạng thái của mediaMediaState.CONNECTED.

Tạo cuộc gọi đi

Để tạo cuộc gọi đi bạn cần thực hiện các bước sau:

  1. Khởi tạo stringeeCall2:
  • client: Đối tượng StringeeClient đã được khởi tạo và dùng để connect đến Stringee Server trước đó. Cần đảm bảo đã kết nối đến Stringee Server thành công và vẫn đang giữ kết nối .
  • from: id của người gọi.
  • to: is của người nhận.
  • Mặc định là cuộc gọi thoại nên nếu bạn muốn khởi tạo cuộc gọi video bạn cần gọi hàm** setVideoCall(true)** trước khi gọi hàm makeCall() và sau khi khởi tạo StringeeCall2.
  1. Thực hiện cuộc gọi:

Trả lời cuộc gọi

Để có thể trả lời được cuộc gọi đến, bạn làm theo những bước sau:

  1. Xử lý nhận cuộc gọi ở hàm onIncomingCall2(StringeeCall2 stringeeCall2) thuộc StringeeConnectionListener.

    Lưu trữ stringeeCall2 vào đối tượng HashMap() với khóa là callId. Sau đó gửi callId của cuộc gọi sang class CallActivity.
  2. Gán StringeeCall2 từ callsMap:
  3. Gửi tín hiệu RINGING:

    Như việc khởi tạo cuộc gọi, ta cần lắng nghe các sự kiện của cuộc gọi

  4. Trả lời và bắt đầu cuộc gọi:

Hiển thị video

Stringee Android SDK hiển thị video của người gọi và người nhận dưới dạng đối tượng View. Bạn có thể thêm chúng như là con của một đối tượng ViewGroup ở ứng dụng. Ở sample, chúng tôi sử dụng đối tượng FrameLayout làm vùng chứa cho video của người gọi và người nhận:

  1. Mở file app/res/layout/activity_call.xml và thêm các dòng sau:
  2. Khai báo vLocal and vRemote trong class CallActivity.
  3. Hiển thị video:

    Sau khi nhận được sự kiện onLocalStream(StringeeCall2 stringeeCall2), ta có thể thêm video của mình vào vLocal:

    Tương tự như onLocalStream, ta có thể thêm video của người bên kia vào vRemote sau khi nhận được event onRemoteStream(StringeeCall2 stringeeCall2):

    Việc thêm view của video cần được thực hiện dưới background UI thread để có thể giao tiếp được với UI components.

Một số tính năng trong cuộc gọi

Ngừng cuộc gọi

Ngừng cuộc gọi và giải phóng tài nguyên của cuộc gọi:

Từ chối cuộc gọi

Từ chối cuộc gọi:

Tắt tiếng

Tắt tiếng của mình:

Chuyển đổi loa

Chuyển đổi giữa loa trong và loa ngoài bằng StringeeAudioManager:

Đổi camera

Đổi trước và sau camera của mình:

Tắt/Mở video

Tắt/Mở video:

Chạy app

Bây giờ ứng dụng của bạn có thể chạy được trên thiết bị. Bạn có thể tham khảo sample phiên bản đầy đủ <a href = https://github.com/stringeecom/android-sdk-samples/tree/master/OneToOneCallSample target = “_blank”>ở đây</a>

Kết luận

Trên đây là hướng dẫn xây dựng ứng dụng gọi video 1-1 trên nền tảng Android với Stringee Call API. Hy vọng bạn có thể tự mình thiết lập một ứng dụng gọi video theo như hướng dẫn của Stringee. Ngoài ra, bạn có thể học cách xây dựng ứng dụng gọi video trên nền tảng iOS <a href = https://stringee.com/vi/blog/post/tutorial-building-an-iOS-video-call-%20app-with-Stringee-Call-API target = “_blank”>tại đây</a>).

Chia sẻ bài viết ngay

Nguồn bài viết : Viblo