Как реализовать видео чат Quickblox - PullRequest
0 голосов
/ 05 июля 2018

Я хочу интегрировать quickblox videochat в мое приложение для Android, но я не могу найти нужную документацию, я просмотрел сайт quickblox, но это не полезно и не так легко понять, если кто-то поможет, я буду благодарен.

Ответы [ 2 ]

0 голосов
/ 06 июля 2018

Ошибка получения -Тип программы уже присутствует: org.webrtc.CameraEnumerationAndroid $ CaptureFormat Message {kind = ERROR, text = Тип программы уже существует: org.webrtc.CameraEnumerationAndroid $ CaptureFormat, sources = [Неизвестный источник файл], имя инструмента = Optional.of (D8)}

ЭТО МОЙ УРОВЕНЬ УРОВНЯ APP

buildscript {
repositories {
    maven { url 'https://maven.fabric.io/public' }
}

dependencies {
    classpath 'io.fabric.tools:gradle:1.+'
}
}
apply plugin: 'com.android.application'

repositories {
maven { url 'https://maven.fabric.io/public' }
}


android {
compileSdkVersion 27
buildToolsVersion '27.0.3'
defaultConfig {
    applicationId "com.mindinfo.xchangemall.xchangemall"
    minSdkVersion 16
    targetSdkVersion 27
    versionCode 1
    versionName "1.0"
    multiDexEnabled true
    testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
}
buildTypes {
    release {
        minifyEnabled false
        proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard- 
rules.pro'
    }
}
dexOptions {
    javaMaxHeapSize "4g"
}
repositories {
    mavenCentral()
}
dataBinding {
    enabled = true
}
compileOptions {
    sourceCompatibility JavaVersion.VERSION_1_8
    targetCompatibility JavaVersion.VERSION_1_8
}
}
dependencies {
implementation fileTree(include: ['*.jar'], dir: 'libs')
implementation 'com.android.support.constraint:constraint-layout:1.1.0'

androidTestImplementation('com.android.support.test.espresso:espresso-core:2.2.2', {
    exclude group: 'com.android.support', module: 'support-annotations'
})

implementation('com.google.api-client:google-api-client-android:1.23.0') {
    exclude group: 'org.apache.httpcomponents'
}
implementation('com.google.apis:google-api-services-drive:v2-rev295-1.23.0') {
    exclude group: 'org.apache.httpcomponents'
}
//noinspection GradleCompatible
implementation 'com.android.support:multidex:1.0.3'
//noinspection GradleCompatible
implementation 'com.android.support:appcompat-v7:27.1.1'
implementation 'com.android.support:design:27.1.1'

implementation 'com.android.support:recyclerview-v7:27.1.1'

implementation 'com.google.android.gms:play-services-location:15.0.1'
implementation 'com.google.android.gms:play-services-gcm:15.0.1'
implementation 'com.google.android.gms:play-services-auth:15.0.1'
implementation 'com.google.android.gms:play-services-maps:15.0.1'
implementation 'com.google.android.gms:play-services-places:15.0.1'
implementation 'com.google.android.gms:play-services-plus:15.0.1'
implementation 'com.loopj.android:android-async-http:1.4.9'
implementation 'com.facebook.android:facebook-android-sdk:4.27.0'
implementation 'de.hdodenhof:circleimageview:2.2.0'
implementation 'com.yahoo.mobile.client.android.util.rangeseekbar:rangeseekbar- 
library:0.1.0'
testImplementation 'junit:junit:4.12'

implementation 'com.github.stfalcon:multiimageview:0.1'
implementation 'com.lorentzos.swipecards:library:1.0.9'
implementation 'com.github.midorikocak:currency-picker-android:1.1.9'
implementation 'com.baoyz.pullrefreshlayout:library:1.2.0'
implementation 'com.google.firebase:firebase-core:16.0.0'
implementation 'com.google.firebase:firebase-analytics:16.0.0'
implementation 'com.google.firebase:firebase-crash:16.0.0'
implementation 'com.google.firebase:firebase-messaging:17.0.0'
implementation 'com.google.firebase:firebase-config:16.0.0'
implementation 'com.google.firebase:firebase-invites:16.0.0'
implementation 'com.futuremind.recyclerfastscroll:fastscroll:0.2.5'
implementation 'me.relex:circleindicator:1.2.2@aar'
implementation('com.crashlytics.sdk.android:crashlytics:2.7.1@aar') {
    transitive = true
}

implementation 'com.github.bumptech.glide:glide:4.7.1'
annotationProcessor 'com.github.bumptech.glide:compiler:4.7.1'
implementation "com.quickblox:quickblox-android-sdk-videochat-webrtc:3.8.1"
}
apply plugin: 'com.google.gms.google-services'
apply plugin: 'io.fabric'

ЭТО МОЙ УРОВЕНЬ УРОВНЯ ПРОЕКТА: -

buildscript {
//    ext.kotlin_version = '1.2.30'
//    ext.roomVersion = '1.0.0'
repositories {
    mavenCentral()
    google()
   jcenter()
    maven {
        url 'https://maven.google.com/' }

    maven {
        url 'https://maven.fabric.io/public'
    }
    maven { url "https://raw.githubusercontent.com/HyphenateInc/Hyphenate-        
 SDK-Android/master/repository" }

}
dependencies {
    classpath 'com.android.tools.build:gradle:3.1.2'
    classpath 'com.google.gms:google-services:3.0.0'
    classpath 'com.neenbedankt.gradle.plugins:android-apt:1.8'
    classpath 'io.fabric.tools:gradle:1.25.4'


}
}
allprojects {
repositories {
    mavenCentral()
    jcenter()
    maven {
        url "https://github.com/QuickBlox/quickblox-android-sdk- 
releases/raw/master/"
    }
    maven {
        url 'https://maven.google.com/' }
    maven { url "https://raw.githubusercontent.com/HyphenateInc/Hyphenate- 
 SDK-Android/master/repository" }
    maven { url "https://jitpack.io" }

}
}

task clean(type: Delete) {
delete rootProject.buildDir
}
0 голосов
/ 05 июля 2018

Во-первых, вам нужно включить сигнализацию. Используя приведенный ниже код, вы можете сделать звонок или принять звонок.

QBRTCClient.getInstance(context).prepareToProcessCalls();
QBChatService.getInstance().getVideoChatWebRTCSignalingManager()
                .addSignalingManagerListener(new QBVideoChatSignalingManagerListener() {
                    @Override
                    public void signalingCreated(QBSignaling qbSignaling, boolean createdLocally) {
                        if (!createdLocally) {
                            QBRTCClient.getInstance(context).addSignaling((QBWebRTCSignaling) qbSignaling);
                        }
                    }
                });

Затем вам нужно добавить сеанс обратного вызова, который поможет вам входящие звонки

QBRTCClient.getInstance(context).addSessionCallbacksListener(this);

Теперь он переопределяет один из onReceiveNewSession . В этом методе вы будете получать вызов, когда противник звонит вам.

Чтобы позвонить,

 QBRTCTypes.QBConferenceType qbConferenceType = QB_CONFERENCE_TYPE_VIDEO;
 List<Integer> opponents = new ArrayList<Integer>();
 opponents.add(userid); //12345 - QBUser ID
 //Set user information
 Map<String, String> userInfo = new HashMap<>();
 userInfo.put("key", "value");
  //Init session
  QBRTCSession session = QBRTCClient.getInstance(this).createNewSessionWithOpponents(opponents, qbConferenceType);
 //Start call
 session.startCall(userInfo);

Чтобы принять звонок

@Override
    public void onReceiveNewSession(QBRTCSession qbrtcSession) {
       qbrtcSession.acceptCall(qbrtcSession.getUserInfo());
    }
...