Skip to content

Commit

Permalink
feat: update NEMeetingKit Android to v3.16.1 (#218)
Browse files Browse the repository at this point in the history
* feat: update NEMeetingKit Android to v3.16.1

* fix: update doc

* fix: clean code.

* chore: update CHANGELOG.md.

---------

Co-authored-by: ChandarLee <[email protected]>
  • Loading branch information
smartzhao and chandarlee authored Sep 12, 2023
1 parent 151c853 commit a6045f2
Show file tree
Hide file tree
Showing 22 changed files with 446 additions and 144 deletions.
221 changes: 221 additions & 0 deletions SampleCode/Android/CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,221 @@
# NEMeetingKit ChangeLog
## v3.16.1(SEP 8, 2023)
- 适配Android 版本低于8.0无法使用画中画功能,默认以最小化

## v3.16.0(SEP 6, 2023)
### New Feature
- 会议最小化开启小窗悬浮,小窗模式下退入后台,在Android 8.0及以上系统会开启画中画

### Bug Fixes
- 网络监测toast与白板toast重复问题
- 被踢时,rtc回调与IM回调时序问题

### Compatibility
- 兼容 NERoomKit 1.20.0
- 兼容 NIMSDK_LITE 9.12.0
- 兼容 NERtcSDK 5.4.8

## v3.15.2(Aug 23, 2023)
### New Features
* 修改会议网络监听,state连续三次为poor时,toast网络异常提示
* 增加弱网或网络断开监听,收到NERoomConnectType.Disconnect显示会议重连loading,收到NERoomConnectType.Reconnect则关闭
* 增加网络异常会议断开监听,增加重新入会弹窗,可以返回首页或重新入会(复用最开始入会的参数)
### Compatibility
* 兼容 `NERoom` 1.19.2 版本
* 兼容 `NIM` 9.12.0 版本
* 兼容 `NERtc` 5.3.11 版本

## v3.15.0(Aug 11, 2023)
### New Features
* 移动端升级Flutter版本至3.10.5
* 优化RTC私有化配置服务
* 会议组件:优化入会协议-entry/config/snapshot/joinRtc合并为一个接口
* 网易会议升级RTC 5.4.3、IM 9.12.0 、白板3.9.6(NERoom升级)
* 网易会议反馈优化-移动端反馈日志下载地址提供全路径
* 请求头区分不同跨端框架
### Compatibility
* 兼容 `NERoom` 1.19.0 版本
* 兼容 `NIM` 9.12.0 版本
* 兼容 `NERtc` 5.4.3 版本

## v3.14.0(July 05, 2023)
### New Features
* 优化大房间信令交互;
### Compatibility
* 兼容 `NERoom` 1.17.0 版本
## v3.13.2(July 19, 2023)
### New Features
* 新增`NERoomRtcController.enableEncryption`,支持开启媒体流加密;
* 新增`NERoomRtcController.disableEncryption`,支持关闭媒体流加密;
### Bug Fixes
* 修复预约会议password等部分字段为空问题;
### Compatibility
* 兼容 `NERoom` 1.16.1 版本
* 兼容 `NIM` 9.10.0 版本
* 兼容 `NERtc` 5.3.7 版本

## v3.13.0(June 21, 2023)
### New Features
* 新增 `NEMeetingOptions.enableAudioShare` 入会选项,配置开启/关闭屏幕共享时的音频共享功能;
### API Changes
* 删除 `NEMeetingKitConfig.reuseIM` 字段,不影响 IM 复用的逻辑;
### Fixed
* 修复音频智能降噪不生效问题;
### Compatibility
* 兼容 `NERoom` 1.16.0 版本
* 兼容 `NIM` 9.10.0 版本
* 兼容 `NERtc` 5.3.7 版本

## v3.11.0(April 27, 2023)
### New Features
* 新增 `NEMeetingOptions.enableTransparentWhiteboard` 入会选项,配置开启/关闭白板透明标注模式;
* 新增 `NEMeetingOptions.enableFrontCameraMirror` 入会选项,配置开启/关闭前置摄像头画面镜像;
### Compatibility
* 兼容 `NERoom` 1.14.0 版本
* 兼容 `NIM` 9.8.0 版本
* 兼容 `NERtc` 4.6.50 版本

## v3.10.0(April 10, 2023)
### New Features
* 新增会议最小化接口:`NEMeetingService.minimizeCurrentMeeting`
* 支持跨AppKey加会议
### API Changes
* 重命名API中会议号字段,会议号(字符串类型)统一使用`meetingNum`命名。被重命名的字段包括:
* `NEMeetingParams.meetingId`
* `NEAccountInfo.meetingId`, `NEAccountInfo.shortMeetingId`
* `NEHistoryMeetingItem.getMeetingId()`, `NEHistoryMeetingItem.getShortMeetingId()`
* `NEMeetingItem.getMeetingId()`
* `NEMeetingInfo.meetingId`, `NEMeetingInfo.shortMeetingId`
* 重命名API中会议唯一Id字段,会议唯一Id(长整型)统一使用`meetingId`命名。被重命名的字段包括:
* `NEMeetingInfo.meetingUniqueId`
* `NEMeetingItem.getMeetingUniqueId()`
* `NEHistoryMeetingItem.getMeetingUniqueId()`
### Compatibility
* 兼容 `NERoom` 1.13.0 版本
* 兼容 `NIM` 9.8.0 版本
* 兼容 `NERtc` 4.6.50 版本
* 兼容 `Common` 1.1.15 版本
* 兼容 `CoreKit` 1.3.0 版本


## v3.9.1(May 11, 2023)
### Bug Fixes
* 修复接听电话时进行本端属性修改时序可能出错的问题;
* 调整绑定画布和订阅的时序,调整为先绑定画布后订阅视频,规避可能出现的黑屏问题(sub、unsub、sub连续信令可能造成订阅后没有流数据);
* 新增退后台检测功能,并自动关闭视频,在回到前台后自动重新打开视频;
* 美颜功能不可用时不初始化美颜模块;
### Compatibility
* 兼容 `NERoom` 1.12.0 版本

## v3.9.0(March 02, 2023)
### New Features
* 新增网络质量检测能力;
* 新增会议系统电话接听处理能力;
* 优化共享&白板下的显示;
* 其他已知问题修复;
### Compatibility
* 兼容 `NERoom` 1.12.0 版本

## v3.8.0(January 09, 2023)
### New Features
* 新增`NEMeetingKitConfig.serverUrl`, 用于设置组件私有化服务器地址;
* 新增`NEMeetingOptions.showScreenShareUserVideo`选项控制观看共享时是否显示屏幕共享者的摄像头画面;
* 新增`NEMeetingOptions.showWhiteboardShareUserVideo`选项控制观看白板时是否显示白板共享者的摄像头画面;
* 新增`NEMeetingOptions.showFloatingMicrophone`选项控制是否显示麦克风悬浮窗;
* 会议中小窗口支持滑动;
### Compatibility
* 兼容 `NERoom` 1.11.0 版本

## v3.7.1(December 15, 2022)
### Bug Fixes
* 多语言文案更新

## v3.7.0(December 07, 2022)
### New Features
* 支持多语言
* 新增`NEMeetingLanguage`类型,枚举组件支持的语言类型;
* 新增`NEMeetingKit.switchLanguage`方法,可切换到对应的语言类型;
* 新增`NEMeetingOptions.detectMutedMic`选项控制是否开启麦克风静音检测功能;
* 新增`NEMeetingOptions.unpubAudioOnMute`选项控制本端静音时是否继续发送静音音频包;
### Compatibility
* 兼容 `NERoom` 1.10.0 版本

## v3.6.0(October 31, 2022)
### New Features
* 修复已知问题
### Compatibility
* 兼容 `NERoom` 1.8.2 版本

## v3.5.0(September 27, 2022)
### New Features
* Flutter端MeetingKit重构
* 修复已知问题
### Compatibility
* 兼容 `NERoom` 1.8.0 版本

## v3.4.0(August 31, 2022)
### New Features
* 聊天室支持图片、文件消息发送与接收
* 新增`NEMeetingOptions.chatroomConfig`字段,类型为`NEMeetingChatroomConfig`:可配置聊天室内相关功能是否开启
* 支持全局事件监听
* 新增`NEGlobalEventListener`全局事件监听器,可监听 RTC 实例创建、销毁的事件
* 新增`NEMeetingKit.addGlobalEventListener`添加全局事件监听
* 新增`NEMeetingKit.removeGlobalEventListener`移除全局事件监听
### Compatibility
* 兼容 `NERoom` 1.7.0 版本

## v3.3.0(July 28, 2022)
### New Features
* 白板共享时支持上传视频和图片
* 预约会议支持配置`SIP`功能开关:`NEMeetingItem#setNoSip`
* 新增会议倒计时结束时间提醒功能开关:`NEMeetingOptions#showMeetingRemainingTip`,默认关闭

## v3.2.0(June 30, 2022)
### New Features
* 支持虚拟背景功能:
* 新增方法:`NESettingsService#enableVirtualBackground`,开启虚拟背景配置
* 新增方法:`NESettingsService#isVirtualBackgroundEnabled`,是否支持虚拟背景
* 新增方法:`NESettingsService#setBuiltinVirtualBackgrounds`,设置自定义背景图片列表
* 新增方法:`NESettingsService#getBuiltinVirtualBackgrounds`,获取内置虚拟背景列表
* 支持IM SDK复用:
* 新增字段:`NEMeetingKitConfig#reuseIM`,是否复用im
* G2 SDK版本升级至4.6.13
* 支持美颜功能,无对外接口变更
* 支持SIP邀请,无对外接口变更
* 支持联席主持人, 新增枚举字段:`NEMeetingRoleType#coHost`,联席主持人


## v3.1.0(June 19, 2022)
### New Features
* 新增方法:`NEMeetingService#anonymousJoinMeeting`,支持会议组建匿名入会
* 支持SIP功能:
* 新增字段:`NEMeetingOptions#noSip`,支持会议内是否显示sip号,默认false
* 新增字段:`NEMeetingInfo#sipId`,支持通过`NEMeetingService#getCurrentMeetingInfo`获取会议sipId
* 支持私有化功能:
* 新增字段:`NEMeetingKitConfig#useAssetServerConfig`,支持读取asset目录下的私有化配置文件`xkit_server.config`
* 调整内部代码工程结构

## v3.0.0(May 19, 2022)
### New Features
* 基于`NERoom`1.1.0版本进行SDK架构升级和改造

### API Changes
* Maven GAV变更:`com.netease.yunxin:meetinglib` 重命名为 `com.netease.yunxin.kit.meeting:meeting`
* 对外包名修改:`com.netease.meetinglib.sdk` 重命名为 `com.netease.yunxin.kit.meeting.sdk`
* 接口类名:`NEMeetingSDK` 重命名为 `NEMeetingKit`
* `com.netease.meetinglib.sdk.NEMeetingSDKConfig` 重命名为 `com.netease.yunxin.kit.meeting.sdk.NEMeetingKitConfig`
* NEMeetingKitConfig:
- 删除deprecated字段:`domain``enableDebugLog``logSize``reuseNIM`
* 隐藏暂不支持的功能字段:`useAssetServerConfig`
* NEMeetingOptions:
- 删除deprecated字段:`audioAINSEnabled``injectedMoreMenuItems`
* 隐藏暂不支持字段:`NEMeetingOptions.noSip`
* 删除 NEMeetingMenuItem 类型 - deprecated
* 删除场景相关API:
* `NEMeetingScene.java`
* `NEMeetingRoleConfiguration.java`
* `NEStartMeetingParams.scene` 字段
* `NEMeetingItemSetting.scene` 字段
* `NEMeetingService.java`修改:
* 删除`NEMeetingService.java`不支持接口:`subscribeRemoteAudioStream``subscribeRemoteAudioStreams``subscribeAllRemoteAudioStreams`
* 删除`NESettingsService.java`以下美颜相关的api
30 changes: 30 additions & 0 deletions SampleCode/Android/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
# NEMeetingKit

会议组件, 内置标准会议场景UI,可快速集成实现标准音视频会议功能。

[Release notes](https://doc.yunxin.163.com/meetingkit/docs/home-page?platform=android)

[Reference documentation](https://doc.yunxin.163.com/docs/interface/NEMeetingKit/Latest/Android/)

[Browse source](https://g.hz.netease.com/yunxin-app/xkit-flutter/-/tree/master/meeting)

### Declaring dependencies
如需添加 NEMeetingKit 的依赖项,您必须将 mavenCentral 代码库添加到项目中。

在应用或模块的 `build.gradle` 文件中添加所需组件的依赖项:

* Kotlin
```
dependencies {
val meetingkit_version = "3.16.0"
implementation("com.netease.yunxin.kit.meeting:meeting:$meetingkit_version")
}
```

* Groovy
```
dependencies {
def meetingkit_version = "3.16.0"
implementation "com.netease.yunxin.kit.meeting:meeting:$meetingkit_version"
}
```
10 changes: 10 additions & 0 deletions SampleCode/Android/app/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,16 @@ Appkey是应用接入会议SDK的凭证,开发者首先需要在网易会议

完成AppKey的申请和声明后,运行示例项目可体验“加入会议”功能,但无法使用“登录”、“创建会议”功能。

#### 对接会议账号

为了体验示例项目中的创建会议功能,在以上完善应用Appkey的基础上,还需要使用会议账号完成SDK的登录鉴权。

会议SDK的登录鉴权需要提供一个有效的会议账号(可使用网易会议PaaS服务提供的创建会议账号接口完成创建),并通过对应的账号ID和TOKEN来完成登录鉴权。

在此示例项目中,开发者需要实现`com.netease.yunxin.kit.meeting.sampleapp.data.DefaultDataRepository#getSDKAuthInfo`方法,返回当前对应AppKey下一个真实有效的会议账号的ID和TOKEN,它们会被用来作为参数完成会议SDK中 login 接口的调用。

完成会议账号的登录实现后,运行示例项目,即可体验完整的会议功能。

### 运行环境

- Android Studio 3.0 +
Expand Down
11 changes: 6 additions & 5 deletions SampleCode/Android/app/build.gradle
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,6 @@ apply plugin: 'kotlin-android'

android {
compileSdkVersion 33
buildToolsVersion "29.0.3"

viewBinding {
enabled = true
Expand All @@ -13,8 +12,8 @@ android {
applicationId "com.netease.yunxin.kit.meeting.sampleapp"
minSdkVersion 21
targetSdkVersion 31
versionCode 31000
versionName "3.10.0"
versionCode 31600
versionName "3.16.0"

testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
}
Expand All @@ -39,10 +38,12 @@ android {
pickFirst 'lib/armeabi-v7a/libc++_shared.so'
}
}

repositories {
flatDir dirs: 'libs'
}
dependencies {
// meeting
implementation 'com.netease.yunxin.kit.meeting:meeting:3.15.0'
implementation 'com.netease.yunxin.kit.meeting:meeting:3.16.1'

implementation "org.jetbrains.kotlin:kotlin-stdlib:$kotlin_version"
implementation 'org.jetbrains.kotlinx:kotlinx-coroutines-core:1.4.3'
Expand Down

This file was deleted.

1 change: 1 addition & 0 deletions SampleCode/Android/app/src/main/AndroidManifest.xml
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@
<activity
android:name=".MainActivity"
android:screenOrientation="portrait"
android:supportsPictureInPicture="false"
android:resizeableActivity="false"
android:exported="true">
<intent-filter>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -29,6 +29,7 @@
import com.netease.yunxin.kit.meeting.sdk.NEMeetingStatus;
import com.netease.yunxin.kit.meeting.sdk.menu.NEMenuClickInfo;
import com.netease.yunxin.kit.meeting.sdk.menu.NEMenuStateController;
import java.lang.reflect.Method;

public class MainActivity extends BaseActivity<ActivityMainBinding> {

Expand Down Expand Up @@ -165,6 +166,17 @@ public boolean onOptionsItemSelected(@NonNull MenuItem item) {
case R.id.im_login:
NIMLoginActivity.start(this);
break;
case R.id.open_flutter_page:
try {
Class<?> clz =
Class.forName("com.example.flutter_module_library.FlutterContainerActivity");
Method startCached = clz.getDeclaredMethod("startCached", Context.class);
startCached.setAccessible(true);
startCached.invoke(null, this);
} catch (Throwable e) {
e.printStackTrace();
}
break;
case R.id.minimize_meeting:
minimizeCurrentMeeting();
break;
Expand Down Expand Up @@ -232,13 +244,13 @@ private void updateMeetingTime(String timeText) {
private void checkAppKey() {
String appKey = MeetingApplication.getInstance().getServerConfig().getAppKey();
if ("Your AppKey".equals(appKey)) {
new AlertDialog.Builder(this)
.setTitle("检测到AppKey未设置")
.setMessage("请在'appkey.xml'文件中填入正确的AppKey")
.setPositiveButton("OK", null)
.setCancelable(false)
.create()
.show();
new AlertDialog.Builder(this)
.setTitle("检测到AppKey未设置")
.setMessage("请在'appkey.xml'文件中填入正确的AppKey")
.setPositiveButton("OK", null)
.setCancelable(false)
.create()
.show();
}
}
}
Loading

0 comments on commit a6045f2

Please sign in to comment.