Skip to content

5分钟集成自定义UI

jackning edited this page May 26, 2021 · 21 revisions

5 分钟集成在线客服

准备工作

  • 萝卜丝官网注册管理员账号,并登录管理后台。
  • 到 客服管理->渠道管理 添加网站/App
  • 到 客服管理->客服账号 有一列 ‘唯一 ID(uid)’ 会在指定客服接口中使用
  • 到 客服管理->技能组 有一列 ‘唯一 ID(wId)’ 会在技能组会话中用到
  • 获取管理员 uid, 登录后台->客服管理->客服账号->管理员账号(唯一 ID(uid))列
  • 获取 appkey,登录后台->客服管理->渠道管理->添加应用->appkey
  • 获取 subDomain,也即企业号:登录后台->客服管理->客服账号->企业号

开始集成

第一步:在总项目 build.gradle 的 allprojects -> repositories 添加

// 添加
mavenCentral()

修改完后,效果如下:

allprojects {
    repositories {
        google()
        // 萝卜丝第一步:
        // 添加
        mavenCentral()
    }
}

文件末尾添加

ext {
    // Sdk and tools
    minSdkVersion = 18
    targetSdkVersion = 26
    compileSdkVersion = 28
    buildToolsVersion = '28.0.3'
    supportLibVersion = '28.0.0'

    appcompatVersion= '1.1.0-rc01'
    butterknifeVersion = '10.1.0'
    recyleviewxVersion = '1.1.0-beta01'
    stethoVersion = '1.5.1'

    archLifecycleVersion = "2.2.0-alpha02"
    archRoomVersion = "2.1.0"
}

第二步:复制 bytedesk-ui 库到自己项目目录

开发者可以参考 demo,直接从 demo 目录中复制到自己项目中

第三步:在总项目的 settings.gradle 末尾添加

include ':bytedesk-ui'

添加完毕后,同步 Sync Now

第四步:在 module 的 build.gradle android{}添加

android {
    ...
    compileOptions {
        sourceCompatibility JavaVersion.VERSION_1_8
        targetCompatibility JavaVersion.VERSION_1_8
    }
    ...
}

第五步:在 module 的 build.gradle dependencies{}添加

// 萝卜丝第三步
// 加载萝卜丝核心库
implementation 'com.bytedesk:libcore:2.6.1'
// 加载萝卜丝默认UI库
implementation 'com.bytedesk:libui:2.6.1'

// 腾讯QMUI界面库
// http://qmuiteam.com/android/page/start.html
// https://bintray.com/chanthuang/qmuirepo
implementation 'com.qmuiteam:qmui:2.0.0-alpha10'
implementation "com.qmuiteam:arch:2.0.0-alpha10"

第六步:AndroidManifest.xml 添加权限

<!--添加萝卜丝权限-->
<uses-permission android:name="android.permission.WAKE_LOCK" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
<uses-permission android:name="android.permission.INTERNET" />

第七步:AndroidManifest.xml 添加 Activity 和 Service

<!--萝卜丝bytedesk.com代码 开始-->
<!--对话页面-->
<activity
    android:name="com.bytedesk.ui.activity.ChatKFActivity"
    android:theme="@style/AppTheme.ByteDesk"/>
<!--长连接service-->
<service android:name="com.bytedesk.paho.android.service.MqttService"/>
<!--下载录音-->
<service android:name="com.bytedesk.core.service.BDDownloadService"/>
<!--录音以及播放-->
<service android:name="com.bytedesk.ui.recorder.KFRecorderService"/>
<!--./萝卜丝bytedesk.com代码 结束-->

第八步:在样式文件 styles.xml 中添加

<!--添加萝卜丝样式 开始-->
<style name="AppTheme.ByteDesk" parent="QMUI.Compat.NoActionBar">
    <!--导航栏样式-->
    <item name="QMUITopBarStyle">@style/ByteDeskTopBar</item>
</style>
<style name="ByteDeskTopBar" parent="QMUI.TopBar">
    <!--导航栏背景颜色-->
    <item name="android:background">@color/app_color_blue</item>
    <!--导航栏字体颜色-->
    <item name="qmui_topbar_title_color">@color/qmui_config_color_white</item>
    <item name="qmui_topbar_subtitle_color">@color/qmui_config_color_white</item>
    <item name="qmui_topbar_text_btn_color_state_list">@color/qmui_config_color_white</item>
    <!--导航栏高度-->
    <item name="qmui_topbar_height">48dp</item>
    <item name="qmui_topbar_image_btn_height">48dp</item>
</style>
<!--添加萝卜丝样式 结束-->

第九部:初始化 UI 和建立长连接

参考 demo 中 MainActivity.java

// 初始化萝卜丝UI界面库
BDUiApi.init(this);
// 具体代码请参考MainActivity.java
anonymousLogin();

第十步:开始客服会话

// 打开客服对话界面
BDUiApi.startWorkGroupChatActivity(context, wId, "工作组客服");

集成完毕